工作常用 Git 命令

阅读目录:

  1. Git 基础概念
  2. 常用的命令
  3. 简明指南
    3.1 创建新仓库
    3.2 检出仓库
    3.3 添加和提交
    3.4 推送改动
    3.5 分支管理
    3.6 更新与合并
    3.7 查看历史
    3.8 版本回退
    3.9 删除文件
    3.10 远程仓库命令总结
    3.11 分支操作命令总结
  4. 参考文献

Git是Linus Benedict Torvalds更好的管理Linux系统而开发的一个“分布式版本控制工具”,对团队协作开发极其友好。高端大气上档次!

Git命令超级的多,所以本文只列举工作中最常用的几条命令:

0. GIt 基础概念

工作区(Working Directory):简单的说,就是本地可以编辑的文件;

版本库(Repository):工作区有一个隐藏目录 .git ,这个不算工作区,而是Git的版本库;

暂存区(stage):git add 后还没有提交到仓库的中间状态;

此外还有Git为我们自动创建的第一个分支 master,以及指向master的一个指针叫 HEAD

HEAD : 它指向你最后一次提交的结果。

Git 模型图:

Git 模型

1. 常用的命令

一周工作中,最常用的三种命令,总结成三个字:拉、提、推。
即:拉取远程仓库最新代码、提交代码到仓库、推送本地代码到远程

拉取远程仓库最新代码

1. git fetch origin <branch-name> // 先从远程分支抓取最新代码
2. git merge --no-ff -m '<merge message>' // 将抓下来的远程代码和本地代码合并

提交代码到仓库

将远程分支代码拉取下来以后,和本地代码合并,解决冲突后,提交自己的修改

1. git add <file-name> // 添加文件到暂存区
2. git commit -m '<commit message>'  // 将暂存区提交到仓库

推送本地代码到远程

1. git push // 将本地代码推送到远程仓库

2. 简明指南

2.1 创建新仓库

创建新文件夹,打开,然后执行

git init

以创建新的 git 仓库。

2.2 检出仓库

克隆远端服务器上的仓库:

git clone <respository-path>

2.3 添加和提交

你可以提出更改(把它们添加到暂存区),使用如下命令:
git add <filename> 或 git add --all
这是 git 基本工作流程的第一步;使用如下命令以实际提交改动:

git commit -m "代码提交信息"

现在,你的改动已经提交到了 HEAD,但是还没到你的远端仓库。

2.4 推送改动

你的改动现在已经在本地仓库的 HEAD中了。执行如下命令以将这些改动提交到远端仓库:

git push origin master

可以把 master 换成你想要推送的任何分支

2.5 分支管理

分支是用来将特性开发绝缘开来的。在你创建仓库的时候,master 是“默认的”分支。在其他分支上进行开发,完成后再将它们合并到主分支上。

创建一个叫做“feature_x”的分支,并切换过去:

git checkout -b feature_x

切换回主分支:

git checkout master

再把新建的分支删掉:

git branch -d feature_x

2.6 更新与合并

要更新你的本地仓库至最新改动,执行:

git pull

以在你的工作目录中 获取(fetch) 并 合并(merge) 远端的改动。
要合并其他分支到你的当前分支(例如 master),执行:

git merge <branch>

在这两种情况下,git 都会尝试去自动合并改动。遗憾的是,这可能并非每次都成功,并可能出现冲突(conflicts)。 这时候就需要你修改这些文件来手动合并这些冲突(conflicts)。改完之后,你需要执行如下命令以将它们标记为合并成功:

git add <filename>

在合并改动之前,你可以使用如下命令预览差异:

git diff <source_branch> <target_branch>

2.7 查看历史

如果你想了解本地仓库的历史记录,最简单的命令就是使用:

git log

你可以添加一些参数来修改他的输出,从而得到自己想要的结果。 只看某一个人的提交记录:

git log --author=<name>

一个压缩后的每一条提交记录只占一行的输出:

git log --pretty=oneline --abbrev-commit

或者你想通过 ASCII 艺术的树形结构来展示所有的分支, 每个分支都标示了他的名字和标签:

git log --graph --oneline --decorate --all

看看哪些文件改变了:

git log --name-status

这些只是你可以使用的参数中很小的一部分。更多的信息,参考:

git log --help

最全的一条查看历史命令:

git log --graph --pretty=oneline --abbrev-commit --decorate --all

2.8 版本回退

已经添加到暂存区stage,恢复到工作区:

git reset HEAD <file-name>

用版本库里的版本替换工作区的版本代码:

git checkout -- fileName

版本回退到上一个版本:

git reset --hard HEAD^

版本回退到某个提交:

git reset --hard <commit-id>

2.9 删除文件

rm fileName //删除本地,可直接git rm
git rm file Name //修改进入缓存区
git commit -m '' //提交到版本库

2.10 远程仓库命令总结

经过以上操作后,代码已经可以提交到本地的Git仓库,下面介绍远程仓库的一些操作

本地Git仓库和GitHub仓库之间的传输密钥:

ssh-keygen -t rsa -C "youremail@example.com" //使本机可以往github上提交

把本地仓库的内容关联到GitHub仓库:

git remote add origin git@github.com:user-name/respository-name.git

本地库的所有内容推送到远程库(初始化一个远程仓库代码):

git push -u origin master //当前分支master所有代码推送到远程进行初始化

本地修改后提交到远程仓库 (修改推送):

git push origin branch-name

从远程仓库克隆一个仓库到本地 :

git clone git@github.com:zhangyusir/hello.git

本地和远程同时创建分支产生关联:

git checkout -b branch-name origin/branch-name

将本地的分支和远程的分支关联起来:

git branch --set-upstream-to branch-name origin-name

2.11 分支操作命令总结

查看本地分支:

git branch

创建分支并切换:

git checkout -b <branch-name>

切换分支:

git checkout<branch-name>

在当前分支快速合并其他分支:

git merge branch-name

保留分支的提交历史既禁止快速合并:

git merge --no-ff -m "commit message" branch-name

删除分支:

git branch -d branch-name //强制删除-D

将当前分支的修改放到“储藏”:

存储 :git stash 恢复 : git stash pop 列表 : git stash list

3. 参考文献

  1. 廖雪峰:https://www.liaoxuefeng.com/wiki/896043488029600
  2. 阮一峰:http://www.ruanyifeng.com/blog/2014/06/git_remote.html
  3. 简明指南:http://rogerdudler.github.io/git-guide/index.zh.html
  4. Git奇技淫巧:https://github.com/521xueweihan/git-tips
  5. Git Book:https://git-scm.com/book/zh/v2
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • 1. 安装 Github 查看是否安装git: $ git config --global user.name "...
    Albert_Sun阅读 13,649评论 9 163
  • 查看、添加、提交、删除、找回,重置修改文件 git help # 显示command的help git sho...
    Swiftor阅读 2,111评论 0 2
  • 声明:这篇文章来源于廖雪峰老师的官方网站,我仅仅是作为学习之用 Git简介 Git是什么? Git是目前世界上最先...
    横渡阅读 3,950评论 3 27
  • (预警:因为详细,所以行文有些长,新手边看边操作效果出乎你的预料) 一:Git是什么? Git是目前世界上最先进的...
    axiaochao阅读 1,928评论 1 8
  • 分布式版本管理工具 git属于分布式 svn集中式 git安装 git初始化一个仓库 其实就是创建了一个.git隐...
    SnowDragonYY阅读 1,504评论 0 0