yum install gitgit
yum remove gitgithub
$ git config --global user.name "Your Name"网络
$ git config --global user.email email@example.comapp
首先,选择一个合适的地方,建立一个空目录:ssh
$ mkdir learngitfetch
$ cd learngitspa
$ pwd指针
/Users/michael/learngit日志
第二步,经过git init
命令把这个目录变成Git能够管理的仓库:code
$ git init
Initialized empty
Git repository
in /
Users/michael/learngit/.git/
编写一个readme.txt文件,内容以下:
Git is a version control system.
Git is free software.
第一步,用命令git add告诉Git,把文件添加到仓库:
$ git add readme.txt
第二步,用命令git commit告诉Git,把文件提交到仓库(-m后面输入的是本次提交的说明):
$ 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添加文件须要add,commit一共两步呢?由于commit能够一次提交不少文件,因此你能够屡次add不一样的文件,好比:
$ git add file1.txt
$ git add file2.txt file3.txt
$ git commit -m "add 3 files."
要随时掌握工做区的状态,使用git status命令。
若是git status告诉你有文件被修改过,用git diff能够查看修改内容
在Git中查看历史记录,显示从最近到最远的提交日志:
$ git log
$ git log --pretty=oneline
一大串相似3628164...882e1e0的是commit id(版本号)
$ git reset --hard HEAD^
用HEAD表示当前版本,上一个版本就是HEAD^,上上一个版本就是HEAD^^,固然往上100个版本写100个^比较容易数不过来,因此写成HEAD~100。
或:
$ git reset --hard 3628164(3628164指版本号)
版本号不必写全,前几位就能够了,Git会自动去找。固然也不能只写前一两位,由于Git可能会找到多个版本号,就没法肯定是哪个了。
Git提供了一个命令git reflog用来记录你的每一次命令:
工做区(Working Directory)
就是你在电脑里能看到的目录,好比个人learngit文件夹就是一个工做区
版本库(Repository)
工做区有一个隐藏目录.git,这个不算工做区,而是Git的版本库。
Git的版本库里存了不少东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为咱们自动建立的第一个分支master,以及指向master的一个指针叫HEAD。
git diff HEAD -- readme.txt命令能够查看工做区和版本库里面最新版本的区别:
丢弃工做区的修改:
$ git checkout -- readme.txt
把暂存区的修改撤销掉(unstage),从新放回工做区:
$ git reset HEAD readme.txt
$ git rm test.txt
rm 'test.txt'
$ git commit -m "remove test.txt"
[master d17efd8] remove test.txt
1 file changed, 1 deletion(-)
delete mode 100644 test.txt
$ ssh-keygen -t rsa -C youremail@example.com
打开“Account settings”,“SSH Keys”页面:
而后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容
登录GitHub,而后,在右上角找到“Create a new repo”按钮,建立一个新的仓库:
在本地的learngit仓库下运行命令:
$ git remote add origin git@github.com:JaceyKan/LearnPython.git
远程库的名字就是origin,这是Git默认的叫法,也能够改为别的,可是origin这个名字一看就知道是远程库
下一步,就能够
$ git push -u origin master
因为远程库是空的,咱们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在之后的推送或者拉取时就能够简化命令。
从如今起,只要本地做了提交,就能够经过命令:
$ git push origin master
用命令git clone克隆一个本地库:
$ git clone git@github.com:JaceyKan/gitskills.git
ssh: Could not resolve hostname github.com: Name or service not known
fatal: The remote end hung up unexpectedly
缘由:网络不通,没法ping通github
设置好网络就能够了
首先,咱们建立dev分支,而后切换到dev分支:
$ git checkout -b dev
Switched to a new branch 'dev'
git checkout命令加上-b参数表示建立并切换,至关于如下两条命令:
$ git branch dev
$ git checkout dev
Switched to branch 'dev'
而后,用git branch命令查看当前分支:
$ git branch
* dev
master
切换回master分支:
$ git checkout master
Switched to branch 'master'
合并指定分支到当前分支,把dev分支的工做成果合并到master分支上:
$ git merge dev
Updating d17efd8..fec145a
Fast-forward
readme.txt | 1 +
1 file changed, 1 insertion(+)
删除dev分支:
$ git branch -d dev
Deleted branch dev (was fec145a).
查看分支:git branch
建立分支:git branch <name>
切换分支:git checkout <name>
建立+切换分支:git checkout -b <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch -d <name>
用带参数的git log也能够看到分支的合并状况:
$ git log --graph --pretty=oneline --abbrev-commit
* 59bc1cb conflict fixed
|\
| * 75a857c AND simple
* | 400b400 & simple
|/
* fec145a branch test
...
准备合并dev分支,请注意--no-ff参数,表示禁用Fast forward:
$ git merge --no-ff -m "merge with no-ff" dev
Merge made by the 'recursive' strategy.
readme.txt | 1 +
1 file changed, 1 insertion(+)
由于本次合并要建立一个新的commit,因此加上-m参数,把commit描述写进去。
把当前工做现场“储藏”起来,等之后恢复现场后继续工做:
$ git stash
Saved working directory and index state WIP on dev: 6224937 add merge
HEAD is now at 6224937 add merge
查看被储藏起来的工做现场:
$ git stash list
stash@{0}: WIP on dev: 6224937 add merge
工做现场还在,Git把stash内容存在某个地方了,可是须要恢复一下,有两个办法:
一是用git stash apply恢复,可是恢复后,stash内容并不删除,你须要用git stash drop来删除;
另外一种方式是用git stash pop,恢复的同时把stash内容也删了:
能够屡次stash,恢复的时候,先用git stash list查看,而后恢复指定的stash,用命令:
$ git stash apply stash@{0}
强行删除分支:
$ git branch -D feature-vulcan
查看远程库的信息:
$ git remote
origin
或者显示更详细的信息:
$ git remote -v
origin git@github.com:michaelliao/learngit.git (fetch)
origin git@github.com:michaelliao/learngit.git (push)
上面显示了能够抓取和推送的origin的地址。若是没有推送权限,就看不到push的地址。
推送分支,就是把该分支上的全部本地提交推送到远程库。
推送时,要指定本地分支:
$ git push origin master
多人协做的工做模式
1.首先,能够试图用git push origin branch-name推送本身的修改;
2.若是推送失败,则由于远程分支比你的本地更新,须要先用git pull试图合并;
3.若是合并有冲突,则解决冲突,并在本地提交;
4.没有冲突或者解决掉冲突后,再用git push origin branch-name推送就能成功!
5.若是git pull提示“no tracking information”,则说明本地分支和远程分支的连接关系没有建立,用命令
git branch --set-upstream branch-name origin/branch-name