git分布式版本控制系统

一、分支概念

每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支。截止

到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支。

HEAD 严格来说不是指向提交,而是指向master,而 master才是指向提交

的,所以,HEAD指向的就是当前分支。

开始的时候,master分支是一条线,Git 用 master 指向最新的提交,再用

HEAD指向 master,就能确定当前分支,以及当前分支的提交点。每次提

交,master分支都会向前移动一步,这样,随着你不断提交,master分支

的线也越来越长。

二、创建分支过程

1、git仓库的建立

[root@git ~]# yum search git|grep git.x86

[root@git ~]# yum -y install git

[root@git ~]# rpm -qa|grep git

git-1.8.3.1-25.el7_9.x86_64

linux-firmware-20180220-62.git6d51311.el7.noarch

crontabs-1.11-6.20121102git.el7.noarch

[root@git ~]# rpm -ql git

1)创建一个空目录,使用git指令一定要cd到初始化之后的目录,init命令初始

[root@git ~]# mkdir /yy000

2)进入这个目录

[root@git ~]# cd /yy000/

3)执行git init 指令

[root@git yy000]# git init  # 初始化工作区(yy000)和仓库(.git)

初始化空的 Git 版本库于 /yy000/.git/

4)发现隐藏目录.git

[root@git yy000]# ls -a

.  ..  .git

[root@git yy000]# cd .git/

[root@git .git]# ls

branches  description  hooks  objects

config    HEAD         info   refs

[root@git .git]# cd ..

[root@git yy000]# vim Test.java

public class Test{
        public static void main(String [] args){
                System.out.println("hello world");

        }

}

[root@git yy000]# git log

fatal: bad default revision 'HEAD'

2、常用指令:

格式:git add .|文件名   # 将修改的文件提交的暂存区域

git commit -m "说明" 将暂存区的数据保存到仓库

git log 查看提交日志

[root@git yy000]# git config --global user.name caizijuan  # 放进仓库

[root@git yy000]# git config --global user.email 19119921829@163.com

[root@git yy000]# echo "//这是一行java注释,不会被编译,能提高文件的可读

性" > Test.java   # 修改Test.java文件,添加一行注释

[root@git yy000]# cat Test.java

//这是一行java注释,不会被编译,能提高文件的可读性

[root@git yy000]# git log

commit 7685d39974154b97bb156ca51d3da0beb0650266

Author: caizijuan <19119921829@163.com>

Date:   Thu Jul 25 10:48:07 2024 +0800

新建了一个Test..java文件,这是新建的

[root@git yy000]# git add .    # add后面加.表示当前目录所有文件

[root@git yy000]# git commit -m "这是第二次提交项目"[master dc3c99e] 这是第

二次提交项目

 1 file changed, 1 insertion(+), 5 deletions(-)

[root@git yy000]# echo "//又加了一个注释" >> Test.java

[root@git yy000]# cat Test.java

//这是一行java注释,不会被编译,能提高文件的可读性

//又加了一个注释

[root@git yy000]# git log   # 没有commit就不会产生日志

[root@git yy000]# git add .

[root@git yy000]# git commit -m "将缓存中的内容提交 到仓库"  #  -m:会调用

终端的注释

[root@git yy000]# git log   # 新增了

[root@git yy000]# echo "//再次添加注释" >> Test.java[root@git yy000]# cat Test.java

//这是一行java注释,不会被编译,能提高文件的可读性

//又加了一个注释

//再次添加注释

[root@git yy000]# git add .

[root@git yy000]# git commit -m "在提交仓库的同时也为自己创建了一个还原点"

[root@git yy000]# git branch     # 查看当前仓库的分支

* master

3、分支:(意义:让一个项目有多重可能性)

1)分支的创建

git branch 新分支名称

2)切换分支

git checkout 分支名称

git checkout -b新分支名称  //创建的同时进行切换

3)删除分支,要求是分支已经合并

git branch -d 分支名     git branch -D 分支名  //强制删除

[root@git yy000]# git branch -d abranch

[root@git yy000]# git branch -d bbranch

[root@git yy000]# git branch -d cbranch

[root@git yy000]# git branch -d dbranch

[root@git yy000]# git branch

* master

# 当前只有一个主分支,工作完成后,其他分支都会合并到主分支

4)查看分支 git branch 有几行,就有几个分支,*标注当前所在的分支

git branch   git status

5)分支合并

git merge分支名称

git checkout abranch  //切换到a分支

git merge bbranch  //在a分支下合并b分支

6)分支冲突(将两个分支合并时产生的)

# 产生的原因:合并的时候有可能出现在文件冲突,即主分支或其他分支都修了

这个文件,此时合并时不知道以哪个分支为主

# 解决:手动修改一部分,只保留主分支修改的内容再提交

[root@git yy000]# git add Test.java     # git add表示添加缓存

[root@git yy000]# git commit -m "新建了一个Test..java文件,这是新建的"  

# 创建newbranch分支,修改内容

[root@git yy000]# echo "//我是主分支 ,我修改了文件" > Test.java

[root@git yy000]# git checkout -b newbranch

[root@git yy000]# git branch

  master

* newbranch

[root@git yy000]# cat Test.java

//我是主分支 ,我修改了文件

[root@git yy000]# echo "//我是newbranch分支" > > Test.java

[root@git yy000]# cat Test.java

//我是主分支 ,我修改了文件

//我是newbranch分支

[root@git yy000]# git checkout newbranch

[root@git yy000]# git status

# 位于分支 newbranch

[root@git yy000]# git add .

[root@git yy000]# git commit -m "abcd"

# 回到主分支修改内容

[root@git yy000]# git checkout master

[root@git yy000]# cat Test.java    # 发现内容并未改变

[root@git yy000]# echo "eft" >> Test.java

[root@git yy000]# git add .

[root@git yy000]# git commit -m "mntyuo"

[root@git yy000]# git branch

* master

  newbranch

# 将newbranch合并到主分支

[root@git yy000]# git merge newbranch

自动合并 Test.java

冲突(内容):合并冲突于 Test.java

自动合并失败,修正冲突然后提交修正的结果。

[root@git yy000]# cat Test.java

<<<<<<< HEAD

//这是一行java注释,不会被编译,能提高文件的可读性

//又加了一个注释

//再次添加注释

// 我是a员工,我不骄傲

我是b员工

eft

=======

//我是主分支 ,我修改 了文件

//我是newbranch分支

>>>>>>> newbranch

# 解决:手动修改一部分,只保留主分支修改的内容再提交

[root@git yy000]# vim Test.java

我是b员工

eft

[root@git yy000]# git add .

[root@git yy000]# git commit -m "合并修正"

[master b1f3f55] 合并修正

[root@git yy000]# git log

项目实战

需求:abc三人实现一个接口Test.java,但一个文件在同一时间只能被一个用户

编辑。

切换到master分支
格式:git branch 分支名称    git checkout -b 分支名称   //分支的同时创建分

[root@git yy000]# git checkout master

已经位于 'master'

[root@git yy000]# ls

Test.java

[root@git yy000]# cat Test.java

//这是一行java注释,不会被编译,能提高文件的可读性

//又加了一个注释

//再次添加注释

2、创建分支 abranch

[root@git yy000]# git branch abranch  

[root@git yy000]# git branch   #  查看当前所在的分支及总分支

  abranch

* master

3、切换分支 'abranch'

[root@git yy000]# git checkout abranch

切换到分支 'abranch'

[root@git yy000]# git branch

* abranch

  master

[root@git yy000]# cat Test.java

//这是一行java注释,不会被编译,能提高文件的可读性

//又加了一个注释

//再次添加注释

4、添加内容

[root@git yy000]# echo "// 我是a员工,我不骄傲" >> Test.java

[root@git yy000]# cat Test.java

//这是一行java注释,不会被编译,能提高文件的可读性

//又加了一个注释

//再次添加注释

// 我是a员工,我不骄傲

[root@git yy000]# git add .

[root@git yy000]# git commit -m "a员工提交的内容"

[root@git yy000]# git branch   #  主分支

  abranch

* master

[root@git yy000]# cat Test.java   # 没有此行(// 我是a员工,我不骄傲

)

[root@git yy000]# git checkout -b bbranch

切换到一个新分支 'bbranch'

[root@git yy000]# git branch

  abranch

* bbranch

  master

[root@git yy000]# cat Test.java

//这是一行java注释,不会被编译,能提高文件的可读性

//又加了一个注释

//再次添加注释

// 我是a员工,我不骄傲

[root@git yy000]# echo "我是b员工" >> Test.java

[root@git yy000]# git branch

  abranch

* bbranch

  master

[root@git yy000]# git checkout abranch

M Test.java

切换到分支 'abranch'

[root@git yy000]# cat Test.java

//这是一行java注释,不会被编译,能提高文件的可读性

//又加了一个注释

//再次添加注释

// 我是a员工,我不骄傲

我是b员工

5、测试

[root@git yy000]#mkdir abc

[root@git yy000]#touch efg

[root@git yy000]#git add abc/

[root@git yy000]#git commmit -m "更新一个目录"

[root@git yy000]#git add efg

[root@git yy000]#git commmit -m "新增了一个efg目录"

[root@git yy000]#git add .

[root@git yy000]#git commmit -m "所有文件都提交"

git拉取 

环境准备

两台主机:git(192.168.2.27)    lq(192.168.2.28)

1、安装git

[root@lq ~]# yum -y install git

2、作免密,连接到git主机

[root@lq ~]# ssh-keygen

[root@lq ~]# ssh-copy-id root@192.168.2.27

[root@lq ~]# ssh root@192.168.2.27

Last login: Thu Jul 25 14:02:56 2024 from 192.168.2.88

[root@git ~]#

3、复制git主机上的资料

[root@lq ~]# git clone 192.168.2.27:/yy000/.git

[root@lq ~]# ls

anaconda-ks.cfg  soft  yy000

[root@lq ~]# cd yy000/

[root@lq yy000]# ls

efg  Test.java

[root@lq yy000]# ls -a    # 查看隐藏文件

.  ..  efg  .git  Test.java

4、设置自己的姓名和邮箱并修改内容

[root@lq yy000]# git pull   #  获取更新的内容

Already up-to-date.

[root@lq yy000]# git config --global user.name aaa

[root@lq yy000]# git config --global user.email juan@163.com

[root@lq yy000]# touch A.class

[root@lq yy000]# git add .

[root@lq yy000]# git commit -m "mnt"

在码云上创建项目并pull和push

仓库初始化

[root@lq ~]# git clone https://gitee.com/cai-zijuan/huajuan.git

[root@lq ~]# cd huajuan/

[root@lq huajuan]#

[root@lq huajuan]# ls

README.en.md  README.md

[root@lq huajuan]# mkdir -p src/main/java/

[root@lq huajuan]# ls

README.en.md  README.md  src

[root@lq huajuan]# touch src/main/java/Test.java

[root@lq huajuan]# tree src/

src/

└── main

    └── java

        └── Test.java

[root@lq huajuan]# git add .

[root@lq huajuan]# git commit -m "文件提交"

[root@lq huajuan]# git push  #  输入账号和密码

[root@lq huajuan]# vim src/main/java/Test.java

public class Test{
public static void main(String [] args){
System.out.println("i shi ceshi test");

}

}

[root@lq huajuan]# git add .

[root@lq huajuan]# git commit -m "做测试"

[root@lq huajuan]# git pull   # 查看最新的及被修改过的
————————————————

                            版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
                        
原文链接:https://blog.csdn.net/m0_74614835/article/details/140695243

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值