公司使用的是GitLab作为版本管理工具,因此必须学习git的使用.
下载安装git客户端工具
Linux自带git;Windows下需安装msysgit或tortoisegit,msysgit支持Git Bash模式和Git GUI模式,tortoisegit即是GUI客户端,建议优先使用命令行模式.
git for windows:http://msysgit.github.com/
tortoisegit :https://tortoisegit.org/
下载安装后,配置生成公钥,并登录GitLab远程库配置公钥免密码验证
$ssh-keygen -t rsa -C "xxx@xx.com"
==>Your identification has been saved in /c/Users/jpush.cn/.ssh/id_rsa.
Your public key has been saved in /c/Users/jpush.cn/.ssh/id_rsa.pub.
#如下命令可以校验公钥配置是否成功
ssh -T git@ssh-gitlab.jpushoa.com
#配置全局用户名邮箱地址
$git config --global user.name "user_name"
$git config --global user.email "xxx@xx.com"
#创建一个版本库
创建一个版本库非常简单,首先,选择一个合适的地方,创建一个空目录:
第二步,通过git init命令把这个目录变成Git可以管理的仓库
#把文件添加到仓库(暂存区)
$ git add readme.txt
#把文件提交到仓库:
$ git commit -m "wrote a readme file"
[master (root-commit) cb926e7] wrote a readme file
1 file changed, 2 insertions(+)
create mode 100644 readme.txt
#撤销修改
$git checkout -- file_name
撤销修改场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。
撤销修改场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了场景1,第二步按场景1操作。
撤销修改场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。
$ git reset --hard HEAD^
#git status命令可以让我们时刻掌握仓库当前的状态
#git diff命令可以查看修改
$git diff readme.txt
#git log命令可以查看最近到最远的提交日志
#本地库初始化($git init)之后要关联一个远程库
$git remote add origin git@server-name:path/repo-name.git
#如果直接clone下来的本地库,应该已经自动关联了
$git clone git@server-name:path/repo-name.git #示例1
$git clone git@github.com:michaelliao/gitskills.git #示例2
#Git鼓励大量使用分支:
查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
创建+切换分支:git checkout -b <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch -d <name>
用git log --graph命令可以看到分支合并图
#推送到远程分支
$git push origin local_branch:remote_branch
推送成功之后再gitlab上面提交MergeRequest,然后把MergeRequest连接发给铁柱请求合并
参考链接:
#廖雪峰Git教程
https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000
#Pro Git
https://git-scm.com/book/zh/v2