git常用命令

git 官方文档 :https://git-scm.com/book/zh/v2/%E8%B5%B7%E6%AD%A5-%E5%85%B3%E4%BA%8E%E7%89%88%E6%9C%AC%E6%8E%A7%E5%88%B6

基础

git help checkout 查看git checkout的命令帮助
git clone https://github.com/libgit2/libgit2 克隆远程仓库到本地
git status 查看当前分支状态
git add m.js将m.js放到暂存区域
git commit -m 'desc' 提交更新并且添加备注desc
git commit -am 'desc' 跳过使用暂存区域直接提交更新并且添加备注desc
git push 推送更新到远程仓库
git pull 获取远程仓库的更新

分支管理

git chekcout mobile 如果存在mobile分支,切换到mobile分支;否则新建mobile分支
git branch -d mobile 删除mobile分支
git checkout -b mobile origin/mobile 拉取远程分支mobile到本地
git chekcout -b mobile 基于当前分支新建并切换到mobile分支
git push origin mobile将本地的mobile分支同步到远程仓库
git push origin --delete mobile删除远程的mobile分支
git ls-remote 查看远程分支列表
git merge mobile 将mobile分支合并到当前分支

标签管理

git tag 查看本地标签列表
git tag -a v1.4 -m 'my version 1.4' 创建标签v1.4,并且添加标签说明“my version 1.4”
git push origin v1.4 将标签v1.4同步到远程仓库
git push origin --tags 将所有本地标签同步到远程仓库
git tag -d v1.4 删除标签v1.4
git push origin :refs/tags/v1.4 删除远程仓库标签v1.4
git tag v1.4new v1.4 复制v1.4标签,生成v1.4new标签
git checkoout v1.4 切换当前文件到v1.4(跟切换分支的命令一致)
git checkout -b mobile v1.4 基于v1.4标签生成mobile分支

其他

git reset HEAD m.js 取消m.js的暂存
git checkout -- m.js 撤销m.js的本地修改
git reset --hard 版本序列号 还原本地文件到某个版本
git reset --hard HEAD~2工作目录、暂存区域、本地仓库回退到上2个版本
git log master ^origin/master 查看到未传送到远程代码库的提交详情

如何只更新某个文件?

git fetch origin master先更新本地库(但不更新工作拷贝)
git log -p master..origin/master 查看差异
git checkout origin/master -- path/to/file 更新单个文件的工作拷贝

而 更新所有文件的工作拷贝 的命令如下:
git merge origin/master

某个文件的某一行修改了,如何追踪修改人?

git blame m.js
git gui blame m.js 使用git GUI界面来查看每一行的变化,更直观

如何查看某个文件的历史修改?

git log m.js
git show 版本号 查看某个版本的修改详情

如何对某个文件进行版本回退?

git log m.js
git reset 9aa51d89799716aa68cff3f30c26f8815408e926 m.js 将m.js回退到某个版本
git checkout m.js
git commit -m "m.js回退版本"
或者
git checkout 9aa51d89799716aa68cff3f30c26f8815408e926 m.js

如何对某个文件取消版本控制,但是不删除?
git rm --cached m.js
然后更新 .gitignore 忽略掉目标文件,最后
git commit -m "We really don't want Git to track m.js anymore!"

如何查看差异?

git diff HEAD工作目录与上次提交时之间的所有差别
git diff 查看尚未暂存的文件更新了哪些部分
git diff filename 查看尚未暂存的某个文件更新了哪些
git diff --cached 查看已经暂存起来的文件和上次提交的版本之间的差异
git diff --cached filename 查看已经暂存起来的某个文件和上次提交的版本之间的差异
git diff ffd98b291e0caa6c33575c1ef465eae661ce40c9 b8e7b00c02b95b320f14b625663fdecf2d63e74c 查看某两个版本之间的差异
git diff ffd98b291e0caa6c33575c1ef465eae661ce40c9:filename b8e7b00c02b95b320f14b625663fdecf2d63e74c:filename 查看某两个版本的某个文件之间的差异

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

推荐阅读更多精彩内容

  • 我的常用: ===================================** 撤销工作修改:**1、gi...
    ddai_Q阅读 721评论 0 5
  • 获得版本库 git init git clone​ 查看信息 git help Git log​ 查看提交日志 g...
    持续进步者阅读 326评论 0 3
  • 分布式版本管理工具 git属于分布式 svn集中式 git安装 git初始化一个仓库 其实就是创建了一个.git隐...
    SnowDragonYY阅读 1,503评论 0 0
  • 遇到什么事情,都要好好,平静应对就好,正如刚才梦真说磨牙,是自己问的,想要牙更好啊,不必不开心,可能不开心,是由于...
    宋长金j阅读 183评论 0 0
  • 前言 AFNetworking其实实现的原理就是使用NSURLSession类,只不过使用对NSURLSessio...
    峰子1994阅读 666评论 0 0