目录
一:配置邮箱和姓名
二:生成SSH Key
三:git 工作区和状态
四:git log 常用法
五:git diff 常用法
六:git 分支操作
七:git 回溯分支
八:git rebase -i 压缩历史提交记录
九:推送到远程仓库
十:提交 Pull Request 流程
十一 接受 pull request
一:配置邮箱和姓名
$ git config --global user.name "Firstname Lastname"
$ git config --global user.email "your_email@example.com"
//让输出更具可读性
$ git config --global color.ui auto
二:生成SSH Key
ssh-keygen -t rsa -C "your_email@example.com"
//将生成的ssh-key配置到github上,然后测试
ssh -T git@github.com
三:git 工作区和状态
四:git log 常用法
//提交信息只显示一行
$ git log --pretty=short
//显示文件改动
$ git log -p
//过滤提交内容
$ git log --grep
//按作者过滤
$ git log --author
五:git diff 常用法
//显示工作区与暂存区的差异
$ git diff
//显示工作区与本地仓库的差异
git diff HEAD
六:git 分支操作
//新建分支
git checkout -b feature-A
//合并分支,将feature-A 分支合并到当前分支
git merge feature-A
//以图表形式查看分支
git log --graph
//以图形界面形式查看分支
gitk
七:git 回溯分支
//让仓库的 HEAD、暂存区、当前工作树回溯到指定状态
git rest --hard
//查看当前仓库执行过的操作的日志
git reflog
八:git rebase -i 压缩历史提交记录
git rebase -i
九:推送到远程仓库
//添加远程仓库
git remote add origin git@github.com:github-book/git-tutorial.git
//推送到远程分支,-u参数可以在推送的同时,将 origin 仓库的 master 分
支设置为本地仓库当前分支的 upstream(上游)
git push -u origin master
1 git push origin master:refs/heads/master
是将本地的master分支推送到远程主机origin上的对应master分支, origin 是远程主机名,
第一个master是本地分支名,
第二个master是远程分支名。
简写为: git push origin master
2 git push origin HEAD:refs/for/master
origin : 是远程的库的名字
HEAD: 是一个特别的指针,它是一个指向你正在工作的本地分支的指针,
可以把它当做本地分支的别名,git这样就可以知道你工作在哪个分支
refs/for :意义在于我们提交代码到服务器之后是需要经过 code review 之后才能进行merge的
refs/heads: 不需要
//我们试着将 feature-D 分支获取至本地仓库
git checkout -b feature-D origin/feature-D
//将本地的 feature-D 分支更新到最新状态(远程仓库的 feature-D)
git pull origin feature-D
十:提交 Pull Request 流程
1. 先fork仓库
2. 克隆仓库
git clone git@github.com:hirocastest/first-pr.git
3. 给原仓库设置 upstream 的名称,将其作为远程仓库
git remote add upstream git://github.com/octocat/Spoon-Knife.git
git fetch upstream
4. 查看分支
git branch -a
5. 创建分支
git checkout -b work gh-pages
6. 推送到远程分支
git push origin work
7. 提交pull request
十一 接受 pull request
1. 克隆仓库
git clone git@github.com:ituring/first-pr.git
2. 获取发送方远程仓库
git remote add PR发送者 git@github.com:PR发送者/first-pr.git
3. 新建分支
git checkout -b pr1
4. 合并分支
git merge PR发送者/work
5. 合并到主分支
git checkout gh-pages
git merge PR送信者/work