Git环境部署
部署git 服务器环境
- 系统环境准备
192.168.30.25 master git gitlab
192.168.30.26 client git
关闭防火墙
[root@master ~]# iptables -F
[root@master ~]# setenforce 0
[root@master ~]# systemctl stop firewalld
- 使用yum安装git (两台服务器都需要安装)
[root@master ~]# yum -y install git
[root@client ~]# yum -y install git
创建git版本仓库,一般规范的方式要以.git为后缀
[root@master ~]# mkdir linuxprobe.git
[root@master ~]# useradd git
[root@master ~]# passwd git
更改用户 git 的密码 。
新的 密码:
无效的密码: 密码是一个回文
重新输入新的 密码:
passwd:所有的身份验证令牌已经成功更新。
[root@master ~]# chown -Rf git:git linuxprobe.git
初始化版本仓库
[root@master ~]# cd linuxprobe.git/
[root@master linuxprobe.git]# git --bare init
初始化空的 Git 版本库于 /root/linuxprobe.git/
此时Git服务器已经部署好了,但不能向服务器推送数据,也不能克隆Git版本仓库,需要
在服务器上开放至少一种支持Git的协议,比如http/https/ssh等现在用的最多的就是HTTPS和SSH ,本案例中使用的是SSH协议,切换至Git客户机来生成SSH秘钥
[root@client ~]# ssh-keygen //一路回车
+---[RSA 2048]----+
| .=.oo*o. |
| .. X.B.. |
| o oo Xo+ |
| * +.o*oo |
| B S. *o |
| . X o oo |
| o + oE . |
| . .. . |
| oo |
+----[SHA256]-----+
[root@client ~]# ssh-copy-id 192.168.30.25 //将客户机的公钥传递给git服务器
此时就已经可以从Git服务器中克隆版本仓库了(此时目录没有文件是正常的)
[root@client ~]# git clone root@192.168.30.25:/root/linuxprobe.git
正克隆到 'linuxprobe'...
warning: 您似乎克隆了一个空版本库。
配置的是用户名名称和电子邮件地址。每次git提交都会引用这两条信息,记录提交了文件的用户,并且会随更新内容一起呗永久纳入历史记录
[root@client ~]# git config --global user.name "zhan san"
[root@client ~]# git config --global user.email root@linuxprobe.com
设置vim 为默认的文本编辑器
[root@client ~]# git config --global core.editor vim
此时查看git工作环境信息
[root@client ~]# git config --list
user.email=root@linuxprobe.com
user.name=zhan san
core.editor=vim
Git只能追踪类似于txt文件,网页,程序源码等文本文件内容的变化,下面模拟代码提交的过程
[root@client ~]# cd linuxprobe/
[root@client linuxprobe]# echo "Initialization Git repository" > readme.txt
将文件添加到暂存区
[root@client linuxprobe]# git add readme.txt
添加到暂存区后再次修改文件的内容
[root@client linuxprobe]# echo "Something not important" >> readme.txt
将暂存区的文件提交到git版本仓库,命令格式为“git commit -m ”提交说明
[root@client linuxprobe]# git commit -m "add the readme file"
[master(根提交) b4cc72b] add the readme file
1 file changed, 1 insertion(+)
create mode 100644 readme.txt
查看当前工作目录的状态
[root@client linuxprobe]# git status
# 位于分支 master
# 尚未暂存以备提交的变更:
# (使用 "git add <file>..." 更新要提交的内容)
# (使用 "git checkout -- <file>..." 丢弃工作区的改动)
#
# 修改: readme.txt
#
修改尚未加入提交(使用 "git add" 和/或 "git commit -a")
1) 第一次修改提交代码:git 将代码文件提交到本地git版本数据库,此时会在暂存区生产一个快照版本
2) 第二次修改提交代码:当再次修改代码是,需要重新提交到暂存区,此时还会生产一个快照版本
3) 提交代码:只有将暂存区的代码提交到Git版本数据库才能算真正提交
查看当前文件内容与Git版本数据库中的差别
[root@client linuxprobe]# git diff readme.txt
diff --git a/readme.txt b/readme.txt
index cb06697..33d16d0 100644
--- a/readme.txt
+++ b/readme.txt
@@ -1 +1,2 @@
Initialization Git repository
+Something not important
现在把文件提交Git版本数据库吧
[root@client linuxprobe]# git add readme.txt
再来查看下当前git版本仓库的状态
[root@client linuxprobe]# git commit -m "added a line of words"
[master 55930eb] added a line of words
1 file changed, 1 insertion(+)
[root@client linuxprobe]# git status
# 位于分支 master
无文件要提交,干净的工作区
但是这次的操作还是只将文件提交到了本地的git仓库,并没有推送带远程的Git服务器
,所有需要定义远程的git服务器
[root@client linuxprobe]# git remote add server root@192.168.30.25:/root/linuxprobe.git
将文件提交到远程git服务器
[root@client linuxprobe]# git push -u server master
Counting objects: 6, done.
Compressing objects: 100% (3/3), done.
Writing objects: 100% (6/6), 517 bytes | 0 bytes/s, done.
Total 6 (delta 0), reused 0 (delta 0)
To root@192.168.30.25:/root/linuxprobe.git
* [new branch] master -> master
分支 master 设置为跟踪来自 server 的远程分支 master。
为了验证是否推送到了远程的git服务,可以换个目录在克隆一份版本仓库
[root@client linuxprobe]# mkdir test
[root@client linuxprobe]# cd test
[root@client test]# git clone root@192.168.30.25:/root/linuxprobe.git
正克隆到 'linuxprobe'...
remote: Counting objects: 6, done.
remote: Compressing objects: 100% (3/3), done.
remote: Total 6 (delta 0), reused 0 (delta 0)
接收对象中: 100% (6/6), done.
Git环境部署的更多相关文章
- 分布式版本库——Windows下Git的环境部署以及在GitHub上开源自己的项目
分布式版本库--Windows下Git的环境部署以及在GitHub上开源自己的项目 这几天着实忙的焦头烂额,可惜不是搞技术,今天周日,难得闲下来,写篇大家都想学习的Git教程,其实廖雪峰老师的网站已经 ...
- 环境部署(七):linux下Jenkins+Git+JDK持续集成
前面几篇博客介绍了linux下安装Jenkins.Git.JDK以及Git基础教程和Git关联github等内容,这篇博客,介绍下如何在linux服务器中利用它们构建持续集成环境... 一.准备工作 ...
- Visual Studio Git代码管理环境部署
Visual Studio 2010 部署Git代码管理环境. 第一:首先做Git的安装和环境部署 1.下载并安装Git软件,在windows环境下的Git叫做“msysGit”,官网地址为https ...
- Anyconnect的VPN环境部署(2)-在Linux客户机上连接Anyconnect
由于之前已经在机房IDC安装了Anyconnect的VPN服务环境(参考:Anyconnect的VPN环境部署(1)-OpenConnect server(ocserv)服务安装)今天介绍下在linu ...
- FW: Chef集中管理工具实践之 (1) 环境部署
本文转载:http://heylinux.com/archives/2208.html Chef集中管理工具实践之 (1) 环境部署 目录结构Chef集中管理工具实践之 (0) 什么是ChefChef ...
- Git自动部署
Git自动部署文件位于repository下面的hooks里的post-receive #!/bin/sh set -e git-update-server-info gitosis-run-hook ...
- Flume环境部署和配置详解及案例大全
flume是一个分布式.可靠.和高可用的海量日志采集.聚合和传输的系统.支持在日志系统中定制各类数据发送方,用于收集数据;同时,Flume提供对数据进行简单处理,并写到各种数据接受方(比如文本.HDF ...
- NodeJS项目迁移兼Ubuntu下NodeJS环境部署
前言 之前做的几个项目都托管在阿里云服务器,但是最近要到期了.想着到底要不要续期,毕竟100/月.后面看着阿里云有个活动,800/三年.果断买下.环境部署折腾了一天,其中也遇到几个坑. 目录 一.安装 ...
- MIP开发教程(一) MIP-CLI工具安装与环境部署
依赖安装 安装 MIP-CLI 创建开发文件结构 1. 依赖安装 MIP-CLI 使用 NPM 安装,依赖 node 环境: node 安装-windows node 安装-mac MIP-CLI 开 ...
随机推荐
- Android studio 解决setText中文乱码问题
我在用Android Studio编译器的时候,总会遇到非常多乱码的问题.第一个乱码问题是在Layout文件中面定义了EditText.在代码中须要将获取到的内容填充到EditText里面,这时候假设 ...
- bzoj 1022 小约翰的游戏John
题目大意: n堆石子,两个人轮流取石子,每个人取的时候,可以随意选择一堆石子 在这堆石子中取走任意多的石子,但不能一粒石子也不取,取到最后一粒石子的人算输 思路: 首先当每堆石子数都为1时,偶数为先手 ...
- 【POJ 1275】 Cashier Employment
[题目链接] 点击打开链接 [算法] 设Ti为第i小时有多少个出纳员开始工作,Vi表示第i小时有多少个来应聘的出纳员 那么,有 : 1. 0 <= Ti <= Vi 2. Ti + Ti- ...
- PCB CE工具取Genesis JOB与STEP内存地址 方法分享
今天无意中在硬盘上找到了<CE工具取Genesis JOB与STEP内存地址 >视频, 这是2013年初由郭兄(永明)远程时录制的一段视频,特别感谢郭兄指引与帮助, 想当初要不是你推出全行 ...
- C语言内存管理总结
更新: 2018/01/09 增加free() 更新: 2018/04/13 修改部分文字与表格背景色与默认颜色相同 //# TODO: malloc, alloc, calloc, realloc ...
- 关于CSS中float的两点心得以及清除浮动的总结
对一个元素运用float后,该元素将脱离正常文档流,这意味着: 1. 运用float后,该元素不再影响父元素的高度,如果一个元素的所有子元素都是float的话,那么该元素的高度是0,这样后面元素渲染的 ...
- Django day27 认证组件,权限组件()
一:认证组件 1.写一个类 class LoginAuth(): # 函数名一定要叫authenticate,接收必须两个参数,第二个参数是request对象 def authenticate(sel ...
- 大圆那些事 LIBRARY_PATH和LD_LIBRARY_PATH环境变量的区别
LIBRARY_PATH和LD_LIBRARY_PATH环境变量的区别 LIBRARY_PATH和LD_LIBRARY_PATH是Linux下的两个环境变量,二者的含义和作用分别如下: LIBRARY ...
- Coursera公开课-Machine_learing:编程作业2
第三周编程作业:Logistic Regression 代码包在gitlab上:https://gitlab.com/luntai/Machine_Learning
- Lua相关回调总结【转】
原文 http://www.zaojiahua.com/lua-callback-functions.html 最近做一个小项目,是用Lua写的,中间用到了很多的回调,基本Cocos中的那几种常用回调 ...