首页 > 其他分享 >git工具使用

git工具使用

时间:2022-10-23 01:11:06浏览次数:89  
标签:git -- repos 使用 test libin 工具 root

第四章 Asible最佳实践-进阶版-RHCA447-(git代码托管平台)

说明:

基础代码架构:无需动手管理基础架构; 自动化代码来定义和构建系统;如果anisble是用来定义这种基础架构的代码;则使用版本控制器;git用来跟踪和控制代码的更改非常有效;

版本控制允许我们对基础架构的代码不同阶段,例如开发、生产、生命周期的管理等等;还能更改我们提交到的分支,并在我们的开发和测试环境中都能很好的应用;测试通过后,可以将其合并到生产代码中去,并且更改应用的基础代码结构;Git就是分布式版本控制系统,允许开发人员管理项目中文件的更改;具有查看和还原旧的版本;比较同一个文件2个版本的识别的更改能力;以及能记录哪些人更改和更改的记录和日志;多个用户更改文件;解决冲突更改并合并在一起的机制;开发人员能克隆远程存储库,在本地存储库创建远程存储库的完整本地副本,而不仅是项目的完整快照;很多快照能暂时存一组相关的更改,并提交给本地存储库,并不会对共享的远程存储库做任何的更改,最后可以push上传到远程存储库;在网络正常的情况下我们可以将远程存储库clone或pull到本地存储库来。

modified:工作树文件的副本已经被编辑,并且与存储库中的最新版本不同。

staged:已经修改的文件已经添加到已更改的文件列表中,以作为一个集合准备提交,但这个状态尚未提交。

committd:已修改的文件已提交到本地存储库中。

15.1 安装git与使用

 

说明:由于我这里没有搭建git服务器,因此都在本地操作

[root@libin ~]# yum  search git | grep ^git

 

 

 

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

 

 

 

[root@libin ~]# git config  -h

用法:git config [选项]

配置文件位置

--global              使用全局配置文件

--system              使用系统级配置文件

--local                使用版本库级配置文件

-f, --file <文件>        使用指定的配置文件

--blob <blob-id>        read config from given blob object

操作

--get                 获取值:name [value-regex]

--get-all               获得所有的值:key [value-regex]

--get-regexp           根据正则表达式获得值:name-regex [value-regex]

--replace-all           替换所有匹配的变量:name value [value_regex]

--add                 添加一个新的变量:name value

--unset               删除一个变量:name [value-regex]

--unset-all             删除所有匹配项:name [value-regex]

--rename-section       重命名小节:old-name new-name

--remove-section       删除一个小节:name

-l, --list               列出所有

-e, --edit              打开一个编辑器

--get-color <slot>       找到配置的颜色:[默认]

--get-colorbool <slot>    找到颜色设置:[stdout-is-tty]

类型

--bool                值是 "true" 或 "false"

--int                  值是十进制数

--bool-or-int           值是 --bool or --int

--path                值是一个路径(文件或目录名)

其它

-z, --null               终止值是NUL字节

--includes              查询时参照 include 指令递归查找

merge                 切换到我要分支,merge我要合并的那个分支

git remote -v            查看远程库   

git log --all              查看所有文件历史修改记录      

git log --oneline          查看提交记录信息

cat .git/config            查看本地存储库配置

git branch  -vv            查看分支

[root@libin test]# git reset  --hard 5xxxxxxxxx   恢复到旧版本

git branch origin           创建分支

git checkout origin          切换分支

git push --set-upstream [email protected]:test.git origin  #指定仓库分支上传push

15.2 git的基本使用

实战1:git的基本命令使用

[root@libin git-repos]# git --version

git version 1.8.3.1

https://github.com/git/git/releases   #查看git的最新版  不要下载带有-rc的,因为它代表了一个候选发布版本

[root@libin ~]# git config   --global -l  #查看全局配置

 

[root@libin ~]# git config   --global user.name libin               #设置用户名

[root@libin ~]# git config   --global user.email [email protected]  #设置邮箱

[root@libin ~]# git config   --global push.default simple           #简单的推送方式

[root@libin ~]# git config   --global credential.helper store   

[root@libin ~]# mkdir git-repos                               #创建一个git仓库

[root@libin ~]# cd git-repos/

[root@libin git-repos]# git init              #变成Git可以管理的仓库的目录,初始化仓库会创建一个./git的目录

初始化空的 Git 版本库于 /root/git-repos/.git/

 

[root@libin git-repos]# git status        #查看仓库的状态

 

拷贝一个yaml文库到本我的git仓库

[root@libin git-repos]# cp /home/libin/ansible/rhca447-46.yaml .

[root@libin git-repos]# git status -sb       #查看文件当前的状态

 

[root@libin git-repos]# git add .          #将文件添加到暂存区,再观察其状态

 

[root@libin git-repos]# git commit -m "this is modify by root"  #将文件正式提交到本地仓库,git commit -m "信息",##master说明已经将文件上传成功,但是我这里为本地

 

[root@libin git-repos]# cd .git/

[root@libin .git]# ls               #这时就会多了许多文文件

[root@libin .git]# git log            #可以查看历史变动

 

[root@libin git-repos]# git push                          #表示上传到远程服务器上

[root@libin .git]# git clone [email protected]:/root/git-repos/   #克隆一个本地版本库

 

[root@libin git-repos]# vim rhca447-46.yaml         #对该文件进行修改

 

[root@libin git-repos]# cd git-repos/                #进入到另外1个版本库中

[root@libin git-repos]# ls

[root@libin git-repos]# git pull                     #拉取最新的文件

 

[root@libin git-repos]# git branch libin                #建立一个新的分支

[root@libin git-repos]# git checkout libin               #切换分支

 

[root@libin rhca447]# git remote -v                   #查看关联的远程库

 

git push --set-upstream origin master       libin分支不push到master分支

git branch -a                           查看当前分支

git checkout libin                        切换分支

git branch rhce                          创建分支 rhce

git status                               查看项目的状态

git remote -v                             

15.3 git本地存储库与远程库github关联

实战2:  本地分支与远程库的关联

1、克隆一个服务端创建的新仓库,克隆gitee上的版本库到本地仓库

[root@libin git-repos]# git clone https://gitee.com/LIBIN_LINUX/rhca447.git

2、进入rhca447目录

[root@libin git-repos]# cd rhca447/

[root@libin rhca447]# pwd

/root/git-repos/rhca447

3、编辑一个新的文件

[root@libin rhca447]# vim rhca447-httpd.yaml

4、将文件提交到暂存区

[root@libin redhat]# git add rhca447-20221021.txt

[root@libin rhca447]# git commit -m "rhca447-httpd.yaml update v1"

 

5、正式将本地master分支给服务器推送文件

[root@libin rhca447]# git push origin master

 

6、服务端便可

以查看到提交,并可查看内容

 

7、服务端编辑更新rhca447-20221021.txt文件提交

 

8、拉取服务端的更新的文件

[root@libin redhat]# git pull origin master

 

9、客户端查看内容

 

 

 

15.4  不同用户协作分支

创建一个裸仓库当成中央仓库,在root 和libin 进行先clone裸仓库,就是一个正常的存储仓库,然后再修改文件,例如:root: push上传中央仓库,普通用户要pull 下来,然后普通用户再修改上传;

 

实战1:

(一)、构建裸仓库

# 创建1个git用户目录

[root@libin ~]# mkdir /home/git   

# 创建一个git用户              

[root@libin ~]# useradd git                     

[root@libin ~]# cd /home/git    

# 生成一个中央仓库(裸仓库)               

[root@libin ~]# git init --bare test.git                      

[root@libin ~]# cd /home/git/test.git                  

# 创建分支名,git remote remove name:为删除分支名,这里我没有操作;若后面创建目录为master的分支时需要这条命令:git remote add  origin [email protected]:test.git

[root@libin ~]# git remote add origin /home/git/test.git

# 这样,裸仓库就搭建成功了

[root@libin ~]# chown -R git:git test.git                   

 

(二)、普通用户构建存储库并上传文件至中央仓库

# 下面添加的环境变量就相当于git status -sb=#查看文件当前的状态

[libin@libin ~]$ vim ~/.bashrc

export PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w$(__git_ps1 " (%s)")\$'

[libin@libin ~]$ source ~/.bashrc

 

# 创建一个目录

libin@libin:~ (master %)$mkdir test

libin@libin:~ (master %)$cd test/

# 克隆裸仓库,形成本地存储库

libin@libin:~/test (master)$git clone [email protected]:/home/git/test.git

 

# 创建一个文件rhca447.yaml

libin@libin:~/test/test (master #)$echo "welcom to study git" >>rhca447.yaml

# 提交到暂存区

libin@libin:~/test/test (master #%)$git add .

# 提交到本地存储库

libin@libin:~/test/test (master #)$git commit -m 'new rhca447.yaml'

# 上传到中央仓库

libin@libin:~/test/test (master)$git push

 

 

(三)管理员构建存储库并上传文件至中央仓库

[root@libin ~]# mkdir test/

[root@libin ~]# cd test/

# 克隆裸仓库,形成本地存储库,此时clone的存储库中肯定有libin用户提交的文件

[root@libin test]# git clone [email protected]:/home/git/test.git

 

# 创建一个文件rhca4472.yaml

[root@libin test]# echo "welcom to you changsha" >>rhca4472.yaml

# 提交到暂存区

[root@libin test]# git add .

# 提交到本地存储库

[root@libin test]# git commit -m 'new rhca4472.yaml'

# 上传到中央仓库

[root@libin test]# git push

 

 

(四)普通用户拉去中央仓库文件

libin@libin:~/test/test (master)$git pull

 

libin@libin:~/test/test (master)$cat rhca4472.yaml

welcom to you changsha

 

(五)普通用户协作文件并push上传中央仓库

libin@libin:~/test/test (master)$echo "first-day:adduser" >>rhca447.yaml

libin@libin:~/test/test (master *)$git add .

libin@libin:~/test/test (master +)$git commit -m "first-day:adduser"

libin@libin:~/test/test (master)$git push

 

 

(六)root用户pull拉取普通用户已修改的最新文件

[root@libin test]# git pull

 

 

(七)查看文件修改记录,并指定恢复到旧版本

# 查看文件历史修改记录

[root@libin test]# git log

 

# 恢复到旧版本

[root@libin test]# git reset --hard 8874f0288797e2ce56825fba13ff134df5b3b8b2

 

 

标签:git,--,repos,使用,test,libin,工具,root
From: https://www.cnblogs.com/libin-linux/p/16817749.html

相关文章

  • 3_ES6中拓展运算符的使用
    一,拓展运算符(...)拓展运算符(...):它会以参数序列的形式输出,更白话讲,比如数组,它可以把数组里面的东西一个一个的输出出来,例如1letarr1=["你","好","V","U","E",1,2]2......
  • 数独辅助工具
    <htmldir="ltr"lang="zh"class="focus-outline-visible"style="background-color:rgb(255,255,255);background-image:unset;t:rgba(0,0,0,1);"><head><......
  • GitHub Pages 和 Jekyll 笔记
    GitHubPages和Jekyll笔记快速创建(使用默认的Jekyll引擎)1.新建仓库新建一个空仓库,名称为username.github.io,其中username就是你的GitHub账号名称2.增加文......
  • ubuntu2004使用bind9配置dns服务器
    使用bind9可以配置的NDS服务器类型有五种:分别为缓冲服务器、主服务器、从服务器、混合服务器以及私密服务器。这次主要试了下主服务器。1.安装bind9 sudoapt-getins......
  • C语言演示多个字符从两端向中间汇聚(Sleep、system函数的简单使用)
    一.问题描述效果图: 二.解题思路我们可以定义两个数组,一个数组存储字符串,一个数组存储‘#’,再来一个循环将两个数组的元素从两端开始进行互换,直至全部换完就得到了完整的字......
  • Windows下使用VSCode配置OpenCV开发环境
    Windows下使用VSCode配置OpenCV开发环境通过使用GitHub上他人编译好的动态库,进行OpenCV环境的配置。目录MinGW安装选择POSIX保留两个MinGW检验是否成功C/CP......
  • 安卓中实现异步任务(2)——使用AsyncTask实现
    安卓中实现异步任务(2)——使用AsyncTask实现问题背景上次的文章大致介绍了几种安卓汇总实现异步任务的方法,讲得比较简要,有朋友问到具体的实现方式,现在开始分列几篇文章详细......
  • 安卓中实现异步任务(3)——使用HandlerThread实现
    #安卓中实现异步任务(3)——使用HandlerThread实现问题背景上篇文章大致介绍了几种安卓汇总实现异步任务的方法,讲得比较简要,有朋友问到具体的实现方式,现在开始分列几篇文章......
  • 数组初步认识和使用
    1.作用:可以同时储存多个数据(就是数据的组合)2.数组的特点a.可以储存多个数据,且只能储存相同类型的数据,有我们定义b.数组中储存的个数是固定的,有我们自己定义。3.如何声明一个......
  • 安卓中实现异步任务(4)——使用线程池实现
    安卓中实现异步任务(4)——使用线程池实现问题背景上篇文章大致介绍了几种安卓汇总实现异步任务的方法,讲得比较简要,有朋友问到具体的实现方式,现在开始分列几篇文章详细介绍......