git常用命令

git

标签(空格分隔): IDE


1.git概念

1.1 两种版本管理方式:

a.集中式:需联网,需要中央节点,代表是svn,
b.分布式:不需要联网,

git是一个版本库管理工具,这个版本库中文件的修改,删除都可以被gt工具管理起来。

1.2 git help

please tell me who you are
     git config --global user.email "you@example.com"
     git config --global user.name "Your Name"
start a working area (see also: git help tutorial)
   clone      Clone a repository into a new directory
   init       Create an empty Git repository or reinitialize an existing one

work on the current change (see also: git help everyday)
   add        Add file contents to the index   
              # git add readme.txt  向仓库中添加文件
   mv         Move or rename a file, a directory, or a symlink
   reset      Reset current HEAD to the specified state  (//原理:git在master分支上维护着head指针)
              # git log 版本日志  
              # git reset --hard  HEAD^  返回上一个版本或者 HEAD~100
              # git reflog 查看命令日志,到达未来某个版本
   rm         Remove files from the working tree and from the index

examine the history and state (see also: git help revisions)
   bisect     Use binary search to find the commit that introduced a bug
   grep       Print lines matching a pattern
   log        Show commit logs
   show       Show various types of objects
   status     Show the working tree status

grow, mark and tweak your common history
   branch     List, create, or delete branches
   checkout   Switch branches or restore working tree files
   commit     Record changes to the repository  #多条add后,commit提交
   diff       Show changes between commits, commit and working tree, etc
   merge      Join two or more development histories together
   rebase     Forward-port local commits to the updated upstream head
   tag        Create, list, delete or verify a tag object signed with GPG

collaborate (see also: git help workflows)
   fetch      Download objects and refs from another repository
   pull       Fetch from and integrate with another repository or a local branch
   push       Update remote refs along with associated objects

'git help -a' and 'git help -g' list available subcommands and some
concept guides. See 'git help <command>' or 'git help <concept>'
to read about a specific subcommand or concept.

2.创建版本库

git init DirectionName #将一个文件初始化为git仓库
git add  filename
git commit -m " "
/ 版本回退/
git log  #查看commit日志
git reset --hard  HEAD^/HEAD~100/commit_id  #回到以前版本
git reflog #查看以前的命令,可以回到未来版本


2.git原理

3.修改

git  checkout -- filename  //将工作区文件恢复到版本库
git reset HEAD filename //清除暂存区

4.git push 提交代码

1.要关联一个远程库: git remote add origin git@github.com:braveliberty/gites6.git
2.
1)生成ssh秘钥:ssh-keygen -t rsa -C "braveliberty@163.com"
2)交给ssh-agent保管:ssh-add ~/.ssh/id_rsa
3)找到.ssh文件下公钥.pub文件,复制到github秘钥中

2.关联后,使用命令:git push -u origin master第一次推送master分支的所有内容;
需要详细指定分支时:git push origin master:shiyi-dev
推送到shiyi-dev分支:git push origin shiyi-dev

3.此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;
常用命令:
git remote rm origin //删除远程库
git remote -v //查看远程库

5.git clone

#多人合作时,会先创建远程库
git clone git@github.com:michaelliao/gitskills.git  //git协议
git clone https://github.com/michaelliao/gitskills.git  //http协议

6.分支

1. 创建和删除分支
查看分支:git branch
创建分支:git branch <name>  
删除分支:git branch -d <name>
切换分支:gti checkout <name>
创建+切换分支:git checkout -b <name>
合并一个分支到当前分支:gti merge <name>    

2.冲突:当两个分支在主分支上处于同样的位置序列时,合并时会出现冲突,解决冲突的办法就是查看文件,再提交一次就可以了。

3.分支管理策略
开发时,master只用来发布版本,dev是所有开发人员提交合并分支,在dev分支上,每个小伙伴都可以开辟自己的分支,最后都合并到dev上。
在合并时,禁止采用fast-forward模式,这种方式会将分支记录删掉。
建议使用:git merge --no-ff -m "merge with no-ff" dev  这种方式相当于多commit一次,所以必须有-m参数

4.bug分支 简单来说:git stash 保存,git stash pop恢复现场
出现master bug需要修复时,先保存分支现场:git stash;
在master主干上新建bug修复分支,修复完成后合并;
回到自己分支,恢复现场:git stash list ;git stash pop ;git apply stash@{wid};

5.强制删除分支:git branch -D feature-vulcan

6.多人合作过程:
    远程信息:git remote -v
    本地与远程建立相同分支:git checkout -b branch-name origin/branch-name
    a.向origin推送自己分支 git push origin <branch-name>
    b.出现冲突,用 git pull 解决冲突,pull 本质是fetch与merge两个过程的合并
    c.分支没有建立连接,用git branch --set-upstream-to=origin/<branch> dev建立连接
    d.再次git push到远程分支
7.git rebase 合并分支线
    git log --graph --pretty=oneline --abbrev-commit  查看分支线
    git rebase //重新构建base tree


分支图,需要注意的是 <strong>head指向的是当前分支master或dev,master或dev真正指向文件。</strong>


【团队开发分支线路】


7.标签

8.给commit打标签
    git tag -a v0.1 -m "version 0.1 released" [1094adb] //没有则默认当前head  
    git tag //show all tags
    git show <tag> //show info about specified tag
9.操作标签
    git -d <tag-name>
    git push origin tagname //推送到origin
    git push origin --tags  //推送所有标签到origin
    删除远程标签两步骤:a.先删除本地tag   b.git push origin :refs/tags/v0.9

8. 编写.gitignore文件

1).将要忽略的文件名添加到.ignore文件中
2).发生冲突:git check-ignore

9.配置alias

两种方式:1.修改config文件
2.命令直接修改

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

推荐阅读更多精彩内容