资料
首次创建
创建用户
git config --global user.name "Tony"
git config --global user.email "tony@gmail.com"
进入代码目录,创建代码仓库
git init
添加文件到仓库
git add AndroidManifest.xml
git add src
git add .
提交
git commit -m "First commit."
忽略文件或目录:
.gitignore
管理修改历史
版本号
在Git中,用HEAD
表示当前版本,也就是最新的提交3628164...882e1e0
(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^
,上上一个版本就是HEAD^^
,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100
。
HEAD相当于一个指针,指向当前的工作于哪个commit,在你跳转到某个commit后,HEAD就指向那个commit,所以速度跳转版本的速度非常快.
stage/unstaged
add之后进入stage,commit后进入branch.
查看历史提交信息
git log
git log --pretty=oneline --abbrev-commit
如果我们只想查看其中一条记录,可以在命令中指定该记录的 id,并加上-1 参数表示我们只想看到一行记录
git log 2e7c0547af28cc1e9f303a4a1126fddbb704281b -1
而如果想要查看这条提交记录具体修改了什么内容, 可以在命令中加入-p参数
git log 2e7c0547af28cc1e9f303a4a1126fddbb704281b -1 -p
查看状态
git status
查看本地文件修改了哪些地方。
git diff src/com/example/providertest/MainActivity.java
回退到某个版本
撤销未add过的文件的修改,就是丢弃所有的修改。
git checkout -- src/com/example/providertest/MainActivity.java
如果文件add过,先reset,再checkout:
git reset HEAD src/com/example/providertest/MainActivity.java
git checkout -- src/com/example/providertest/MainActivity.java
如果文件commit过,reset --hard
回退到上一个版本:
git log
git reset --hard 443ab205fac62b4316ca0f9188cd6b85fbc4a813 // 跳到某个版本
git reset --hard HEAD^ // 回到上个版本
前进到某个版本
git reflog // 查看命令历史,找到你要的commit id,然后用reset跳转.
git reset --hard xxxx // 跳到某个版本
git rm
远程协作
可以这样说,如果你是一个人在开发,那么使用版本控制工具就远远无法发挥出它真正强大的功能。
没错,所有版本控制工具最重要的一个特点就是可以使用它来进行团队合作开发。每个人的电脑上都会有一份代码,当团队的某个成员在自己的电脑上编写完成了某个功能后,就将代码提交到服务器,其他的成员只需要将服务器上的代码同步到本地,就能保证整个团队所有人的代码都相同的。这样的话,每个团队成员就可以各司其职,大家共同来完成一个较为庞大的项目。
git clone https://xxxxxxxxxxxxxxxx
git push origin master
git fetch origin master
git diff origin/master
git pull origin master(2in1)
git merge origin/master
托管到Git仓库 步骤
傻瓜式:
首先GitHub上新建repository
-
git clone到本地
target目录
git clone https://github.com/tony-green/coolweather.git
-
把本地项目的source code拷贝到本地
target目录
git add . git commit -m "First commit." git push origin master
推送本地git仓库到远程:
git remote add origin git@github.com:michaelliao/learngit.git
git push -u origin master
远程clone
git clone git@github.com:michaelliao/gitskills.git
多人协作
- 查看远程库信息,使用
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
; - 从远程抓取分支,使用
git pull
,如果有冲突,要先处理冲突。
Branch管理
查看有哪些branch:
git branch
git branch –a
创建新branch
git branch version1.0
切换新branch为工作branch
git checkout version1.0
创建并切换分支(2合1命令):
git checkout -b version1.0
merge来自new branch的修改:
git checkout master
git merge version1.0
删除new branch:
git branch -d version1.0
git branch -D version1.0 // 强制删除,丢弃修改
stash
stash的作用就是保存该branch的现场,该branch的工作目录用于他用:
git stash
用完后,需要回复现场,接着之前的工作:
git stash list // 查看
git stash apply // 恢复stash内容
git stash drop // 删除stash内容
git stash pop // (以上2合1的命令)
标签管理
tag就是一个让人容易记住的有意义的名字,它跟某个commit绑在一起。
创建标签:
git tag <name>
git tag v0.9 6224937 // 针对某个commit打标签
查看标签:
git tag
git show <tagname>
删除标签:
git tag -d v0.1
操作:
命令git push origin <tagname>可以推送一个本地标签;
命令git push origin --tags可以推送全部未推送过的本地标签;
命令git tag -d <tagname>可以删除一个本地标签;
命令git push origin :refs/tags/<tagname>可以删除一个远程标签。
配置git
$ git config --global color.ui true
$ 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站点(tbd)
搭建Git服务器非常简单,通常10分钟即可完成;
要方便管理公钥,用Gitosis;
要像SVN那样变态地控制权限,用Gitolite。
如何架设git服务器? gogsnun