Git 常用命令速查表
创建版本库
-
$ git clone <url>
#克隆远程版本库 -
$ git init
#初始化本地版本库
修改和提交
-
$ git status
#查看状态 -
$ git diff
#查看变更内容 -
$ git add .
#跟踪所有改动过的文件 -
$ git add <file>
#跟踪指定的文件 -
$ git mv <old> <new>
#文件改名 -
$ git rm <file>
#删除文件 -
$ git rm --cached <file>
#停止跟踪文件但不删除 -
$ git commit -m “commit message”
#提交所有更新过的文件 -
$ git commit --amend
#修改最后一次提交
查看提交历史
$ git log
#查看提交历史$ git log -p <file>
#查看指定文件的提交历史$ git blame <file>
#以列表方式查看指定文件的提交历史
撤消
-
$ git reset --hard HEAD
#撤消工作目录中所有未提交文件的修改内容 -
$ git checkout HEAD <file>
#撤消指定的未提交文件的修改内容 -
$ git revert <commit>
#撤消指定的提交
分支与标签
-
$ git branch
#显示所有本地分支 -
$ git checkout <branch/tag>
#切换到指定分支或标签 -
$ git branch <new-branch>
#创建新分支 -
$ git branch -d <branch>
#删除本地分支 -
$ git tag
#列出所有本地标签 -
$ git tag <tagname>
#基于最新提交创建标签 -
$ git tag -d <tagname>
#删除标签
合并与衍合
-
$ git merge <branch>
#合并指定分支到当前分支 -
$ git rebase <branch>
#衍合指定分支到当前分支
远程操作
-
$ git remote -v
#查看远程版本库信息 -
$ git remote show <remote>
#查看指定远程版本库信息 -
$ git remote add <remote> <url>
#添加远程版本库 -
$ git fetch <remote>
#从远程库获取代码 -
$ git pull <remote> <branch>
#下载代码及快速合并 -
$ git push <remote> <branch>
#上传代码及快速合并 -
$ git push <remote> :<branch/tag-name>
#删除远程分支或标签 -
$ git push --tags
#上传所有标签
复制版本库
如果你不想派生项目,而只是想复制一份相同的源代码,或者想从别的 Git 托管服务那里复制一份源代码到 GitCafe 上的话,可以通过以下步骤来操作。
1). 从原地址克隆一份裸版本库,当然你也可以把托管于其它 git 服务器上的版本库克隆下来。
git clone --bare git://gitcafe.com/username/project.git
2). 然后到 GitCafe 服务器上创建一个新项目。
3). 以镜像推送的方式上传代码到 GitCafe 服务器上。
cd project.git
git push --mirror git@gitcafe.com/username/newproject.git
4). 删除本地代码
cd ..
rm -rf project.git
派生项目与上游代码库保持同步
1). 在 Fork 的代码库中添加上游代码库的 remote 源,(操作一次就可以,以后不必每次添加)
git remote add upstream git://gitcafe.com/username/upstream
# upstream 表示上游代码库名称
2). 本地修改和提交 (commit)
3). 在每次 Pull Request 前做如下操作,即可实现和上游版本库的同步。
git remote update upstream
git rebase upstream/master
# 如果不是 master 分支,请把 master 改为相应的分支名,
同时在 rebase 前用 git checkout 命令切换到相应的本地分支
4). Push 代码到 GitCafe
git push
参考:ProGit-分支的衍合
HTTP Errors
如果你在使用 HTTP 协议进行 Git 操作的时候出现错误提示:
-
401 错误:
$ git push origin master
error: RPC failed; result=22, HTTP code = 401
fatal: The remote end hung up unexpectedly
fatal: The remote end hung up unexpectedly
Everything up-to-date -
403 错误:
$ git push origin master
error: RPC failed; result=22, HTTP code = 401
fatal: The remote end hung up unexpectedly
fatal: The remote end hung up unexpectedly
Everything up-to-date
有以下几个可能性:
-
Git 版本过低。GitCafe 推荐使用的 Git 版本是 >= 1.7,请参考这里获取最新版本。
$ git --version
git version 1.8.2.1 -
远程仓库路径设置错误。注意,GitCafe 对于路径的识别是大小写敏感的。
查看已有的远程仓库:
$ git remote -v origin https://gitcafe.com/GitCafe/help.git (fetch) origin https://gitcafe.com/GitCafe/help.git (push)
设置新的远程仓库路径:
$ git remote set-url origin https://gitcafe.com/GitCafe/Help.git
查看新的远程仓库路径:
$ git remote -v origin https://gitcafe.com/GitCafe/Help.git (fetch) origin https://gitcafe.com/GitCafe/Help.git (push)
对该仓库没有访问权限。检查你是否对目标仓库有相应的读写权限。
输入了错误的用户名和密码。检查你是否使用了对该仓库有写权限的正确的账户名称和密码,检查是否对所有你名下的仓库均不能访问。
Git 相关问题
Git 介绍 (Git.md)
Git 常用命令速查表 (Git_Cheat_Sheet.md)
Git 常用命令速查表PDF版 (Git_Cheat_Sheet.pdf)
Git 常用命令速查表PNG版 (Git_Cheat_Sheet.png)
派生项目与上游代码库保持同步 (Sync_With_Upstream.md)
复制版本库 (Duplicating_Repo.md)
HTTP错误列表 (HTTP_Errors.md)
Git Community Book 中文版 (Git_Community_Book.pdf)
Pro Git 中文版 (Pro_Git.pdf)
来自GitCafe