• git笔记


    gitstudy

    学习Git笔记

    原文教程:git 廖雪峰

    一、安装Git

    • msysgit是Windows版的Git,下载地址https://gitforwindows.org/,网速慢的可以使用另一个源下载。

    • 安装成功后配置:

      • git config --global user.name "Your Name"
      • git config --global user.email "email@example.com"
      • example:git config --global user.name "chen"
      • example:git config --global user.email "aaa@163.com"
    • 注意git config命令的--global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址。

    二、创建版本库

    • mkdir dir // 创建git仓库目录
    • git init // 初始化一个Git仓库(工作区)
    • git add <file> // 将修改的文件加入暂存区
    • git commit -m "说明" // 提交到历史版本
    • git push origin master // 再推送到远程(此功能需要连到远程仓库,看下文)
    小结:
    初始化一个Git仓库,使用git init命令。<br>
    添加文件到Git仓库,分两步:<br>
        第一步,使用命令git add <file>,注意,可反复多次使用,添加多个文件;<br>
        第二步,使用命令git commit,完成。<br>
    每次修改,如果不add到暂存区,那就不会加入到commit中。<br>
    

    三、时光穿梭

    查看仓库当前状态
    • git status
    小结:
        要随时掌握工作区的状态,使用git status命令。
    
    查看修改内容
    • git diff <filename> // 查看修改内容
    • git diff HEAD --<filename> // 查看工作区与版本库里面最新版本的区别
    小结:
    如果git status告诉你有文件被修改过,用git diff可以查看修改内容
    
    版本回退
    • git log // 查看提交历史
    • git log --pretty=oneline //只查看版本号历史
    • git reflog // 查看命令历史
    • git reset --hard HEAD^ // 回到上一个版本
    • git reset --hard <commit id>(版本号) // 回到指定版本
    • 上一个版本就是HEAD^,上上一个版本就是HEAD^^,往上100个版本HEAD~100
    小结:
    HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,
    

    使用命令git reset --hard commit_id
    穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本
    要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本

    工作区与暂存区
    • Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD
    • 把文件往Git版本库里添加的时候,是分两步执行的:
      • 第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区
      • 第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支
    • 因为我们创建Git版本库时,Git自动为我们创建了唯一一个master分支,所以,git commit就是往master分支上提交更改
    • 可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改
    撤销修改
    • git checkout -- <file> // 可以丢弃工作区的修改(相当于回退到修改前,未git add)
    • 命令git checkout -- <file> 意思就是,把file文件在工作区的修改全部撤销,这里有两种情况:
      • 一种是file自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;
      • 一种是file已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
    • 总之,就是让这个文件回到最近一次git commitgit add时的状态;即将工作区修改的内容回退到之前暂存区或版本库的状态
    • git checkout -- <file>命令中的--很重要,没有--,就变成了“切换到另一个分支”的命令
    • 如果修改完后git add 到暂存区,但是在git commit之前,可以用git reset HEAD <file>把暂存区的修改撤销掉,重新放回工作区。
    • 当修改文件后git add到暂存区,即将工作区提交到暂存区,再修改工作区的文件,使用git checkout -- 可以使暂存区的文件修改记录删除。
    • git reset HEAD <file> 后再用git checkout -- <file> 可以丢弃掉工作区的修改。
    • git reset命令既可以回退版本,也可以把暂存区的修改回退到工作区。当我们用HEAD时,表示最新的版本。
    • 当改错了东西,还从暂存区提交到了版本库时,可以用 版本回退 回退到上一个版本。前提是还没有把本地版本推送到远程。
    小结:
    工作区即当前目录,暂存区即git add 所在的虚拟目录
    场景1:当改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令 git checkout -- file
    场景2:当不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了场景1,第二步按场景1操作。
    场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,用版本回退,不过前提是没有推送到远程库。
    

    image

    删除文件
    • 当在文件管理器中把没用的文件删了,或者用rm命令删了时,有两种情况:
      • 一种是确实要从版本库中删除该文件,那就用命令 git rm <file> 删掉,并且 git commit
      • 一种情况是删错了,因为版本库里还有,所以可以用 git checkout -- <file> 把误删的文件恢复到最新版本。
    • git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
    小结:
    命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么就永远不用担心误删
    但是要小心,只能恢复文件到最新版本,会丢失**最近一次提交后修改的内容**
    

    四、远程仓库

    • 设置SS加密:
      • 第1步:创建SSH Key。查看用户主目录下是否有.ssh目录,如果有,再看看该目录下有没有id_rsa和id_rsa.pub这两个文件,如果已经有了,可直接跳到下一步。
        如果没有,打开Shell(Windows下打开Git Bash),创建SSH Key:ssh-keygen -t rsa -C "youremail@example.com"。id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人
      • 第2步:登陆GitHub,打开“Settings”,“SSH and GPG keys”页面:点“New SSH key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容。最后点“Add SSH key”,此时应该就可以看到已经添加的Key了
    添加远程库(先有本地库,后有远程库)
    • 关联远程库:git remote add origin git@server-name:path/repo-name.git
    • 关联后,把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。
    • 第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
    • 把本地master分支的最新修改推送至GitHub:git push origin master
    小结:
    要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git;
    关联后,使用命令git push -u origin master第一次推送master分支的所有内容;
    此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改。
    
    从远程库克隆(先有远程库,后有本地库)
    • 先在GitHub上创建一个新的仓库,然后使用 git clone git@server-name:path/repo-name.git 克隆一个本地库。
    • git clone chen@域名(ip):/path
    • Git支持多种协议,默认的git://使用ssh,但也可以使用https等其他协议.
      • 在git服务器上添加用户、修改用户组
      • useradd -s /usr/bin/git-shell chen //这里需要制定git-shell
      • usermod -g git chen
      • passwd chen
    小结:
    要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆。
    Git支持多种协议,包括https,但通过ssh支持的原生git协议速度最快。
    

    五、分支管理

    创建与合并分支
    • 在Git里HEAD指向主分支master,而master指向提交,所以HEAD指向的就是当前分支。
    • master分支是一条线,Git用master指向最新的提交,再用HEAD指向master,就能确定当前分支,以及当前分支的提交点;
      每次提交,master分支都会向前移动一步,这样,随着不断提交,master分支的线也越来越长。
    • 当创建新的分支时,例如dev,Git新建了一个指针叫dev,指向master相同的提交,再把HEAD指向dev,就表示当前分支在dev上;从现在开始,对工作区的修改和提交就是针对dev分支了,比如新提交一次后,dev指针往前移动一步,而master指针不变。
    • Git分支合并最简单的方法,就是直接把master指向dev的当前提交,就完成了合并:
      • 1)切换回master分支:git checkout master;
      • 2)把dev分支的工作成果合并到master分支上:git merge dev

    image

    小结:
    查看分支:git branch       //git branch命令会列出所有分支,当前分支前面会标一个*号
    创建分支:git branch <name>
    切换分支:git checkout <name>
    创建+切换分支:git checkout -b <name>
    合并指定分支到当前分支:git merge <name>
    删除分支:git branch -d <name>
    
    解决冲突
    • Git用<<<<<<<,=======,>>>>>>>标记出不同分支的内容。
    • git log --graph --pretty=oneline --abbrev-commit //查看分支的合并情况
    小结:
    当Git无法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。
    用git log --graph命令可以看到分支合并图。
    
    分支管理策略
    • 通常,合并分支时,如果可能,Git会用Fast forward模式,但这种模式下,删除分支后,会丢掉分支信息。
    • 如果要强制禁用Fast forward模式,使用命名git merge --no-ff -m “描述” <branch-name> ,Git就会在merge时生成一个新的commit,这样,从分支历史上就可以看出分支信息。
    • 分支管理基本原则:
    • 首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;
    • 干活都在dev分支上,也就是说,dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本;
    • 每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。
    小结:
    合并分支时,加上--no-ff参数就可以用普通模式合并,合并后的历史有分支
    能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。
    
    Bug分支
    • 软件开发中,bug就像家常便饭一样。在Git中,由于分支是如此的强大,所以,每个bug都可以通过一个新的临时分支来修复,修复后,合并分支,然后将临时分支删除。
    • 当需要修复bug而分支上的工作还没完成时,可以用git stash功能将当前的工作现场“储存”起来,等以后恢复现场后继续工作。
    • git stash list查看“储存”起来的工作现场列表。
    • 恢复工作现场有两种方法:
      • 一时用git stash apply恢复,但是恢复后,stash内容并不删除;
      • 另一种方式是用git stash pop,恢复的同时把stash内容也删了
    • 可以多次stash,恢复的时候,先用git stash list查看,然后用git stash apply stash@{0}恢复指定的stash
    小结:
    修复bug时,我们会通过创建新的bug分支进行修复,然后合并,最后删除;
    当手头工作没有完成时,先把工作现场git stash一下,然后去修复bug,修复后,再git stash pop,回到工作现场。
    
    Feature分支
    • 每添加一个新功能,最好新建一个feature分支,在上面开发,完成后,合并,最后,删除该feature分支。
    • git branch -D <name> // 强行删除没有合并过的分支。
    小结:
    开发一个新feature,最好新建一个分支;
    如果要丢弃一个没有被合并过的分支,可以通过git branch -D <name>强行删除。
    
    多人协作
    • 多人协作的工作模式通常是这样:
      • 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,如果有冲突,要先处理冲突。

    六、标签管理

    • 发布一个版本时,我们通常先在版本库中打一个标签(tag),这样,就唯一确定了打标签时刻的版本。
    • 将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来。所以,标签也是版本库的一个快照。
    • Git的标签虽然是版本库的快照,但其实它就是指向某个commit的指针。
    创建标签
    • 在Git打标签时,需切换到需要打标签的分支上。
    • git tag <name>; // 打一个新标签,默认标签是打在最新提交的commit上的。
    • git tag <tagname> <commit id> // 给指定的版本打一个新标签。
    • git tag // 查看标签。
    • git show <tagname> // 查看标签信息。
    • git tag -a <tagname> -m "描述" <commit id> // 创建带有说明的标签,用-a指定标签名,-m指定说明文字。
    • git tag -s <tagname> -m "描述" <commit id> // 通过-s用私钥签名一个标签。签名采用PGP签名,因此,必须首先安装gpg(GnuPG),如果没有找到gpg,或者没有gpg密钥对,就会报错
    小结:
    命令git tag <name>用于新建一个标签,默认为HEAD,也可以指定一个commit id;
    git tag -a <tagname> -m "..." <commit id> 可以指定标签信息;
    git tag -s <tagname> -m "..." <commit id> 可以用PGP签名标签;
    命令git tag可以查看所有标签;
    命令git show <taganme>可以查看标签信息。
    
    操作标签
    • git tag -d <tagname> //删除标签,创建的标签都只存储在本地,不会自动推送到远程。所以,打错的标签可以在本地安全删除。
    • git push origin <tagname> //推送某个标签到远程。
    • git push origin --tags //一次性推送全部尚未推送到远程的本地标签。
    • 如果标签已经推送到远程,要删除远程标签,分两步:
      • 1、先从本地删除:git tag -d <tagname>;
      • 2、从远程删除。删除命令也是push,格式:git push origin :refs/tags/<tagname>
    小结:
    命令git push origin <tagname>可以推送一个本地标签;
    命令git push origin --tags可以推送全部未推送过的本地标签;
    命令git tag -d <tagname>可以删除一个本地标签;
    命令git push origin :refs/tags/<tagname>可以删除一个远程标签,需先删除本地标签。
    

    七、使用GitHub

    • 在GitHub上,可以任意Fork开源仓库;
    • 自己拥有Fork后的仓库的读写权限;
    • 可以推送pull request给官方仓库来贡献代码。

    八、自定义Git

    忽略特殊文件
    • 在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件。
    • GitHub已有的各种配置文件,只需要组合一下就可以使用了。在线浏览:https://github.com/github/gitignore
    • 忽略文件的原则是:
      • 1.忽略操作系统自动生成的文件,比如缩略图等;
      • 2.忽略编译生成的中间文件、可执行文件等,也就是如果一个文件是通过另一个文件自动生成的,那自动生成的文件就没必要放进版本库,比如Java编译产生的.class文件;
      • 3.忽略你自己的带有敏感信息的配置文件,比如存放口令的配置文件。
    • 当想添加文件到Git,却被.gitignore忽略,添加不了时,可以用 git add -f <filename> 强制添加。
    • git check-ignore -v <filename> //查看.gitignore里那条规则过滤了该文件
    小结:
    忽略某些文件时,需要编写.gitignore;
     .gitignore文件本身要放到版本库里,并且可以对.gitignore做版本管理。
    
    配置别名
    • git config --global alias.<别名> <原操作> //例:git config --global alias.st status配置完后,敲 git st 就相当于git status
    • --global参数是全局参数,也就是这些命令在这台电脑的所有Git仓库下都有用。
    • 配置Git的时候,加上--global是针对当前用户起作用的,如果不加,那只针对当前的仓库起作用。
    • 每个仓库的Git配置文件都放在.git/config文件中;而当前用户的Git配置文件放在用户主目录下的一个隐藏文件.gitconfig中
    
    ##### 搭建Git服务器 [教程地址](http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/00137583770360579bc4b458f044ce7afed3df579123eca000)
  • 相关阅读:
    WIN10X64LTSC2019中度精简版by双心
    MACbook安装WIN7后亮度调节的办法
    MACbook安装WIN7中文版后乱码的解决办法
    MACbook关机开机的咚咚咚声音
    MacBook安装WIN7开机黑屏的解决办法
    小马激活的问题
    安装WIN7系统备忘录
    win7 64位平台编译的程序在XP 32位平台无法运行的解决方法
    for循环包含多个双引号怎么办?windows
    windows下sed回车换行符处理
  • 原文地址:https://www.cnblogs.com/irockcode/p/8669562.html
Copyright © 2020-2023  润新知