zoukankan      html  css  js  c++  java
  • git环境搭建、git详细使用教程、快速上手git

    Git环境搭建

    一、操作系统上已经有git,但是版本过旧

    (1)右键桌面-点击Git Bash Here,打开git窗口。通过git --version来查看当前的git的版本。

    (2)输入git update-git-for-windows可以进行升级,因为是国外的软件,下载比较慢,请耐心等待。

    git update-git-for-windows

    二、没有安装过git - 安装步骤

    那就跟着我们来看看接下来的内容(以2.23.0的为例,其它版本都类似)

    配置git环境变量

    安装完成后在命令行窗口执行git --version检查命令是否能运行,如果可以表示安装成功,如果提示不是内部命令可能是环境变量有问题。

    安装完成后,还需要最后一步设置,右击电脑桌面,点击Git Bash Here在命令行输入如下:

    因为Git是分布式版本控制系统,所以需要填写用户名和邮箱作为一个标识方便我们在提交代码的时候知道是谁提交的

    git config --global user.name 大汉

    git config --global user.phone 123456

    git config --global user.email "m187XXXXXXXX@163.com"

    git config --list

    注意:git config --global 参数,有了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然你也可以对某个仓库指定的不同的用户名和邮箱。

    Git的使用

    三、git是什么?

    Git是目前世界上最先进的分布式版本控制系统。

    工作原理 / 流程:

    四、SVN与Git的最主要的区别?

           SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而干活的时候,用的都是自己的电脑,所以首先要从中央服务器哪里得到最新的版本,然后干活,干完后,需要把自己做完的活推送到中央服务器。集中式版本控制系统是必须联网才能工作,如果在局域网还可以,带宽够大,速度够快,如果在互联网下,如果网速慢的话,不太合适了。

           Git是分布式版本控制系统,那么它就没有中央服务器的,每个人的电脑就是一个完整的版本库,这样,工作的时候就不需要联网了,因为版本都是在自己的电脑上。既然每个人的电脑都有一个完整的版本库,那多个人如何协作呢?比如说自己在电脑上改了文件A,其他人也在电脑上改了文件A,这时,你们两之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。

    五、创建版本库。

    第一步:什么是版本库?版本库又名仓库,英文名repository你可以简单的理解一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改,删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻还可以将文件”还原”。所以创建一个版本库也非常简单,如下我是E –> 文件夹ceshi下新建一个banbenku版本库。

    第二步:通过命令 git init 把这个目录变成git可以管理的仓库,如下:

    git init

    这时候你当前banbenku目录下会多了一个.git的目录,这个目录是Git来跟踪管理版本的,没事千万不要手动乱改这个目录里面的文件,否则,会把git仓库给破坏了。如下:

    六、把文件添加到版本库中。

    注意:所有的版本控制系统,只能跟踪文本文件的改动,比如txt文件,网页,所有程序的代码等,Git也不列外,版本控制系统可以告诉你每次的改动,但是图片,视频这些二进制文件,虽也能由版本控制系统管理,但没法跟踪文件的变化,只能把二进制文件每次改动串起来,也就是知道图片从1kb变成2kb,但是到底改了啥,版本控制也不知道。

    准备工作:

    首先,我在版本库banbenku目录下新建一个记事本文件 wenjian.txt 新增内容: woshineirong11111

    第一步:使用命令git add wenjian.txt将文件wenjian.txt添加到暂存区里面去。如下:

    git add wenjian.txt

    如果和上面一样,没有任何提示,说明已经添加成功了。

    第二步:用命令git commit -m "wenjian.txt已经提交",告诉Git,把文件提交到仓库。

    git commit -m "wenjian.txt已经提交"

    现在我们已经提交了一个wenjian.txt文件了

    第三步:提交后,我们可以通过命令git status来查看是否还有文件未提交,如下:

    git status

    说明没有任何文件未提交

    七、如何把修改后的文件添加到版本库中。

    第一步:修文件wenjian.txt中的内容,比如我在下面添加一行woshineirong22222的内容,继续使用git status来查看下结果,如下:

    woshineirong22222

    git status

    上面的命令告诉我们wenjian.txt文件已被修改,但是未被提交的修改。

    第二步:查看文件修改了什么内容。如果我想看下wenjian.txt文件到底改了什么内容,如何查看呢?可以使用如下命令:

    git diff wenjian.txt

    如上可以看到,wenjian.txt文件内容从一行“woshineirong11111”修改后,添加了一行woshineirong22222内容。

    第三步:将修改后的文件提交到仓库。知道了对wenjian.txt文件做了什么修改后,我们可以放心的提交到仓库了,提交修改后的文件和提交文件是一样的2步(第一git add wenjian.txt第二是:git commit -m “文件增加woshineirong22222”)。

    git status

    git add wenjian.txt

    git status

    git commit -m “文件增加woshineirong22222”

    git status

    八、查看历史记录、版本回退、版本回退后恢复原来的版本

    上面我们已经学会了修改文件,现在我继续对wenjian.txt文件进行修改,再增加一行

    内容为“woshineirong33333”,继续执行命令如下:

    woshineirong33333

    git add wenjian.txt

    git commit -m "文件增加woshineirong33333"

    第一步:查看历史记录。现在我已经对wenjian.txt文件做了三次修改了,现在想查看下历史记录,如何查呢?在这里可以使用命令git log来查看,如下:

    git log

    git log命令显示从最近到最远的显示日志,我们可以看到最近三次提交,如果嫌上面显示的信息太多的话,我们可以使用命令 git log --pretty=oneline 演示如下:

    git log --pretty=oneline

    第二步:版本回退,如果现在想把当前的版本回退到上一个版本,要使用什么命令呢?可以使用2种命令

    第一种是:回退到上个版本git reset --hard HEAD^ 那如果要回退到上上个版本只需把HEAD^ 改成 HEAD^^ 以此类推。

    回退前:

    回退:

    git reset --hard HEAD^

    回退后:

    第二种:如果要回退到前100个版本的话,使用上面的方法肯定不方便,我们可以使用下面的简便命令操作:git reset --hard HEAD~100 即可。

    可以看到,第一种情况内容已经回退到上一个版本了。我们可以继续使用git log 来查看下历史记录信息,如下:

    git log

    第三步:版本回退后恢复原来的版本。在上面可以看到,文件前面增加的woshineirong33333内容没有看到了,但是现在我想回退到最新的版本就是之前增加的woshineirong33333的内容要如何恢复呢?我们可以通过版本号回退,使用命令方法如下:git reset --hard 版本号

    恢复前:

    恢复:

    git reset --hard 写你之前生成的版本号

    恢复后:

    但是现在有一个问题:假如我已经关掉过一次命令行界面或者33333内容的版本号我并不知道应该怎么办呢?要如何知道增加3333内容的版本号呢?可以通过如下命令即可获取到版本号:git reflog 演示如下:

    git reflog

    通过上面的显示我们可以知道,增加内容33333的版本号是c1b0743我们现在可以命令

    git reset --hard c1b0743来恢复了。演示如下:

    git reset --hard 具体的版本号

    git reflog

    可以看到 目前已经是最新的版本了。

    九、工作区和暂存区的区别

    工作区:就是你在电脑上看到的目录,比如目录下wenjianjia里的文件(.git隐藏目录版本库除外)。或者以后需要再新建的目录文件等等都属于工作区范畴。
    版本库(Repository):工作区有一个隐藏目录.git,这个不属于工作区,这是版本库。其中版本库里面存了很多东西,其中最重要的就是stage(暂存区),还有Git为我们自动创建了第一个分支master,以及指向master的一个指针HEAD。 

    我们前面说过使用Git提交文件到版本库有两步:

    第一步:是使用 git add 把文件添加进去,实际上就是把文件添加到暂存区。

    第二步:使用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支上。

     我们继续使用demo来演示下: 

    我们在wenjian.txt再添加一行内容为woshineirong44444,接着在目录下新建一个文件为wenjian2.txt 内容为zhangsan11111,我们先用命令 git status来查看下状态,如下:

    修改前: 

    git status 

    修改:

    woshineirong44444

    wenjian2.txt      zhangsan11111

    修改后:

    git status

    现在我们先使用git add 同时提交当前目录下所有文件git add .命令把2个文件都添加到暂存区中,再使用git status来查看下状态,如下:

    git add wenjian.txt

    git add wenjian2.txt

    git status

    接着我们可以使用git commit一次性提交到分支上,如下:

    git commit -m "一次性提交所有文件,包括wenjian.txt和wenjian2.txt"

    git status

    十、Git撤销修改和删除文件操作

    1、撤销修改:
    比如我现在在wenjian.txt文件里面增加一行内容为woshineirong55555如下:

    woshineirong55555

    在我未提交之前,发现添加woshineirong55555的内容有误,所以我得马上恢复以前的版本,在之前可以如下几种方法可以做修改:

    1如果我知道要删掉些内容的话,直接手动更改去掉那些需要的文件,然后add添加到暂存区,最后commit掉。

    2我可以按以前的方法直接恢复到上一个版本。使用 git reset --hard HEAD^

    但是现在我不想使用上面的2种方法,我想直接想使用撤销命令该如何操作呢?

    第一种情况:wenjian.txt自动修改后,还没有放到暂存区使用撤销修改就回到和版本库一模一样的状态

    在做撤销之前,我们可以先用 git status 查看下当前的状态。如下所示:

    git status

    可以发现,Git会告诉你,git restore (git版本在2.23前的使用git checkout -- file 可以恢复复原工作区的修改,如下命令:git restore -- wenjian.txt 如下所示:

    git restore -- wenjian.txt

    命令 git restore --wenjian.txt 意思就是,把wenjian.txt文件在工作区做的修改全部撤销,这里
    第二种情况:文件wenjian.txt进行修改,然后放入暂存区,接着又作了修改,撤销修改就回到添加暂存区后的状态。操作如下:
    wenjian.txt文件添加一行内容为woshineirong66666

    woshineirong66666

    通过git add 增加到暂存区后,接着添加内容woshineirong77777,我想通过撤销命令让其回到暂存区后的状态。如下所示:

    git add wenjian.txt

    git status

    woshineirong77777

    执行撤销及查看结果(发现woshineirong77777已经被撤销):

    git restore -- wenjian.txt

    注意:命令git restore -- wenjian.txt 中的 -- 很重要,如果没有 -- 的话,那么命令变成创建分支了。

    2、删除文件
    假如我现在版本库banbenku目录添加一个文件wenjian3.txt,然后提交。如下:

    git add wenjian3.txt

    git commit -m "添加了wenjian3.txt的文件"

    可以直接在目录下手动点击删掉文件wenjian3.txt

    git status

    此时有2个选择,1.直接commit掉。2.从版本库中恢复被删除的文件

    直接commit命令提交掉可以彻底从版本库中删掉此文件,

    没有commit之前,如果我想在版本库中恢复此文件如何操作呢?

    可以使用如下命令 git restore -- wenjian3.txt,如下所示:

    git restore -- wenjian3.txt

    十一、远程仓库

    1、注册github账号

    注册地址:https://github.com/

    2、window下配置SSH连接GitHub、GitHub配置ssh key。由于你的本地Git仓库和github仓库之间的传输是通过SSH加密的,所以需要一点设置:
    1创建SSH Key。在用户主目录下,看看有没有.ssh目录,如果没有的话,打开命令行,输入如下命令:

    ssh-keygen -t rsa –C “youremail@example.com”

    ssh-keygen -t rsa -C "m18774341199@163.com"

    设置好后,看看这个目录下有没有id_rsa和id_rsa.pub这两个文件id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人

    2登录github打开”settings”中的SSH Keys页面,然后点击“Add SSH Key”,填上任意title,在Key文本框里黏贴id_rsa.pub文件的内容。

    点击 Add SSH Key,你就可以看到已经添加的key 

    十二、如何添加远程仓库?

    现在的情景是:我们已经在本地创建了一个Git仓库(banbenku)后,又想在github创建一个Git仓库,并且希望这两个仓库进行远程同步,这样github的仓库可以作为备份,又可以其他人通过该仓库来协作。

    1首先,在网页上登录github上,然后在右上角找到“New repository”创建一个新的仓库。如下:

    2)填写仓库的名称banbenku(注意github上的库名称要和本地上的git库名称相同),并创建。

    目前,在GitHub上的这个banbenku仓库还是空的,GitHub告诉我们,可以从这个仓库克隆出新的仓库,也可以把一个已有的本地仓库与之关联,然后,把本地仓库的内容推送到GitHub仓库。

    3现在,我们根据GitHub的提示,在本地的banbenku仓库下运行命令用你们自己的

    git remote add origin https://github.com/Miraclefruit/banbenku.git

    4)把本地仓库分支master内容推送到远程仓库去

    git push -u origin master

    中途可能会弹出登录窗口,登录就行了。

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

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

    5推送成功后,可以立刻在github页面中看到远程库的内容已经和本地一模一样了,上面的要输入github的用户名和密码如下所示:

    6从现在起,只要本地作了提交,就可以通过如下命令:

    git push origin master

    把本地master分支的最新修改推送到github上了,现在你就拥有了真正的分布式版本库了。

    十三、假如远程库有新的内容,如何从远程库克隆到本地库

    上面我们了解了先有本地库,后有远程库时候,如何关联远程库。现在我们想,假如远程库有新的内容了,我想克隆到本地来,,如何克隆呢?

    1首先,登录github,创建一个新的仓库,名字叫banbenku2如下:

    如下,我们看到:

    现在,远程库已经准备好了,下一步是使用命令git clone库地址(用你们自己的),克隆一个本地库了。如下所示:

    git clone https://github.com/Miraclefruit/banbenku2

    接着在我本地目录下生成banbenku2目录了,如下所示:

    演示了怎么从github上拉代码后,我们手动在文件夹中把这个banbenku2给删除了

    十四、创建分支

    在版本回填退里,你已经知道,每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支。截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支。HEAD严格来说不是指向提交,而是指向master,master才是指向提交的,所以,HEAD指向的就是当前分支。

    首先,我们来创建dev分支,然后切换到dev分支上。如下操作:

    git checkout -b dev

    git branch

    git checkout 命令加上 –b参数表示创建并切换,相当于如下2条命令

    git branch dev

    git checkout dev

    git branch查看分支,会列出所有的分支,当前分支前面会添加一个星号。然后我们在dev分支上继续做demo,比如我们现在在wenjian.txt再增加一行woshineirong88888

    首先我们先来查看下wenjian.txt内容,接着添加内容woshineirong88888,如下:

    woshineirong8888

    git add wenjian.txt

    git commit -m "dev分支上增加内容woshineirong88888"

    现在dev分支工作已完成,现在我们切换到主分支master上,继续查看wenjian.txt内容如下:

    git checkout master

    cat wenjian.txt

    因为现在不在dev下,所以woshineirong88888不见了。

    十五、合并分支

    现在如果我们dev分支上的内容合并到分支master上,可以在master分支上,使用如下命令 git merge dev 如下所示:

    git merge dev

    cat wenjian.txt

    git merge命令用于合并指定分支到当前分支上,合并后,再查看wenjian.txt内容,可以看到,和dev分支最新提交的是完全一样的。

    注意到上面的Fast-forward信息,Git告诉我们,这次合并是“快进模式”,也就是直接把master指向dev的当前提交,所以合并速度非常快。

    合并完成后,我们可以接着删除分支dev了,操作如下:

    git branch -d dev

    git branch

    总结创建分支与合并分支命令如下:

    查看分支:git branch

    创建分支:git branch name

    切换分支:git checkout name

    创建+切换分支:git checkout –b name

    合并某分支到当前分支:git merge name

    删除分支:git branch –d name

    十六、如何解决分支合并冲突?

    (1)下面我们还是一步一步来,先新建一个新分支,比如名字叫fenzhi1,在wenjian.txt添加一行内容woshineirong99999,然后提交,如下所示:

    git checkout -b fenzhi1

    cat wenjian.txt

    添加内容woshineirong99999和woshineirong00000:

    添加内容woshineirong99999woshineirong00000后,提交内容:

    git add wenjian.txt

    git commit -m "在fenzhi1上新增woshineirong99999和woshineirong00000"

    2同样,我们现在切换到master分支上来,也在最后一行添加内容woshineirong99999,如下所示:

    git checkout master

    cat wenjian.txt

    添加内容woshineirong99999后,提交内容:

    cat wenjian.txt

    git add wenjian.txt

    git commit -m "在master上新增woshineirong99999"

    (3)现在我们需要在master分支上来合并fenzhi1,如下操作:

    git merge fenzhi1

    git status

    cat wenjian.txt

    Git用<<<<<<<,=======,>>>>>>>标记出不同分支的内容,其中<<<HEAD是指主分支修改的内容,>>>>>fenzhi1 是指fenzhi1上修改的内容

    (4)出现冲突后,我们可以对主分支、结合、合并分支进行修改保存即可:

    git add wenjian.txt

    cat wenjian.txt

    git commit -m "整合冲突部分内容再次提交"

    5假如想查看分支合并的情况的话,需要使用命令 git log 命令进行查看。(使用英文字母q可以退出日志查看)

    十七、 分支管理策略

    通常合并分支时,git一般使用”Fast forward”模式,在这种模式下,删除分支后,会丢掉分支信息,现在我们来使用带参数 –no-ff来禁用”Fast forward”模式。首先我们来做demo演示下:

    大致步骤如下:

    创建一个dev分支。
    修改wenjian.txt内容。
    添加到暂存区。
    切换回主分支(master)。
    合并dev分支,使用命令 git merge –no-ff -m “注释” dev
    查看历史记录
    截图如下:

    git checkout -b dev

    新增文件wenjian4.txt

    git add wenjian4.txt

    git commit -m "新增wenjian4.txt"

    git checkout master

    git merge --no-ff -m "禁用fast forward" dev

    git branch -d dev

    git branch

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

    分支策略:首先master主分支应该是非常稳定的,也就是用来发布新版本,一般情况下不允许在上面干活,干活一般情况下在新建的dev分支上干活,干完后,比如要发布,或者说dev分支代码稳定后可以合并到主分支master上来。

    十八、 bug分支

    在开发中,会经常碰到bug问题,那么有了bug就需要修复,在Git中,分支是很强大的,每个bug都可以通过一个临时分支来修复,修复完成后,合并分支,然后将临时的分支删除掉。

    比如我在开发中接到一个404 bug时候,我们可以创建一个404分支fenzhi3来修复它,但是,当前的fenzhi2分支上的工作还没有提交。

    并不是我不想提交,而是工作进行到一半时候,我们还无法提交,比如我这个fenzhi2分支bug要2天完成,但是我404 bugfenzhi3需要5个小时内完成。怎么办呢?还好,Git还提供了一个stash功能,可以把当前工作现场 ”隐藏起来”,等以后恢复现场后继续工作。如下先创造一个fenzhi2正在工作的状态

    创建并切换分支fenzhi2    

    git checkout -b fenzhi2

    git status

    将当前fenzhi2正在工作的状态隐藏起来:

    git stash

    git status

    所以现在我可以通过创建fenzhi3(处理404bug)分支来修复bug了。

    首先我们要确定在那个分支上修复bug,比如我现在是在主分支master上来修复的,现在我要在master分支上创建一个临时分支,演示如下:

    先切换到主分支git checkout master

    创建临时分支修复404缺陷fenzhi3 git checkout -b fenzhi3

    修改前文件内容:cat wenjian.txt

    修改

    修改后:

    cat wenjian.txt

    提交:

    git add wenjian.txt

    git commit -m "修改 404 bug"

    修复完成后,切换到master分支上,并完成合并,最后删除fenzhi3(处理404bug)分支。演示如下:

    git checkout master

    git merge --no-ff -m "合并分支修改404bug的内容" fenzhi3

    cat wenjian.txt

    git branch -d fenzhi3

    git branch

    现在,我们回到分支fenzhi2上干活了。

    git checkout fenzhi2

    git status

    工作区是干净的,那么我们工作现场去哪里呢?我们可以使用命令 git stash list来查看下。如下:

    git stash list

    工作现场还在,Git把stash内容存在某个地方了,但是需要恢复一下,可以使用如下2个方法:

    (1)git stash apply恢复,恢复后,stash内容并不删除,你需要使用命令git stash drop来删除。
    (2)另一种方式是使用git stash pop,恢复的同时把stash内容也删除了。
    演示如下

    git stash list

    git stash pop

    git stash list

    git status

    git add wenjian3.txt

    git commit -m "提交wenjian3.txt"

    出处:https://home.cnblogs.com/u/erweimalaoshi/

    欢迎转载,但未经作者同意请保留此段声明,并在文章页面明显位置给出原文链接。

     

  • 相关阅读:
    sql 连表
    Laravel 数据验证
    zend studio 破解、汉化和字体颜色及快捷键相关设置
    关于storm的一些知识点
    storm架构原理及集群部署
    storm使用过程中出现的错误:Caused by: java.net.UnknownHostException: storm: 未知的名称或服务
    ElasticSearch基础知识
    ElasticSearch java客户端更新时出现的错误:NoNodeAvailableException[None of the configured nodes are available
    sublime text3 注册码 (Version 3.0)
    使用HTMLTestRunner生产报告
  • 原文地址:https://www.cnblogs.com/erweimalaoshi/p/13529275.html
Copyright © 2011-2022 走看看