记录自己在centos虚拟机搭建简易git服务器的过程,分享给大家

折月煮酒 提交于 2019-12-04 12:57:41

心血来潮,想自己搭建一个git开发环境, 奈何linux小白, git小白, 只好搜索网上资源,整理到一起。

完成之后,发现自己的知识贫乏至极, 继续努力学习才是王道。


我的真机安装的是Windows 8专业版。

在vmware上安装了centos6.3-64位,  作为服务器, 选用的live cd版本,ISO文件相比binDVD版本小一点。

1.服务器部分:

1.1 更换yum源

cd /etc/yum.repos.d 进入yum源配置目录

mv CentOS-Base.repo CentOS-Base.repo.bk 备份系统自带的yum源

wget http://mirrors.163.com/.help/CentOS-Base-163.repo 下载163网易的yum源

mv CentOS-Base-163.repo CentOS-Base.repo 覆盖系统自带yum源

yum makecache 使配置立即生效

1.2 安装git

yum install -y git

安装完毕后, 运行检查版本的命令: git --version, 若出现

git version 1.7.1 GIT

安装完毕。

可惜git版本够老, 对yum如何去获取最新版本的软件,完全不懂。

虽然对版本差异不懂, 但还是希望可以使用现在最新的2.0.0版本。 

于是遵从网上的方法饶了点弯路。

1). 从githubclone下来git的源码: git clone https://github.com/git/git

2). 安装git前准备(安装需依赖的包):
yum install curl -y
yum install curl-devel -y
yum install zlib-devel -y
yum install openssl -y
yum install perl -y
yum install cpio -y
yum install expat-devl -y
yum install gettext-devl -y
yum installperl-devel.i686 -y
yum install -y libpcap.x86_64
yum install -y libpcap-devel.x86_64
yum install -y perl-devel.x86_64
3). 编译安装
autoconfig
./configure
make
make install

4). 安装完毕后, 运行检查版本的命令: git --version, 若出现

git version 2.0.0 GIT

git安装完毕

1,3 搭建简易git服务器

1). 关闭selinux

vi /etc/selinux/config

修改SELINUX=Enabled为SELINUX=Disabled

2). 创建git裸版本库

cd /repo/ repo文件夹下放各种各样的项目的git版本库

git init bare my.git  建立一个全新得版本仓库,注意这里不是工作目录,我理解的是这里保存的是当前project的全局信息。

3). 版本库用户管理

groupadd git 增加名为git的组,专门为git服务

useradd -pxxx -g git gitowner 增加一个普通用户名为gitowner,这个用户可以不是开发者一员。

chown -R gitowner /repo/ 递归地把/repo/目录下所有文件的属主改为gitowner(参数-R 代表递归目录下所有文件或目录)

chgrp -R git /repo/ 递归地把/repo/目录下所有文件的属组改为git

chmod 770 -R /repo 仅允许git组内成员对repo文件夹进行操作  

4). 生成密钥对

$ cd ~ 

$ ssh-keygen -t rsa

$ chmod 700 ~/.ssh

$ cat id_rsa.pub >> ~/.ssh/authorized_keys

$ chmod 600 ~/.ssh/authorized_keys

5). centos打开SSH连接(以下方式有些不安全=。=, 继续研究中)

vi /etc/ssh/sshd_config 打开ssh配置文件

RSAAuthentication yes 开启RSS验证

PubkeyAuthentication yes 开启公钥验证???

AuthorizedKeysFile     .ssh/authorized_keys  这个文件就是我们之前生成ssh key的地方

找到#Port 22, 去掉‘#’注释, 指定SSH连接的端口号,安全方面不建议使用默认22端口why?

Protocol 2,1 允许SSH1和SSH2连接,建议设置成 Protocal 2

vi /etc/ssh/hosts.allow 

在最后面添加一行:sshd: All, 应该是允许所有连接的意思。

以上配置完毕后,输入以下命令启动或重启ssh服务

/etc/init.d/sshd start/restart

6). centos关闭防火墙(可选)

方法一:完全关闭防火墙。

使用setup命令启动文字模式配置实用程序,在”选择一种工具”中选择”防火墙配置”,然后选择”运行工具”按钮,出现防火墙配置界面,将”安全级别”设为”禁用”,然后选择”确定”即可。

方法二:关闭防火墙对80,22端口的保护

#/sbin/iptables -I INPUT -p tcp –dport 80 -j ACCEPT
#/sbin/iptables -I INPUT -p tcp –dport 22 -j ACCEPT
#/etc/rc.d/init.d/iptables save

#/etc/init.d/iptables restart 重启防火墙

2.Windows客户端部分:

2.1 先安装git for windows,再安装totorisegit.

2.2 将服务器上~/.ssh/id_rsa私钥文件复制到客户端

2.3 启动puttygen, load刚才从服务器上复制的id_rsa私钥文件, 如下:


生成完毕后, 点击Save private key保存转换格式后的私钥,如下图。


tortoisegit

设置程序中配置远程主机

2.4 在totorisegit中配置远程主机


2.5 在本地建立版本库后,可以尝试用pull命令拉取文件。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!