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

[经验分享] "廖雪峰的Git教程"学习笔记

[复制链接]

尚未签到

发表于 2018-9-16 10:39:35 | 显示全部楼层 |阅读模式
  廖雪峰的《Git教程》

Git简介

Git的版本
  

git version  
which git
  

设置Git
  

git config --global user.name "MiracleWong"  
git config --global user.email "youremail@example.com"
  
git config --global color.ui auto
  

查看Git的设置
  

git config --global user.name  
git config --global user.email
  
git config --global color.ui
  

初始化仓库
  

cd project  
git init
  

  
git init project
  

查看文件状态
  

git status  

添加文件到版本库
  git add命令实际上就是把要提交的所有修改放到暂存区(Stage)
  

git add readme.txt  

提交到仓库
  git commit就可以一次性把暂存区的所有修改提交到分支
  

git commit -m "add readme.txt"  

时光穿梭机

查看日志——提交历史
  

git log  
git log --pretty=oneline
  
git log --pretty=oneline --abbrev-commit  显示前6位commit-id
  

  HEAD 表示当前版本,上个版本HEAD^,上上个版本HEAD^。

记录命令历史
  

git reflog  

回退到上一个版本
  

git reset --hard HEAD^  

查看工作区和版本库里面最新版本的区别
  

git diff HEAD -- readme.txt  

撤销暂存区的内容,重新放回工作区
  

git reset HEAD readme.txt  

丢弃工作区的修改
  

git checkout -- readme.txt  

删除文件
  

git rm file  
git commit -m "dekete file"
  

删错了文件,恢复
  git checkout其实是用版本库里的版本替换为工作区的版本
  

git checkout -- test.txt  

远程仓库

生成ssh key
  

ssh-keygen -t rsa -C "youremail@example.com"  

添加远程仓库
  

git remote add origin git@github.com:michaelliao/learngit.git  

本地内容推送到远程仓库
  

git push -u origin master 第一次推送master分支的所有内容  
git push
  
git push origin master
  

远程仓库克隆
  

git clone git@github.com:michaelliao/gitskills.git  

分支管理

创建分支
  

git branch   

创建+切换分支
  

git checkou -b dev  

列出所有分支
  

git branch  

切换分支
  

git checkout master  

合并某分支到当前分支
  

git merge dev  
git merge
  

删除分支
  

git branch -d   

分支合并
  --bo-ff强制禁用Fast-Forward模式,生成一个新的commit信息,从分支历史上可以看出分支信息
  

git merge --no-ff -m "merge with no-ff" dev  

分支策略
  master 分支应该是非常稳定的,仅用来发布新版本,平时不在上面干活。
  干活在dev分支上

stash功能,储存当前工作现场
  

git stash  

恢复现场,stash不删除(默认)
  

git stash apply stash@{0}  
git stash drop (删除储存的现场)
  

恢复现场,stash删除
  

git stash pop  

查看储存的现场
  

git stash list  

强行删除分支
  

git branch -D   

显示仓库信息
  

git remote -v  

推送分支
  

git push origin master  
git push origin dev
  

创建远程分支到本地
  

git checkout -b dev origin/dev  

建立本地分支和远程分支的关联
  

git branch --set-upstream dev origin/dev  

标签管理

创建标签
  

git tag v1.0  

查看所有标签
  

git tag  

补充tag
  

git tag v0.9 commit-id  

显示标签tag信息
  

git show   

创建带有说明的标签
  用-a指定标签名,-m指定说明文字:
  

git tag -a v0.1 -m "version 0.1>  

用PGP签名标签
  

git tag -s v0.2 -m "signed version 0.2>  

删除标签
  

git tag -d v0.1  

推送某个标签到远程
  

git push origin v1.0  

一次性推送全部尚未推送到远程的本地标签、
  

git push origin --tags  

删除一个远程标签
  

git push origin :refs/tags/v1.0  

Git服务
  The world’s leading software development platform · GitHub
  码云 Gitee — 开源中国基于 Git 和 SVN 的代码托管和协作开发平台
  Coding - 代码托管 项目管理 WebIDE 企业服务

自定义Git

Git显示颜色
  

git config --global color.ui true  
git config --global color.ui auto
  

忽略特殊文件


  • 忽略操作系统自动生成的文件,比如缩略图等;
  • 忽略编译生成的中间文件、可执行文件等,也就是如果一个文件是通过另一个文件自动生成的,那自动生成的文件就没必要放进版本库,比如Java编译产生的.class文件;
  • 忽略你自己的带有敏感信息的配置文件,比如存放口令的配置文件。
强制添加忽略文件
  

git add -f App.class  

gitignore命令检查
  

git check-ignore -v App.class  

设置别名
  

git config --global alias.st status  
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)%Creset' --abbrev-commit"
  

配置文件
  

[core]  repositoryformatversion = 0
  filemode = true
  bare = false
  logallrefupdates = true
  ignorecase = true
  precomposeunicode = true
  
[remote "origin"]
  url = git@github.com:michaelliao/learngit.git
  fetch = +refs/heads/*:refs/remotes/origin/*
  
[branch "master"]
  remote = origin
  merge = refs/heads/master
  

参考资料


  • Git官网
  • Git Pro 中文版



运维网声明 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-584446-1-1.html 上篇帖子: Eclipse 的Git Console插件 下篇帖子: spring cloud config git配置的坑
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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