Git -- 基础命令

初始化

git init   目录下会出现 .git 的目录,所有 Git 需要的数据和资源都存放在这个目录 中  


从现有仓库Clone

git clone [url]

git clone [url] name    clone 下来的项目目录更改为 name


查看文件仓库状态

git status


跟踪新文件(将已跟踪的文件加入暂存区)

git add [fileName]


忽略文件

cat .gitignore

#                 此为注释 – 将被 Git 忽略

*.a                 # 忽略所有 .a 结尾的文件

!lib.a             # 但 lib.a 除外

/TODO         # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO build/

build/          # 忽略 目录下的所有文件

doc/*.txt     # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

规则:

/      :表示目录

*      :表示通配多个字符

?      :表示通配单个字符

[]      :包含单个字符的匹配列表

!     :表示不忽略

#      :注释

/folder/                                :过滤整个文件夹

/folder/past.text                 :过滤具体某个文件

*.zip                                     :过滤所有zip文件

!aa.zip                                 :不过滤aa.zip文件

!/folder/need.text               :不过滤具体文件

备注:

    1、.gitignore 文件需要在第一次push之前上传,上传后增加则无效(已经管理了,增加 忽略规则也无效)

    2、git 对 .gitignore 文件是按 行从上到下匹配 (即若前面的范围大于后面的范围,则后面的不生效)

    3、.gitignore 文件只作用于 未被跟着的文件,即 添加后未 add 及 commit 过。若被跟踪过,则无效

    4、针对 .gitignore 不生效的办法:清除本地缓存(即改为未跟踪状态)

        git rm -r --cached .         //清理缓存

        git add .                            //重新 trace file 

        git commit -m 'update .gitignore'   //提交


查看修改内容

git diff             显示还没有暂存起来的改动,而不是这次工作和上次提交之间的差异

git diff --cached

git diff --staged


提交更新

git commit -m "xxx"

git commit -a -m "xxx"    会自动把所有已经跟踪过的文件暂 存起来一并提交


移除文件

git rm grit.gemspec

如果删除之前修改过并且已经放到暂存区域的话,则必须 要用强制删除选项 -f

git rm --cached readme.txt 仅是从跟踪清单中删除


移动文件

git mv file_from file_to      (同一目录下,即为改名操作)


查看提交历史

git log

选项 说明

-p 按补丁格式显示每个更新之间的差异。

--stat 显示每次更新的文件修改统计信息。

--shortstat 只显示 --stat 中最后的行数修改添加移除统计。

--name-only 仅在提交信息后显示已修改的文件清单。

--name-status 显示新增、修改、删除的文件清单。

--abbrev-commit 仅显示 SHA-1 的前几个字符,而非所有的 40 个字符。

--relative-date 使用较短的相对时间显示(比如,“2 weeks ago”)。

--graph 显示 ASCII 图形表示的分支合并历史。

--pretty 使用其他格式显示历史提交信息。可用的选项包括 oneline,short,full,fuller 和 format(后跟指定格式)。

按照时间作限制的选项,比如 --since 和 --until

git log --since=2.weeks

选项 说明

-(n) 仅显示最近的 n 条提交

--since, --after 仅显示指定时间之后的提交。

 --until, --before 仅显示指定时间之前的提交。

 --author 仅显示指定作者相关的提交。 

--committer 仅显示指定提交者相关的提交。


撤消操作

git commit --amend

git reset HEAD <file>        取消已经暂存的文件

git checkout -- benchmarks.rb    取消对文件的修改


远程仓库

git remote     查看当前配置有哪些远程仓库

git remote -v   显示对应的克隆地址

git remote add [shortname] [url]:    添加新的远程仓库

git fetch [remote-name]    从远程仓库抓取数据 

fetch 命令只是将远端的数据拉到本地仓库,并不自动合并到当前工作分支,只有当你确实准备好 了,才能手工合并

git pull    从原始克隆的远 端仓库中抓取数据后,合并到工作目录中当前分支

git push [remote-name] [branch-name]      推送数据到远程仓库   

git remote show [remote-name]      查看某个远程仓库的详细信息

git remote rename  name newName 重命名

git remote rm  移除 对应的远端仓库


标签     

git tag     列出现有标签    

git tag -l 'v1.4.2.*'    筛选

git tag -a v1.4 -m 'my version 1.4'          创建一个含附注类型的标签

git show    查看相应标签的版本信息

git tag -s v1.5 -m 'my signed 1.5 tag'       签署标签

git tag v1.4-lw    轻量级标签(保存着对应提交对象的校验和信息的文件)

git tag -v [tag-name]    验证已经签署的标签

git tag -a v1.2 9fceb02    后期加注标签

git push origin [tagName]        分享标签

git push origin --tags    一次推送所有(本地新增的)标签

git tag -d name 删除本地tag

git push origin :refs/tags/tagName  删除远程tag

git tag -l     查看本地tag

git show-ref --tag     查看远程tag

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

推荐阅读更多精彩内容

  • linux基础命令findfind / -name targetfilename 查找文件按时间查找也有参数 -a...
    AQ王浩阅读 1,469评论 0 5
  • Git 基础 基本原理 客户端并不是只提取最新版本的文件快照,而是把代码仓库完整的镜像下来。这样一来,任何一处协同...
    __silhouette阅读 15,853评论 5 147
  • Add & Commit git init 初始化一个 Git 仓库(repository),即把当前所在目录变成...
    冬絮阅读 4,774评论 0 8
  • git常用命令 GIT常用命令备忘:http://stormzhang.com/git/2014/01/27/gi...
    新篇章阅读 8,449评论 1 26
  • 9:20—16:00精准营销用户的跟进服务 16:00—18:00 10 11、12、13、14所有会员跟进服务
    秦淮首席书童阅读 110评论 0 0