Git使用基础与技巧

原创 2015年03月18日 09:04:07

创建版本库

$ 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 #上传所有标签

如何让派生的项目与上游代码库保持同步

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

复制版本库

如果你不想派生项目,而只是想复制一份相同的源代码,或者想从别的 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

如何应对 Git 操作时候的 HTTP 错误

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

上面2个错误有以下几个可能导致的:

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)

对该仓库没有访问权限。检查你是否对目标仓库有相应的读写权限。

输入了错误的用户名和密码。检查你是否使用了对该仓库有写权限的正确的账户名称和密码,检查是否对所有你名下的仓库均不能访问。

411 错误:

error: RPC failed; result=22, HTTP code = 411
fatal: The remote end hung up unexpectedly

这个错误是因为是由于上传的包过大 HTTP 的头出错导致的。

解决方法:

需要设置http.postBuffer,设置为50MB就可以了

git config http.postBuffer 524288000

Git 进阶:10大技巧让你迅速提升

最近我们推出了两个教程:熟悉Git的基本功能和让你在开发团队中熟练的使用Git . 我们所讨论的命令足够一个开发者在Git使用方面游刃有余。在这篇文章中,我们试图探索怎样有效的管理你的时间和充分的...
  • MLQ8087
  • MLQ8087
  • 2016年08月10日 17:51
  • 1707

一个三年Android开发的总结-常用的git技巧与误区

常用的git技巧前文《git的基础知识与协作开发》,对git的基本使用作了流水式的总结。在日常工作中最常用的也往往都是git checkout -b创建新分支,修改之后commit,再然后git pu...
  • w7849516230
  • w7849516230
  • 2016年03月27日 18:50
  • 2030

关于Intellij Idea中git的技巧

  • qq496013218
  • qq496013218
  • 2017年02月08日 14:41
  • 702

Ubuntu下git使用小技巧

来自一位同事的使用技巧。 ubuntu 下使用git进行版本控制,无论是提交代码还是管理代码,我们会建立许多的分支,在分支的切换过程中我们怎么知道自己当前在该仓的哪个分支上呢?git branch!这...
  • sssheiye
  • sssheiye
  • 2016年02月18日 10:31
  • 591

工作中使用git的实用技巧总结

工作中使用git的实用技巧总结 本文仅涉及工作中常用的比较实用的技巧和方法,并不会涉及大而全的. 所以关于如何安装git,或者git stash的用法请自行Google.创建一个新的本地git分支g...
  • hw1287789687
  • hw1287789687
  • 2016年07月15日 09:58
  • 1395

前端JavaScript面试技巧全套

第1章 课程简介 从几个常见面试开始,讨论针对一个题目的分析思路,总结题目对应的知识点。最后列出所有 JS 知识点的集合 —— JS 知识体系框架。 第2章 JS基础知识(上) 讲解 J...
  • zhangye19920611
  • zhangye19920611
  • 2017年12月09日 16:37
  • 216

Git基本操作--命令,真的只有最基本的操作

Git基本操作命令,暂时只有最基本的操作,摘自第一行代码! 安装   Ubuntu系统打开shell界面,输入:sudo apt-get install git-c...
  • lyankj
  • lyankj
  • 2016年10月26日 09:58
  • 900

【Git】远程仓库的使用

远程仓库远程仓库是指托管在互联网或其他网络中的你的项目的版本库你可以有好几个远程仓库,通常有些仓库对你只读,有些则可以读写。与他人协作涉及管理远程仓库以及根据需要推送或拉取数据管理远程仓库包括了解如何...
  • White_Idiot
  • White_Idiot
  • 2017年09月02日 19:17
  • 149

Git——git 使用技巧

今天在Server上建立一个git 库,把本地的code 上传到Server,再次clone下来时,发现少了些文件。原来git 工具不上上传一些二进制,pdf,.patch等一些文件。在上传时,git...
  • nxh_love
  • nxh_love
  • 2013年09月03日 16:48
  • 1443

IAR使用技巧总结

1 关于编译器 有时候
  • QAQWE
  • QAQWE
  • 2014年05月29日 15:35
  • 2167
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Git使用基础与技巧
举报原因:
原因补充:

(最多只允许输入30个字)