设为首页 收藏本站
查看: 1192|回复: 0

[经验分享] 《Git教程

[复制链接]

尚未签到

发表于 2018-1-15 20:05:48 | 显示全部楼层 |阅读模式
一.创建版本库
  ①初始化一个Git仓库:git init
  ②添加文件到Git仓库:1.git add<file> ;  2.git commit

二.时光机穿梭
  ①查看工作区状态,文件是否被修改过:git status
  ②查看修改的内容:git diff

1.版本回退
  ①HEAD:当前版本
  ②HEAD^:上个版本
  ③定位版本:git reset --hard commit_id
  ④git log:穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本
  ⑤git reflog:要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。

2.工作区和暂存区
  ①工作区:就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区
  ②版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
  ③暂存区:Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区。
  第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;
  第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。

3.管理修改
  ①每次修改,如果不add到暂存区,就不会加入到commit中

4.撤销修改
  ①git checkout -- file:丢弃工作区的修改
  ②git reset HEAD file:把暂存区的修改撤销掉,重新放回工作区

5.删除文件
  ①git rm:从版本库中删除文件

三.远程仓库

1.添加远程库
  ①关联一个远程库:git remote add origin git@server-name:path/repo-name.git
  ②关联后第一次推送master分支的所有内容:git push -u origin master
  ③此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改
  ps:由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。

2.从远程库克隆
  ①要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆
  ②Git支持多种协议,包括https,但通过ssh支持的原生git协议速度最快

四.分支管理

1.创建与合并分支
  ①查看分支:git branch
  ②创建分支:git branch<name>
  ③切换分支:git cheakout<name>
  ④创建+切换分支:git cheakout -b <name>
  ⑤合并某分支到当前分支:git merge<name>
  ⑥删除分支:git branch - d <name>

2.解决冲突
  ①查看分支合并图:git log -- graph
  eg:git log --graph --pretty =oneline --abbrev -commit

3.分支管理策略
  ①合并分支时加--no-ff参数:普通模式合并,合并后的历史有分支,禁用fast forward
  eg:git log --no-ff-m"merge with no--ff"dev

4.Bug分支
  ①git stash:把当前工作现场隐藏起来,去修复bug
  ②git stash pop:恢复工作现场同时删除stash内容

5.Feature分支
  ①开发一个新feature,最好新建一个分支;
  ②如果要丢弃一个没有被合并过的分支,可以通过git branch -D <name>强行删除

6.多人协作
  ①git remote -v:查看远程库信息
  ②git push origin branch-name:从本地推送分支
  ③git pull:推送失败时,抓取远程的新提交
  ④git checkout -b branch-name origin/branch-name:在本地创建和远程分支对应的分支(本地和远程分支的名称最好一致)
  ⑤git branch --set-upstream branch-name origin/branch-name:建立本地分支和远程分支的关联

五.标签管理

1.创建标签

  ①git tag <name>:新建一个标签(默认为HEAD,也可以指定commit>  ②git tag -a <tagname> -m "blablabla...":可以指定标签信息
  ③git tag -s <tagname> -m "blablabla...":可以用PGP签名信息
  ④git tag:查看所有标签

2.操作标签
  ①git push origin <tagname>:推送一个本地标签
  ②git push origin --tags:推送全部未推送过的本地标签
  ③git tag -d <tagname>:删除一个本地标签
  ④git push origin :refs/tags/<tagname>:删除一个远程标签

六.使用GitHub
  ①在GitHub上,可以任意Fork开源仓库;
  ②自己拥有Fork后的仓库的读写权限;
  ③可以推送pull request给官方仓库来贡献代码。

七.自定义Git

1.忽略特殊文件
  ①忽略某些文件时,需要编写.gitignore;

2.配置别名
  ①我们只需要敲一行命令,告诉Git,以后st就表示status:git config --global alias.st status
  eg:
  

$ git config --global alias.co checkout  
$ git config --global alias.ci commit
  
$ git config --global alias.br branch
$ git config --global alias.unstage 'reset HEAD'  

$ git config --global alias.last 'log -1'  

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"  

3.搭建Git服务器
  GitHub就是一个免费托管开源代码的远程仓库。但是对于某些视源代码如生命的商业公司来说,既不想公开源代码,又舍不得给GitHub交保护费,那就只能自己搭建一台Git服务器作为私有仓库使用。
  例如大众点评code.dianpingoa.com

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-435458-1-1.html 上篇帖子: Git本地仓库(Repository)详解 下篇帖子: Owen Chen - 热爱互联网,热爱前端开发JAVASCRIPT , ANGULAR.JS , DOJO , NODE.JS欢迎访问个人博客:owenche
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表