git实用命令

由于不支持[TOC]只能手动目录了இ௰இ
我的博客:PowerScript

初学者推荐看廖雪峰的git教程
本篇文章就是对其教程上的内容进行整理

主要操作

  • 创建版本库
git init
  • 添加到暂存区
# 可在提交到版本库前多次使用
git add <file>
  • 查看状态
git status
  • 比较文件
git diff <file> #比较工作区和暂存库的文件
git diff HEAD --<file> #比较工作区和版本库的文件
  • 将暂存区文件提交到版本库
# 一次性提交所有暂存区文件
git commit -m "your commentary"
  • 查看日志

优化配置在“其它”的“别名”里<a href="#alias">点这</a>

git log #输出从最近到最远的提交日志,版本变化时也会变化
git log -1 #最近一次
git log --pretty=oneline #更加简洁地输出
git reflog #查看命令历史,可以用来回到未来的版本
  • 切换版本
git reset --hard <cmmit id>
#除了commit id,HEAD也可用,HEAD指向当前版本,HEAD^指向前一个版本
#同理HEAD^^指向上上个版本
#HEAD~100指向往上的第100个版本
  • 撤销修改
# 如果暂存区有内容就回到暂存区,否则回到版本库
# 文件删除了也可以用这条命令从版本库里恢复
git checkout -- <file>
# 将暂存区中的内容删除
git reset HEAD <file>
  • 删除文件
git rm <file>
git commit -m "text"
  • 标签
git tag <name> # 创见一个标签
git tag #查看所有标签
git tag <name> <commit_id> # 可给以前的id打标签
git show <name> # 查看标签信息
git tag -a <name> -m "text" <commit_id> # 创建有说明文字的标签
git tag -d <name> # 删除标签
# 远程操作相关(下面)
git push origin <name> # 推送某个标签到远程
git push origin --tags #一次性推送所有尚未推送到远程的本地标签
# 若要删除远程的标签
git tag -d <name> # 先删除本地标签
git push origin :refs/tags/<name> #再用该命令

远程仓库

提交

注意用tag提交在上面几行("标签"中)

  • 连接仓库并上传文件
# 生成密匙对
ssh--keygen -t rsa -C "youremail@example.com"
# 查看公匙
cat ~/.ssh/id_rsa.pub
# 仓库放了公匙后添加到远程仓库
git remote add origin git@github.com:xxx/xxxx.git
# 第一次上传文件(其实-u起到了关联分支的作用)
git remote # 查看链接的远程仓库
git remote -v # 也可以查看
git push -u origin master
# 之后上传文件
git push origin master
  • 推送到不同的仓库(如github和gitee上的)
# 此时就不能按原来那样命名origin了,要命不同的名字
git remote add github git@github.com:xxx/xxxx.git
git remote add gitee git@gitee.com:xxx/xxxx.git
  • 删除远程仓库
git remote rm origin # 如删除原有的github仓库
  • 下载仓库
git clone git@github.com:xxx/xxxx.git
# 创建远程仓库的dev到本地(原因是上面的命令默认拉去master分支)
git checkout -b dev origin/dev
  • 若合作时远程仓库的提交有冲突
# 拉去dev分支
git pull
# 若出现错误提示(no tracking information),把提示命令复制下来,如下
# 指定两branch的链接(一次就行)
git branch --set-upstream-to=origin/<branch name> <branch name>
# 再pull
# 之后再手动解决冲突
#再提交
git commit -m "text"
git push origin dev

分支相关

git branch # 查看分支
git branch <branch name> # 创建分支
#切换分支
git checkout <name>
git switch <name> # 同样可以
# ------
# 创建+切换分支
git checkout -b <name>
git switch -c <name> # 同样可以
# ------
# 合并某分支到当前分支,启用[Fast forward](即完成后删除那个分支)
git merge <naem> 
# ------
git branch -d <name> # 删除分支(已合并)
git branch -D <naem> # 强行丢弃一个没被合并的分支
git log --graph # 查看分支合并图
git log --graph --pretty=oneline --abbrev-commit # 简洁一点
# 合并某分支到当前分支,不启用[Fast forward](即不删除那个分支,利于团队合作)
# --no-ff表示 不删除
# -m 即要新建一个commit
git merge --no-ff -m "text" <branch name>

一般管理图

======master====>
    ^          ^
====|=dev======|========>
      ^              ^
======|==Mike===>    |
=================Bob=|==>

Bug分支

# 假设现在为dev分支,要到master分支上修bug
git stash # 把当前工作现场暂时储存起来
# 现在用'git switch'可以看到工作区是干净的
git checkout master
git checkout -b issue-101 #如果已有,则不用'-b'
# 然后修复文档,如index.php
git add index.php
git commit -m "fix bug 101"

git switch master
git merge --no-ff -m "merged bug fix 101"

git switch dev
git stash list #列出储存的工作现场
git stash pop #恢复并删除stash
# 刚才的命令等价于'git stash apply'加上'git stash drop'
# 'git stash pop stash@{0}'等可以指定,apply、drop也可以这样。
# 若dev分支也有master上的bug
git cherry-pick <commit_id> # 把刚才在master上的特定提交复制到dev上

其他

  • 命令
git rebase # 作用是把提交历史变成一条直线
# 可以用git log --graph --pretty=oneline --abbrev-commit 查看提交历史
#不建议随便用,因为别人开发也会受到影响
  • 忽略特殊文件

只需要在工作区下添加".gitignore"文件即可
有现成的配置文件

  • 配置别名

<span id="alias">

git config --global alias.st status # st就表示status了, git st
# 使git log更加好用 git lg
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
# 由于我的yellow显示为white,就改了一下:
git config --global alias.lg "log --color --graph --pretty=format:'%C(bold red)%h%Creset -%C(bold cyan)%d%Creset %s %Cgreen(%cr) %Cred<%an>%Creset' --abbrev-commit"
# 其它如git reset HEAD file 改为 git unstage 
git config --global alias.unstage 'reset HEAD'

至于GUI版git自建git服务器不在本文范围内

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