Git(二)指令

常用指令
  • git init:初始化一个仓库
  • git clone <url>: 克隆一个仓库
//会在当前目录下创建一个libgit2的目录,并在这个目录下初始化一个.git文件夹
//从远程仓库拉取下的所有数据都放入.git文件夹,然后从中读取最新版本的文件的拷贝
git clone https://github.com/libgit2/libgit2
  • git clone <url> <name>:在本地重新定义仓库的名称
 git clone https://github.com/libgit2/libgit2 mylibgit
  • git status: 查看你的文件状态
    image.png

    上图中可以看出readme 文件还未被git 跟踪,是Untracked 状态,提示使用git add readme 使其暂存(以后被commited)
git add README //暂存
git status
image.png

上图是已暂存的状态

  • git status -s / git status --short:状态简览


    image.png
 - ?? 未被跟踪的文件
 - M :已修改的文件
 - A : 已暂存的文件
 - AM: 已暂存但是又被修改的文件
  • git diff: 查看尚未暂存的文件更新了哪些部分,比较的是工作区和暂存区的差异,也就是修改后还未暂存的内容

  • git diff --staged/ git diff --cached:比较的是已暂存的和最后一次提交的差异,也就是已暂存的将要添加到下次提交里的内容
    例如:有一个third 文件,已经暂存的内容是:“第三个文件”,修改的内容是“第一次修改”,该文件的状态是 AM,就是已经暂存,但是又做了修改

    image.png

    git diff:说明工作区和暂存区的差别是 添加了"第一次修改"
    image.png

    git diff --staged/ git diff --cached:说明暂存区和上一次提交的差别是“第三个文件”
    image.png

  • git commit -a :跳过add 过程,自动把所有跟踪过的文件提交,未跟踪过的不行

    image.png

  • git rm:移除文件,必须从已跟踪过的文件清单中移除(就是被git 所知晓的文件)

    image.png

  • git rm --cached "文件名或者目录":删除git 仓库中的文件,但是保留工作区,意思是磁盘上保存,但是git 不跟踪,适用于没有来得及用gitignore 就提交的大量无用文件

git add 文件名 暂存
git commit -m '提交记录' 提交
git commit -am 暂存+提交
git branch 分支名创建分支
git checkout 分支名切换分支
git checkout -b 分支名:创建并切换分支
git merge 分支名 合并分支
git remote add origin 地址添加远程库地址
git push origin 分支推送到远程仓库
git fetch:从服务器抓取本地没有的数据,但是不会修改工作目录中的内容,它只会获取数据然后让你自己合并
git pull:拉取,并合并,修改工作目录内容

git 支持的协议

git 支持多种数据传输协议
https:// 协议,git://协议, ssh 协议 user@server:path/to/repo.git

提交历史查看
  • git log
  • git log -p / git log --patch:它会显示每次提交所引入的差异
  • git log -2/ 数字指定打印几条log
  • git log --stat :每次提交的简略统计信息
  • git log --pretty:个选项可以使用不同于默认格式的方式展示提交历史
  • git log --pretty=oneline:会将每个提交放在一行显示,在浏览大量的提交时非常有用
pretty 子项
//以下三行格式基本一致,详尽程度不一
git log --pretty=short
git log --pretty=full
git log --pretty=fuller
// git log --pretty=format:""
撤销操作
  • git commit --amend: 会提交暂存中的信息,如果上次提交之后没有做任何改动,那么会修改提交信息
远程仓库
  • git remote://查看远程仓库,一般是简写(默认origin)
  • git remote -v://会列出所有的远程仓库, 简写和地址
  • git remote add <shortname> <url>:shortname 就是远程仓库的简写,可以指定,之后可以使用简写代替远程仓库 例如拉取:git fetch <shortname>
  • git fetch <remote>:拉取远程仓库,remote 为远程的简写,默认origin
  • git push <remote> <branch>:推送到远程仓库
  • git push origin master:将master 分支推送到origin 服务器
  • git remote show <remote>:查看远程仓库
  • git remote rename:改写远程仓库的简写名称(例如 git remote rename pb pual)
  • git remote remove/git remote rm :移除远程仓库
  • git checkout -b <branch> <remote>/<branch>:创建一个本地分支branch 跟踪远程分支 <remote>/<branch>
  • git checkout --track origin/main(远程分支名):创建并检出一个本地分支 main,跟踪远程引用 origin/main(以上的快捷方式)
  • git push origin --delete <branch>删除远程分支
打标签

git 可以给仓库历史中的某一个提交打上标签,代表性的是人们用这个功能来标记发布节点

  • git tag :列出所有标签
  • git tag -l /git tag -list: 同上,可以省略
  • git tag -l "v1.8.5*" :列出1.8.5系列版本
    标签分为轻量标签附注标签轻量标签只是一个临时的信息,它只是某个特定提交的引用。附注标签是存储在git 数据库中的一个完整的对象
附注标签
  • git tag -a v1.4 -m "my version 1.4"
轻量标签
  • git tag -v1.4 -lw
补打标签

通过git log --pretty=oneline 查看所有的提交,在某一次提交补打标签 要找到对应的校验和,通过 git tag -a <校验和或者部分校验和> -m "内容"

image.png

共享标签

默认情况下,git push 并不会将标签传送到远程仓库上,创建完成后必须显示的推送标签

  • git push <remote> <tag>: git push origin v1.0 :推送一次标签
  • git push <remote> --tags: git push origin --tags:一次推送很多标签
删除标签
  • git tag -d <tagname>:git tag -d v1.0 删除本地1.0的标签
  • git tag -d <tagname> -lw :删除轻量标签
    上述操作并不会删除远程,需要
  • git push <remote>:refs/tags/<tagname>
    或者:
  • git push <remote> --delete <tagname>
检出标签,如果你需要进行更改,比如你要修复旧版本中的错误,那么通常需要创建一个新分支:
  • git checkout -b version2 v2.0.0 ://Switched to a new branch 'version2'
分支

git branch:查看分支
git branch -v:查看每一个分支的最后一次提交
git branch -vv:列出所有的本地分支,并且包含更多的信息(例如跟踪的远程分支)
git branch --merged:查看与当前分支合并过的分支
git branch --no-merged查看与当前分支未合并过的分支
git branch -d删除无用分支

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

推荐阅读更多精彩内容