在项目开发中使用Git版本控制工具以提高效率

安装Git(Linux CentOS平台)
 
源码方式安装
 
1.装依赖
 
$ yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel
 
2.下源码并编译安装
 
地址:http://git-scm.com/download
 
编译安装:
 
$ tar -zxf git-1.7.2.2.tar.gz
 $ cd git-1.7.2.2
 $ make
 $ sudo make  install
 


二进制包安装
 
$ yum install git-core

 

使用Git
 
#建立自己的工作目录
 sudo mkdir /var/www/site/mycitsm_zyz
 cd /var/www/site/mycitsm_zyz
 
#从代码仓库clone代码
 sudo Gitclone ssh://username@ip:port/path/to/example.git  /path/to/workdir
 
#克隆代码到自己的工作目录后先设置用信息以便于识别更新来源
 $ git config user.name "username"
$ git config user.email [email protected]
 

#忽略某些文件
 在工作目录下创建并编辑.gitignore文件,写入想忽略的内容
 样例:
 $ cat .gitignore
 *.pyc
 *.pyo
 test_*
 *.bak
 

 


之后便可以在自己的工作目录中编辑并提交代码。
 
一般工作流程
 #更新代码
 $vim /path/to/file
 
#查看文件状态
 $git status
 
#暂存更新
 $git add /path/to/file
 
#本地提交更新
 $git commit -m "说明信息"
 或通过
 $git commit -v 编写更详细的提交说明并将具体的更新内容记录在内。
 
#推送本地更新到远程仓库
 $git push origin master(origin为假定的远程仓库名,master是默认分支)
 
#从远程仓库拉取新内容
 $git pull origin
 
#获取帮助
 $git help
 

#新建分支
 $git branch branchname
 
#切换分支
 $git checkout branchname
 

#上述两步可合并为一步
 $git checkout -b branchname
 
#合并分支
 
先切回主分支$git checkout master
 再合并分支到主分支$git merge branchname
#查看分支
 $git branch
 
#仅查看未合并分支
 $git branch --no-merged
 
#仅查看已合并分支
 $git branch --merged
 
#删除分支(已合并)
 $git branch -d branchname
 
#删除分支(无论是否已合并)
 $git branch -D branchname
 

#查看未暂存文件的与修改前的差异
 
$git diff
 
#查看已暂存文件与上次提交时快照之间的差异
 $git diff --cached
 
#移除文件
 $git rm /path/to/file
 
#仅从跟踪清单删除不从工作目录删除
 $git rm --cached /path/to/file
 
#移动文件
 $ git mv file_from file_to
 
#查看提交历史
 $ git log
 
#修改最后一次提交
 $ git commit --amend
 
#取消已暂存文件
 $ git reset HEAD /path/to/file
 
#取消对文件对的修改
 $git checkout -- /path/to/file
 
#回退
 $git reset--mixed HEAD~N
 $git reset--soft HEAD~N
 $git reset--hard HEAD~N
 其中N表示最近的N次提交,这里也可以是某次提交后返回的版本唯一标识(可通过$git log获取到)
 --mixed保留改动,回退commit和index
 --soft保留改动,回退commit,不回退index
 --hard彻底回退到某个版本
 
#查看当前远程库
 $git remote -v
 
#从远程库拉取更新
 $git fetch origin

#合并拉取的更新的分支到本地分支
 $git merge origin/master
 
以上两步可合并为一步
 $git pull origin

GitLab 的详细介绍:请点这里
GitLab 的下载地址:请点这里

相关推荐