Git学习

作者: JenniferYe | 来源:发表于2018-10-25 09:47 被阅读9次

git笔记

廖雪峰Git教程

创建版本库(repository)

  1. 创建一个空目录:

    $ mkdir learngit
    $ cd learngit
    $ pwd
    /Users/michael/learngit
    
  2. 通过git init 把这个目录变成Git可以管理的仓库:

    $ git init
    

把文件添加到版本库

一定要放到learngit目录下(子目录亦可)

  1. git add 把文件添加到仓库

    $ git add readme.txt
    
  2. git commit 告诉Git, 把文件提交到仓库

    $ git commit -m "wrote a readme file" 
    

git status 可以让我们时刻掌握仓库当前的状态

gti diff 可以看到做了什么修改

版本回退

  1. HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id
  2. 穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。
  3. 要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。

撤销修改

git checkout -- file可以丢弃工作区的修改:

一种是readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;

一种是readme.txt已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。

总之,就是让这个文件回到最近一次git commitgit add时的状态。

删除文件

$ git rm test.txt

远程仓库

  1. 创建SSH Key

    $ ssh-keygen -t rsa -C "youremail@example.com"
    
  2. 登录GitHub,打开“Account settings”,“SSH Keys”页面;

    然后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容。

添加远程库

  1. 登陆GitHub,然后,在右上角找到“Create a new repo”按钮,创建一个新的仓库

  2. 我们根据GitHub的提示,在本地的learngit仓库下运行命令

  3. 远程库的名字就是origin,这是Git默认的叫法,也可以改成别的,但是origin这个名字一看就知道是远程库

  4. 把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。

    由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。

  5. 从现在起,只要本地作了提交,就可以通过命令

    $ git push origin master
    

从远程库克隆

  1. 登陆GitHub,创建一个新的仓库,名字叫gitskills

  2. 用命令git clone克隆一个本地库

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

创建与合并分支

  1. 创建dev分支,然后切换到dev分支:

    $ git checkout -b dev
    

    git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:

    $ git branch dev
    $ git checkout dev
    
  2. git branch命令查看当前分支:

    $ git branch
    
  3. dev分支的工作完成,我们就可以切换回master分支

    $ git checkout master
    
  4. dev分支的工作成果合并到master分支上

    $ git merge dev
    
  5. 删除dev分支

    $ git branch -d dev
    

解决冲突

  • git status可以告诉我们冲突的文件

  • 直接查看冲突文件内容,Git用<<<<<<<=======>>>>>>>标记出不同分支的内容

  • 带参数的git log也可以看到分支的合并情况

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

分支管理策略

Bug分支

当手头工作没有完成时,先把工作现场git stash一下,然后去修复bug,修复后,再git stash pop,回到工作现场。

多人协作

多人协作的工作模式通常是这样:

  1. 首先,可以试图用git push origin branch-name推送自己的修改;
  2. 如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;
  3. 如果合并有冲突,则解决冲突,并在本地提交;
  4. 没有冲突或者解决掉冲突后,再用git push origin branch-name推送就能成功!

如果git pull提示“no tracking information”,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream branch-name origin/branch-name

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

创建标签

  • 命令git tag用于新建一个标签,默认为HEAD,也可以指定一个commit id;
  • git tag -a -m "blablabla..."可以指定标签信息;
  • git tag -s -m "blablabla..."可以用PGP签名标签;
  • 命令git tag可以查看所有标签。
  • 命令git push origin可以推送一个本地标签;
  • 命令git push origin --tags可以推送全部未推送过的本地标签;
  • 命令git tag -d可以删除一个本地标签;
  • 命令git push origin :refs/tags/可以删除一个远程标签。

操作标签

  • 命令git push origin可以推送一个本地标签;
  • 命令git push origin --tags可以推送全部未推送过的本地标签;
  • 命令git tag -d可以删除一个本地标签;
  • 命令git push origin :refs/tags/可以删除一个远程标签。

相关文章

  • Git+node.js+TDD

    目录 Git学习 node.js学习 用Nodejs和Git完成TDD编程 Git学习 Git是什么Git是一款免...

  • Git 学习笔记

    ----------------- Git 学习 ------------------ Git 简介 Git...

  • git 入门

    git 入门学习笔记----3个入门命令:git init、git add、git commit -v 学习场景(...

  • git技术,GitHub、GitLab

    git学习 Git教程(小白快速入门版) Git教程(简化版) git详细学习 Gitlab的管理使用手册git初...

  • Git常用命令与学习总结

    安装Git Git的下载地址:Git官网下载地址 学习网址 git 学习笔记- Book 在线练习地址 基础常用指...

  • Git学习之思维导图

    Git学习之思维导图 Git学习之思维导图

  • git记录

    Git Magic图解gitgit 学习笔记git游戏(学习)1、消除文档路径中文乱码git config --g...

  • git资源学习

    git资源学习 Git详解之一 Git起步 Git详解之二 Git基础 Git详解之三 Git分支 Git详解之四...

  • Git入门学习资源

    Git入门学习资料 廖雪峰 Git教程 Git官网 Pro Git git 简明指南 github-git-che...

  • 2018-04-18

    git学习小结 关于git init,git add,git commit 用法总结 1.首先配置git 全局配置...

网友评论

      本文标题:Git学习

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