安装git
sudo apt-get install git
git config命令的--global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址
git config --global user.name "Your name"
git config --global user.email "email@XX.com"
创建版本库repository
首先找一个地方,创建一个空目录,然后使用git init 命令
git init
将文件放到建好的仓库目录下使用如下命令
用add将文件添加到仓库
git add filename
用commit告诉git, 把文件提交到仓库
git commit -m "input something "
git commit命令执行成功后会告诉你,文件被改动的情况。commit可以一次提交很多文件
查看仓库历史
git status命令可以让我们时刻掌握仓库当前的状态
git status
git diff filename 可以查看该文件时如何被修改的
版本回退
用git log 命令查看历史记录
git reset --hard +版本号
其中**HEAD表示当前版本,HEAD^表示上一个版本,HEAD^^表示上上一个版本 也可写成HEAD~100上一百个版本。版本号不用全写,写前几位就行。git会自动帮你找到
用git reflog 可以查看你每一次的操作记录
撤销修改
使用
git checkout --xxx.txt
命令git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,这里有两种情况:
一种是readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;
一种是readme.txt已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
总之,就是让这个文件回到最近一次git commit或git add时的状态
使用git reset HEAD +filename可以把暂存区的修改撤销掉,重新放回工作区。git reset命令既可以回退版本,也可以把暂存区的修改撤销掉
删除文件
** 使用git rm filename**删除文件
若删错了,可用 git checkout -- filename进行恢复
查看、切换、创建和删除分支
git br -r # 查看远程分支
git br new_branch> # 创建新的分支
git br -v # 查看各个分支最后提交信息
git br --merged # 查看已经被合并到当前分支的分支
git br --no-merged # 查看尚未被合并到当前分支的分支
git co branch> # 切换到某个分支
git co -b new_branch> # 创建新的分支,并且切换过去
git co -b new_branch> branch> # 基于branch创建新的new_branch
git co $id # 把某次历史提交记录checkout出来,但无分支信息,切换到其他分支会自动删除
git co $id -b new_branch> # 把某次历史提交记录checkout出来,创建成一个分支
git br -d branch> # 删除某个分支
git br -D branch> # 强制删除某个分支 (未被合并的分支被删除的时候需要强制)
分支合并和rebase
git merge branch> # 将branch分支合并到当前分支
git merge origin/master --no-ff # 不要Fast-Foward合并,这样可以生成merge提交
git rebase master branch> # 将master rebase到branch,相当于:
git co branch> git rebase master git co master git merge branch>
Git暂存管理
git stash # 暂存
git stash list # 列所有stash
git stash apply # 恢复暂存的内容
git stash drop # 删除暂存区
远程仓库
创建SSH key
ssh-keygen -t rsa -C "email@xx.com"
如果一切顺利的话,可以在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人
登陆GitHub,打开“Account settings”,“SSH Keys”页面:
然后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容
将本地仓库推送到GitHub仓库
git remote add origin git@github.com:pastqing/wangdao.git
git push -u origin mastercd
由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令
此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改
从远程仓库克隆
git clone git@github.com:pastqing/wangdao.git
查看提交记录
git log
git log file> # 查看该文件每次提交记录
git log -p file> # 查看每次详细修改内容的diff
git log -p -2 # 查看最近两次详细修改内容的diff
git log --stat #查看提交统计信息