git 命令行操作

这里参考廖雪峰老师的教程,一步步重头操作一遍。

概念

Git:分布式版本控制系统
和svn 这种集中式的版本控制系统比较

集中式版本控制系统:版本库是存放在中央服务器的,必须联网才能工作;
分布式版本控制系统:每个人的电脑都是一个完整的版本库,工作的时候不需要联网;
分布式的安全性高,一个人的损坏了可以从其他人那里拷贝,而集中式的,中央服务挂掉,所有人都干不了活

操作

前提安装了git

git --version
//git version 1.7.11.msysgit.1
1.本地创建版本库
mkdir git-operate
cd git-operate
2.把目录变成git管理的仓库
git init
3.新建readme.txt文件添加到git仓库
git add readme.txt  //执行上面的命令,没有任何显示,这就对了,Unix的哲学是“没有消息就是好消息”,说明添加成功。
4.用git commit 提交到仓库
git commit -m "add new file"
[master (root-commit) c0b6535] add new file
 1 file changed, 2 insertions(+)
 create mode 100644 readme.txt
5.通常我们会修改已有的文件,用git status查看当前仓库文件的状态
$ git status
# On branch master
# Changes not staged for commit:
#   (use "git add <file>..." to update what will be committed)
#   (use "git checkout -- <file>..." to discard changes in working directory)
#
#       modified:   readme.txt
#
no changes added to commit (use "git add" and/or "git commit -a")
6.git status告诉我们文件的状态,现在看看修改的内容
$ git diff readme.txt
diff --git a/readme.txt b/readme.txt
index 013b5bc..d8036c1 100644
--- a/readme.txt
+++ b/readme.txt
@@ -1,2 +1,2 @@
-Git is a distributed version control system.
+Git is a version control system.
 Git is free software.
\ No newline at end of file
7.提交修改之后的文件(提交修改和提交新文件是一样的两步:git add、git commit)
$ git add readme.txt

$ git status
# On branch master
# Changes to be committed:
#   (use "git reset HEAD <file>..." to unstage)
#       modified:   readme.txt

$ git commit -m "modify file"
[master ee01550] modify file
 1 file changed, 1 insertion(+), 1 deletion(-)

$ git status
# On branch master
nothing to commit (working directory clean)
8.使用git status命令随时掌握工作区的状态
9.将本地版本库推到github上

首先:github上建ssk key参考链接:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/001374385852170d9c7adf13c30429b9660d0eb689dd43a000

然后:在github上新建一个和本地同名的仓库,参考链接:
https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013752340242354807e192f02a44359908df8a5643103a000


最后:根据提示将本地仓库和github仓库关联

$ git remote add origin git@github.com:mxcz213/git-operate.git

$ git push -u origin master
Counting objects: 7, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (5/5), done.
Writing objects: 100% (7/7), 609 bytes, done.
Total 7 (delta 1), reused 0 (delta 0)
remote: Resolving deltas: 100% (1/1), done.
To git@github.com:mxcz213/git-operate.git
 * [new branch]      master -> master
Branch master set up to track remote branch master from origin.

//把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。
//由于远程库是空的,我们第一次推送master分支时,加上了-u参数,
//Git不但会把本地的master分支内容推送的远程新的master分支,
//还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
//以后再提交远程仓库就是git push origin master
10.克隆一个远程仓库
git clone git@github.com:mxcz213/git-operate.git
11.多次修改提交之后,想改回某一个版本,版本回退,查看提交日志
git log    //显示从最近到最远的提交日志
$ git log --pretty=oneline        //单行输出log信息
c0160df418d31c3b4d3792c814cbad2b90b4b613 commit again
1852c62687999bb837ff09831c9898e5faede408 modify file
ee01550aee99f47270cb7c8b9bf08e9ca6431bde modify file
c0b6535d48040e1a26d4cb9cbc1bbef13121b62d add new file

把readme.txt回退到上一个版本modify file
在git中HEAD表示当前版本,上一个版本是HEAD,上上一个版本是HEAD^,往上很多版本比如100个就是HEAD~100,使用git reset命令回退版本

$ git reset --hard HEAD^
HEAD is now at 1852c62 modify file

$ cat readme.txt
Git is a distributed version control system.
Git is free software. 
//文件被还原了
//通过commit id来回退版本,缩写id,git自己会去找
$ git log --pretty=oneline
1852c62687999bb837ff09831c9898e5faede408 modify file
ee01550aee99f47270cb7c8b9bf08e9ca6431bde modify file
c0b6535d48040e1a26d4cb9cbc1bbef13121b62d add new file

 $ git reset --hard ee01
HEAD is now at ee01550 modify file

$ git log --pretty=oneline
ee01550aee99f47270cb7c8b9bf08e9ca6431bde modify file
c0b6535d48040e1a26d4cb9cbc1bbef13121b62d add new file

$ git reflog     //记录每一次的命令
ee01550 HEAD@{0}: reset: moving to ee01
1852c62 HEAD@{1}: reset: moving to HEAD^
c0160df HEAD@{2}: commit: commit again
1852c62 HEAD@{3}: commit: modify file
ee01550 HEAD@{4}: commit: modify file
c0b6535 HEAD@{5}: commit (initial): add new file

重点--分支管理

master分支只来提交,每次有新功能,每个人都可以建自己的分支,在分支上开发,完成之后合并到master分支,防止代码丢失或者影响到别人的开发进度。

1.创建dev分支,并切换到dev分支
2.查看当前分支
3.修改readme.txt文件内容:Creating a new branch is quick.
4.查看当前dev分支里readme.txt文件内容
5.切换并查看master分支里readme.txt文件内容
6.合并dev分支的内容到master分支

mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ git checkout -b dev      //创建dev分支并切换到dev分支
Switched to a new branch 'dev'

mxcz@ITA-1401-0047 /E/workCode/git-operate (dev)
$ git branch    //查看分支
* dev
  master

//修改dev分支里面readme.txt文件的内容为:`Creating a new branch is quick.`然后提交
mxcz@ITA-1401-0047 /E/workCode/git-operate (dev)
$ git add readme.txt

mxcz@ITA-1401-0047 /E/workCode/git-operate (dev)
$ git commit -m "branch test"
[dev e0d6643] branch test
 1 file changed, 1 insertion(+), 2 deletions(-)

mxcz@ITA-1401-0047 /E/workCode/git-operate (dev)
$ git checkout master    //切换分支到master
Switched to branch 'master'
Your branch is behind 'origin/master' by 1 commit, and can be fast-forwarded.

mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ cat readme.txt
Git is a version control system.
Git is free software.
mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ git checkout dev
Switched to branch 'dev'

mxcz@ITA-1401-0047 /E/workCode/git-operate (dev)
$ cat readme.txt
Creating a new branch is quick.

mxcz@ITA-1401-0047 /E/workCode/git-operate (dev)
$ git checkout master
Switched to branch 'master'
Your branch is behind 'origin/master' by 1 commit, and can be fast-forwarded.

mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ git merge dev      //将dev分支合并到master分支(这种合并分支不会保存分支操作记录)
Updating ee01550..e0d6643
Fast-forward
 readme.txt | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)

mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ cat readme.txt    //合并成功,文件被修改
Creating a new branch is quick.

mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ git branch -d dev     //删除dev分支
Deleted branch dev (was e0d6643).

mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ git branch    //查看分支只剩master分支了
* master
保留分支记录的操作git merge -m "merge with --no-ff" bug-101
mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ git checkout -b bug-101
Switched to a new branch 'bug-101'

mxcz@ITA-1401-0047 /E/workCode/git-operate (bug-101)
$ cat readme.txt
Creating a new branch is quick.
create a bug-101 branch
mxcz@ITA-1401-0047 /E/workCode/git-operate (bug-101)
$ git add readme.txt

mxcz@ITA-1401-0047 /E/workCode/git-operate (bug-101)
$ git commit -m "create bug-101 branch"
[bug-101 5fc13df] create bug-101 branch
 1 file changed, 1 insertion(+)

mxcz@ITA-1401-0047 /E/workCode/git-operate (bug-101)
$ git branch
* bug-101
  master

mxcz@ITA-1401-0047 /E/workCode/git-operate (bug-101)
$ git checkout master
Switched to branch 'master'
Your branch and 'origin/master' have diverged,
and have 1 and 1 different commit each, respectively.

mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ git merge --no-ff -m "merge with no-ff" bug-101
Merge made by the 'recursive' strategy.
 readme.txt | 1 +
 1 file changed, 1 insertion(+)

mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ git log --graph --pretty=oneline --abbrev-commit
*   02bbf1a merge with no-ff
|\
| * 5fc13df create bug-101 branch
|/
* e0d6643 branch test
* ee01550 modify file
* c0b6535 add new file

此时的分支信息就有保留,使用--no-ff,这时master就不再是一条直线了,分叉了。
但是git可以通过rebase变基成为一条干净的线;

先解决冲突
mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ git push origin master
To git@github.com:mxcz213/git-operate.git
 ! [rejected]        master -> master (non-fast-forward)
error: failed to push some refs to 'git@github.com:mxcz213/git-operate.git'
hint: Updates were rejected because the tip of your current branch is behind
hint: its remote counterpart. Merge the remote changes (e.g. 'git pull')
hint: before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.

mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ git pull
Auto-merging readme.txt
CONFLICT (content): Merge conflict in readme.txt
Automatic merge failed; fix conflicts and then commit the result.

mxcz@ITA-1401-0047 /E/workCode/git-operate (master|MERGING)
$ cat readme.txt
<<<<<<< HEAD
Creating a new branch is quick.
create a bug-101 branch
=======
Git is a distributed version control system.
Git is free software.
>>>>>>> 1852c62687999bb837ff09831c9898e5faede408

打开readme.txt文件,手动删掉冲突<<<<<<<=======>>>>>>>的部分,然后提交

mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ git push origin master
Counting objects: 14, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (6/6), done.
Writing objects: 100% (10/10), 994 bytes, done.
Total 10 (delta 1), reused 0 (delta 0)
remote: Resolving deltas: 100% (1/1), done.
To git@github.com:mxcz213/git-operate.git
   1852c62..6ac178c  master -> master

mxcz@ITA-1401-0047 /E/workCode/git-operate (master)
$ git log --graph --pretty=oneline --abbrev-commit
*   6ac178c fixed conflict
|\
| * 1852c62 modify file
* |   02bbf1a merge with no-ff
|\ \
| * | 5fc13df create bug-101 branch
|/ /
* | e0d6643 branch test
|/
* ee01550 modify file
* c0b6535 add new file
如果commit的注释写错了,要修改掉,怎么办?下面来操作修改最后一次提交的注释change file改成change file xxx
git log
commit 9219151d7352b0561ae2d1d5c5c20a4c6dfbd4d1
Author: mxcz<chenjuanhe@pptv.com>
Date:   Fri Mar 15 13:33:54 2019 +0800

    change file

commit 6ac178c4d6672ac7de86ed9f7775da908cd02668
Merge: 02bbf1a 1852c62
Author: mxcz<chenjuanhe@pptv.com>
Date:   Thu Mar 14 17:17:02 2019 +0800

    fixed conflict
$ git commit --amend   //进入修改commit里


改成change file xxx,然后按Esc,再按:wq保存退出编辑:

mxcz@ITA-1401-0047 /E/workCode/git-operate (master|REBASE-i)
$ git commit --amend
[master 464ab48] change file xxx
 1 file changed, 5 deletions(-)

然后强制推到服务器

$ git push -f
Counting objects: 5, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 294 bytes, done.
Total 3 (delta 0), reused 0 (delta 0)
To git@github.com:mxcz213/git-operate.git
 + 9219151...464ab48 master -> master (forced update)

此时再查看git log提交历史,commitmessage已经被修改过来

$ git log
commit 464ab488219208a9e30bcd5b7cb6e5b37c7a43a3
Author: mcxz<chenjuanhe@pptv.com>
Date:   Fri Mar 15 13:33:54 2019 +0800

    change file xxx

commit 6ac178c4d6672ac7de86ed9f7775da908cd02668
Merge: 02bbf1a 1852c62
Author: mxcz<chenjuanhe@pptv.com>
Date:   Thu Mar 14 17:17:02 2019 +0800

    fixed conflict
git打标签
$ git tag test_20190315_html

$ git push origin test_20190315_html
Total 0 (delta 0), reused 0 (delta 0)
To git@github.com:mxcz213/git-operate.git
 * [new tag]         test_20190315_html -> test_20190315_html

$ git tag
test_20190315_html

总结

关联远程仓库
// 关联远程
git remote add origin git项目地址
//查看远程关联的地址
git remote -v
// 移除远程关联
git remote remove origin
添加文件

git add . 将所有文件添加到暂存区

分支管理

Git鼓励大量使用分支:
查看分支:git branch
切换分支:git checkout <branch name>
创建本地分支:git branch <branch name>
创建+切换本地分支:git checkout -b <branch name>
将新建的分支推到远程:git push origin <branch name>

合并某分支到当前分支:git merge <branch name> (这种合并分支不会保存分支操作记录)
查看远端所有分支:git branch -a
强制删除本地分支:git branch -D <branch name>
删除远程分支:git push origin --delete <branch name>

git回滚merge

git merge feat-branch 的话,想要回滚回去:
git reflog 查看提交记录的版本号
git reset --hard 版本号 回滚到merge之前的状态

标签

git tag [tag name] #给当前分支的最后一次commit打上标签
git tag [tag name] [commit id] #给指定的commit打上标签
git tag -a [tag name] -m "[comment]" [commit id] #创建有说明的标签
git tag #显示所有标签
git show [tag name] #显示指定标签的提交信息
git tag -d [tag name] #删除标签
git push origin [tag name] #推送指定标签到远程
git push origin --tags #推送所有本地标签到远程

参考:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000
https://www.jianshu.com/p/c4e66d70e858
https://www.jianshu.com/p/54cd784fc9aa

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

推荐阅读更多精彩内容