Git笔记

资料

首次创建

创建用户

git config --global user.name "Tony"
git config --global user.email "tony@gmail.com"

进入代码目录,创建代码仓库

git init

添加文件到仓库

git add AndroidManifest.xml
git add src
git add .

提交

git commit -m "First commit."

忽略文件或目录:

.gitignore

管理修改历史

版本号

在Git中,用HEAD表示当前版本,也就是最新的提交3628164...882e1e0(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100

HEAD相当于一个指针,指向当前的工作于哪个commit,在你跳转到某个commit后,HEAD就指向那个commit,所以速度跳转版本的速度非常快.

stage/unstaged

add之后进入stage,commit后进入branch.

查看历史提交信息

git log
git log --pretty=oneline --abbrev-commit

如果我们只想查看其中一条记录,可以在命令中指定该记录的 id,并加上-1 参数表示我们只想看到一行记录

git log 2e7c0547af28cc1e9f303a4a1126fddbb704281b -1

而如果想要查看这条提交记录具体修改了什么内容, 可以在命令中加入-p参数

git log 2e7c0547af28cc1e9f303a4a1126fddbb704281b -1 -p

查看状态

git status

查看本地文件修改了哪些地方。

git diff src/com/example/providertest/MainActivity.java

回退到某个版本

撤销未add过的文件的修改,就是丢弃所有的修改。

git checkout -- src/com/example/providertest/MainActivity.java

如果文件add过,先reset,再checkout:

git reset HEAD src/com/example/providertest/MainActivity.java
git checkout -- src/com/example/providertest/MainActivity.java

如果文件commit过,reset --hard回退到上一个版本:

git log
git reset --hard 443ab205fac62b4316ca0f9188cd6b85fbc4a813 // 跳到某个版本
git reset --hard HEAD^ // 回到上个版本

前进到某个版本

git reflog // 查看命令历史,找到你要的commit id,然后用reset跳转.
git reset --hard xxxx // 跳到某个版本

git rm

远程协作

可以这样说,如果你是一个人在开发,那么使用版本控制工具就远远无法发挥出它真正强大的功能。

没错,所有版本控制工具最重要的一个特点就是可以使用它来进行团队合作开发。每个人的电脑上都会有一份代码,当团队的某个成员在自己的电脑上编写完成了某个功能后,就将代码提交到服务器,其他的成员只需要将服务器上的代码同步到本地,就能保证整个团队所有人的代码都相同的。这样的话,每个团队成员就可以各司其职,大家共同来完成一个较为庞大的项目。

git clone https://xxxxxxxxxxxxxxxx

git push origin master

git fetch origin master
git diff origin/master
git pull origin master(2in1)

git merge origin/master

托管到Git仓库 步骤

傻瓜式:

  1. 首先GitHub上新建repository

  2. git clone到本地target目录

     git clone https://github.com/tony-green/coolweather.git
    
  3. 把本地项目的source code拷贝到本地target目录

     git add .
     git commit -m "First commit."
     git push origin master
    

推送本地git仓库到远程:

git remote add origin git@github.com:michaelliao/learngit.git
git push -u origin master

远程clone

git clone git@github.com:michaelliao/gitskills.git

多人协作

  1. 查看远程库信息,使用git remote -v
  2. 本地新建的分支如果不推送到远程,对其他人就是不可见的;
  3. 从本地推送分支,使用git push origin branch-name,如果推送失败,先用git pull抓取远程的新提交;
  4. 在本地创建和远程分支对应的分支,使用git checkout -b branch-name origin/branch-name,本地和远程分支的名称最好一致;
  5. 建立本地分支和远程分支的关联,使用git branch --set-upstream branch-name origin/branch-name
  6. 从远程抓取分支,使用git pull,如果有冲突,要先处理冲突。

Branch管理

查看有哪些branch:

git branch
git branch –a

创建新branch

git branch version1.0

切换新branch为工作branch

git checkout version1.0

创建并切换分支(2合1命令):

git checkout -b version1.0

merge来自new branch的修改:

git checkout master
git merge version1.0

删除new branch:

git branch -d version1.0
git branch -D version1.0 // 强制删除,丢弃修改

stash

stash的作用就是保存该branch的现场,该branch的工作目录用于他用:

git stash

用完后,需要回复现场,接着之前的工作:

git stash list  // 查看
git stash apply // 恢复stash内容
git stash drop  // 删除stash内容
git stash pop       // (以上2合1的命令)

标签管理

tag就是一个让人容易记住的有意义的名字,它跟某个commit绑在一起。

创建标签:

git tag <name>
git tag v0.9 6224937 // 针对某个commit打标签

查看标签:

git tag
git show <tagname>

删除标签:

git tag -d v0.1

操作:

命令git push origin <tagname>可以推送一个本地标签;

命令git push origin --tags可以推送全部未推送过的本地标签;

命令git tag -d <tagname>可以删除一个本地标签;

命令git push origin :refs/tags/<tagname>可以删除一个远程标签。

配置git

$ git config --global color.ui true

$ git config --global alias.st status
$ git config --global alias.co checkout
$ git config --global alias.ci commit
$ git config --global alias.br branch

参考: 配置方法

部署Git站点(tbd)

搭建Git服务器非常简单,通常10分钟即可完成;

要方便管理公钥,用Gitosis;

要像SVN那样变态地控制权限,用Gitolite。

如何架设git服务器? gogsnun

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,378评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,356评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,702评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,259评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,263评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,036评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,349评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,979评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,469评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,938评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,059评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,703评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,257评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,262评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,485评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,501评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,792评论 2 345

推荐阅读更多精彩内容