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

[经验分享] git学习总结(二)本地git仓库的相关操作

[复制链接]

尚未签到

发表于 2018-1-16 09:17:28 | 显示全部楼层 |阅读模式
  想要进行git的相关操作,首先要建立一个git仓库,有两种方式可以建立git仓库,一个是新建,一个是克隆现有的git仓库:
  新建一个git仓库:  git init
  克隆现有的git仓库:  git clone [url] [目录名(如果木有,则建立一个和原仓库同名的目录)]
  建立起来的git仓库都是在目录下多了一个.git目录,不同点是init的里边啥也木有,clone的是把目标git仓库复制过来了。
  以下就开始git的相关操作了:
  git status            查看文件的状态,是否暂存;
  git add <file name>        将未暂存文件暂存;
  git rm <file name>        删除文件;
  git rm --cache <file name>    在git仓库中删除此文件的跟踪,但是不删除文件;
  git reset HEAD <file name>    将暂存的文件拉回未暂存状态;
  git checkout <file name>    取消未暂存状态的文件的修改,返回到暂存或者已经提交的状态;
  git diff [<filename>]         查看未暂存文件的修改;
  git diff --cache        查看已暂存状态的文件的修改;
  git diff --staged        效果同上,在git1.6.1以上版本可用。
  忽略某些文件
  我们总会有些文件不需要跟踪,比如使用eclipce开发android的时候的bin/,这些就需要我们忽略掉,方法如下:
  1.在./.git/info/exclude文件中添加需要忽略的名字;
  2.在.下新建一个名字为.gitignore的文件,把需要忽略的名字添加进去。
  提交更新
  提交更新的命令是 git commit ,后边有些选项可以选择来节省某些步骤:
  -a             可以省略add 步骤;
  -m "commit message"     是添加提交的内容概述,可以省略直接使用git commit后打开文本编辑器来输入内容概述。
  移动文件
  移动文件的命令是 git mv file_from file_to,该命令相当于 mv fill_from fill_to    git rm file_from   git add file_to
  撤销操作
  修改最后一次的提交,可以覆盖最后一次commit的内容,用于补充忘记提交的内容或者改动提交内容的概述,命令为 git commit --amend
  取消已经暂存的文件,将状态从已暂存拉回未暂存,git reset HEAD <file name>
  取消对文件的修改,只有未暂存状态才可以使用,git checkout <file name>
  查看提交历史
  一个是用图形工具来查看:gitk ;另外就是代码查看:git log  ,会按照时间顺序列出所有的提交,有很多选项可以选择:
  -p        显示出所有的具体改动
  -n        显示最近的n条数据
  --stat        显示每次更新的增删改的具体数据
  等等,很多很多,不过感觉没啥用,就不一一写了,从来没用过,gitk用的最多,而且看起来清楚
  远程仓库的相关使用
  查看远程仓库:git remote   ,另外,添加-v选项(verbose),可以显示对应的克隆地址;
  查看某个远程仓库的详细信息:git remote show [remote-name]
  添加远程仓库:git remote add [remote-name] [url]
  远程仓库的改名:git remote rename [old-name] [new-name]
  远程仓库的删除:git remote rm [remote-name]
  从远程仓库抓取数据:git fetch [remote-name]
  推送数据到远程仓库:git push [remote-name] [branch-name] 这里需要注意的是,如果只写了本地branch的名字,他会将本地的branch推送上去,如果remote上木有该branch,将会新建一个,如果想推送的remote的某个branch里边,需要写成 git push [remote-name] [local-branch-name]:[remote-branch-name]  这样就可以了,之前没理解清楚的时候没写远程仓库的branch名字,费了好多时间才弄明白,血的教训阿
  标签
  查看现有的标签:git tag,按照字母顺序排列
  查看某些特定的标签:git tag -l '搜索条件'
  新建标签:git tag -a [tag-name]   ,可以添加-m选项来添加标签的附注,省略打开文本编辑器来写的步骤了;
  补充添加标签;有时忘记在每次commit后建立标签,只需要在新建标签中添加对应的commit的ssh-1码的前几位就可以了 git tag -a [tag-name] [ssh-1]
  新建轻量级标签: git tag [tag-name]
  查看标签对应的内容:git show [tag-name]
  分享标签:git push [remote-name] [tag-name]
  推送所有的标签:git push [remote-name] --tags

运维网声明 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-435588-1-1.html 上篇帖子: 《Pro Git》笔记 下篇帖子: git(创建,提交,回退)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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