综合 Git 知识总结

  1. 设置全局信息 git config --global
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
  • --global 参数代表机器上所有的 Git 仓库都使用这个配置
    会保存到
C:\Users\Classichu\.gitconfig

文件里

[user]
    name = louisgeek
    email = louisgeek@qq.com
[core]
    quotepath = false
[gui]
    encoding = utf-8
[i18n "commit"]
    encoding = utf-8
[i18n]
    logoutputencoding = utf-8
[http]
    postBuffer = 524288000

2.查看当前全局配置 git config

3.创建版本库 git init

Administrator@LouisGeek MINGW64 /d/LouisGit
$ mkdir hello_git  //创建目录文件

Administrator@LouisGeek MINGW64 /d/LouisGit
$ cd hello_git      //切换目录文件

Administrator@LouisGeek MINGW64 /d/LouisGit/hello_git
$ pwd
/d/LouisGit/hello_git  //查看目录路径

Administrator@LouisGeek MINGW64 /d/LouisGit/hello_git
$  git init   //初始化当前目录为版本库
Initialized empty Git repository in D:/LouisGit/hello_git/.git/

4.添加文件 git add

Administrator@LouisGeek MINGW64 /d/LouisGit/hello_git (master)
$ git add hello.txt   // git add . 添加所有文件

5.提交文件 git commit

$ git commit -m "add hello"
[master (root-commit) 36a3976] add hello
 1 file changed, 2 insertions(+)
 create mode 100644 hello.txt

6.查看状态 git status

Administrator@LouisGeek MINGW64 /d/LouisGit/hello_git (master)
$ 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:   hello.txt

no changes added to commit (use "git add" and/or "git commit -a")

7.查看不同 git diff

Administrator@LouisGeek MINGW64 /d/LouisGit/hello_git (master)
$ git diff

git diff HEAD -- hello.txt  //命令查看工作区和版本库最新版本区别

8.查看提交的日志记录 git log

Administrator@LouisGeek MINGW64 /d/LouisGit/hello_git (master)
$  git log
commit 36a397685948c3067a7c0131b188ae02968d1a91
Author: louisgeek <louisgeek@aliyun.com>
Date:   Fri Feb 10 23:33:11 2017 +0800

    add hello

简洁查看日志 git log --pretty=oneline

Administrator@LouisGeek MINGW64 /d/LouisGit/hello_git (master)
$  git log --pretty=oneline
36a397685948c3067a7c0131b188ae02968d1a91 add hello

9.回退到之前的版本 git reset

在 Git 中,用 HEAD 表示当前版本,也就是最新的提交,上一个版本就是HEAD,上上一个版本就是HEAD^,当然往上 100 个版本写 100 个^比较容易数不过来,所以写成 HEAD~100

$ git reset --hard HEAD^ //上一个版本

$ git reset --hard 3628164  //制定版本编号的那个版本

查看文件内容 cat

Administrator@LouisGeek MINGW64 /d/LouisGit/hello_git (master)
$  cat hello.txt
Git is a distributed version control system.
Git is free software.

10.记录你的每一次命令

$ git reflog

11.撤销修改

场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令

 git checkout --hello.txt

场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令

git reset HEAD hello.txt

就回到了场景 1,第二步按场景 1 操作。

场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考【回退到之前的版本】

12.删除文件 rm

rm hello.txt

13.关联远程库 git remote add

git remote add origin git@github.com:xxx/xxx.git

14.内容推送到远程 git push

git push -u origin master  //把分支 master 推送到远
//加上了-u参数,Git 不但会把本地的 master 分支内容推送的远程新的 master 分支,还会把本地的 master 分支和远程的 master 分支关联起来,在以后的推送或者拉取时就可以简化命令。

git push origin master //把本地master分支的最新修改推送

删除关联

git remote rm origin

15.克隆远程版本

git clone git@github.com:michaelliao/gitskills.git

16.创建分支 git checkout -b

git checkout -b dev
//-b参数表示创建并切换,相当于以下两条命令:
$ git branch dev
$ git checkout dev

17.查看分支信息 git branch

git branch

18.切换分支 git checkout

git checkout master

19.合并分支 git merge

git merge dev //把dev的分支内容合并到master上

//Fast-forward信息,Git 告诉我们,这次合并是“快进模式”,也就是直接把 master 指向 dev 的当前提交,所以合并速度非常快。


20.删除分支 git branch -d

git branch -d dev

21.查看分支图

git log --graph命令可以看到分支合并图

22.合并分支时,加上--no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而 fast forward 合并就看不出来曾经做过合并。

准备合并 dev 分支,请注意--no-ff参数,表示禁用 Fast forward

22.保存工作现场

git stash

23.查看保存的工作现场

git stash list

24.恢复工作现场

 git stash pop
 
 相当于下面两个命令
 用git stash apply恢复,但是恢复后,stash 内容并不删除,
 需要用git stash drop来删除
 
 可以多次 stash,恢复的时候,先用git stash list查看,然后恢复指定的 stash,用命令:
  git stash apply stash@{0}

25.强制删除分支

git branch -D feature-vulcan

26.查看远程库的信息

git remote

git remote -v  //显示更详细的信息

27.创建远程分支

创建远程 origin 的 dev 分支到本地,于是他用这个命令创建本地 dev 分支:

$ git checkout -b dev origin/dev

28.指定本地 dev 分支与远程 origin/dev 分支的链接,根据提示,设置 dev 和 origin/dev 的链接

$ git branch --set-upstream dev origin/dev

29.打标签

git tag <name> //就可以打一个新标签

$ git tag v0.9 6224937 //打标签到指定版本

git tag -a v0.1 -m "version 0.1 released" 3628164
// -a指定标签名,-m指定说明文字

30.查看标签

git tag

31.查看标签信息

git show v0.9

32.删除标签

git tag -d v0.1

33.远程标签

命令git push origin <tagname>可以推送本地标签;

命令git push origin --tags可以推送全部未推送过的本地标签;

命令git tag -d <tagname>可以删除本地标签;

命令git push origin :refs/tags/<tagname>可以删除远程标签

34.配置git

让 Git 显示颜色,会让命令输出看起来更醒目:

$ git config --global color.ui true

35.生成公钥

$ ssh-keygen -t rsa -C "louisgeek@qq.com" //创建ssh

36.对终端显示的配置,给文字添加颜色,更易于阅读

git config --global color.diff auto  
git config --global color.status auto  
git config --global color.branch auto

37.乱码设置(其他方案:http://www.cnblogs.com/wangkongming/p/3821305.html

$ git config --global core.quotepath false          # 显示 status 编码
$ git config --global gui.encoding utf-8            # 图形界面编码
$ git config --global i18n.commit.encoding utf-8    # 提交信息编码
$ git config --global i18n.logoutputencoding utf-8  # 输出 log 编码
$ export LESSCHARSET=utf-8  # 最后一条命令是因为 git log 默认使用 less 分页,所以需要 bash 对 less 命令进行 utf-8 编码

附常用命令

Git 全局设置:
git config --global user.name "louisgeek"
git config --global user.email "louisgeek@qq.com"


创建 git 仓库:
mkdir test
cd test
git init
touch README.md
git add README.md
git commit -m "first commit"
git remote add origin https://git.oschina.net/louisgeek/test.git
git push -u origin master


已有项目?
cd existing_git_repo
git remote add origin https://git.oschina.net/louisgeek/test.git
git push -u origin master

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

推荐阅读更多精彩内容

  • 1. 安装 Github 查看是否安装git: $ git config --global user.name "...
    Albert_Sun阅读 13,648评论 9 163
  • 一大早到二楼上厕所这里的厕所宽敞舒服可是,妈蛋,居然有人再听,咦,没人啊犹豫着,踹开门嘿,真没人哦,是邪风关上了门...
    lekli阅读 443评论 4 7
  • “青霞,你相信命吗?” “命里注定你要承受劫难吗?命里注定我们要相爱无法相守吗?” “这种命,我不信。” 青霞替紫...
    英雄念花迟美人念关雎阅读 211评论 0 1
  • 大一马上结束了 我有点后悔上大学 我觉得我在虚度光阴…… 因为我玩了半个月了! 因为考试的原因 我不得不停下我喜欢...
    语千阅读 313评论 0 1