Git笔记

作者: 南阳临风 | 来源:发表于2017-01-23 18:26 被阅读0次

    资料

    首次创建

    创建用户

    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

    相关文章

      网友评论

          本文标题:Git笔记

          本文链接:https://www.haomeiwen.com/subject/wzbabttx.html