linux上 搭建http服务 作为git服务端

本文详细介绍如何在服务器上安装并配置HTTP服务和Git服务,实现通过HTTP协议访问Git仓库,包括修改端口、设置用户权限、配置虚拟主机等关键步骤。

项目上使用git服务作为配置中心,为了方便要在服务器上搭建http服务,作为git服务的代理
一、安装httpd
执行命令

yum install httpd -y

完成安装,启动httpd服务

systemctl  start  httpd.service

查看httpd状态

service httpd status

服务启动成功,结果如下;
在这里插入图片描述
也可以通过浏览器访问,ip:80(服务默认端口),正常结果如下
在这里插入图片描述
这里为了防止80端口占用冲突,在/etc/httpd/conf/httpd.conf中修改为8091。这里可能因为selinux导致修改端口后http服务启动失败,这里可命令临时关闭
执行

sudo setenforce 0

查看状态

getenforce

状态变为 Permissive

此命令临时关闭 selinux 重启失效
二、安装git服务
执行安装命令

yum install git  -y
yum install git-core  -y

安装完成,可使用命令查看git 版本

git --version

在这里插入图片描述
创建git服务端仓库

#创建仓库目录
mkdir -p  /home/http_git/test.git
#进入目录
cd /home/http_git/test.git
#初始化仓库
git init --bare
#设置目录所属用户/组
chown -R apache:apache /home/http_git

创建账号

//#testuser为账户名 可以随意定义,后续需要输入密码
htpasswd -m -c /etc/httpd/conf.d/git-team.htpasswd testuser

# 修改git-team.htpasswd文件的所有者与所属群组
chown apache:apache /etc/httpd/conf.d/git-team.htpasswd

#设置git-team.htpasswd文件的访问权限
chmod 640 /etc/httpd/conf.d/git-team.htpasswd

接下来需要修改httpd服务,使得请求可以转发到git仓库

vim /etc/httpd/conf/httpd.conf

在文件末尾添加

<VirtualHost *:8091>
        ServerName 172.31.100.48
        SetEnv GIT_HTTP_EXPORT_ALL
        SetEnv GIT_PROJECT_ROOT /home/http_git
        ScriptAlias /git/ /usr/libexec/git-core/git-http-backend/
        <Location />
                AuthType Basic
                AuthName "Git"
                AuthUserFile /etc/httpd/conf.d/git-team.htpasswd
                Require valid-user
        </Location>

</VirtualHost>

其中VirtualHost 配置服务端口
ServerName 服务器ip
GIT_PROJECT_ROOT 仓库路径
ScriptAlias是将以/git/开头的访问路径映射至git的CGI程序git-http-backend
AuthUserFile是验证用户帐户的文件
保存修改后 重启httpd服务

systemctl  restart httpd.service

验证git服务端仓库是否可用,在任一文件下执行

git clone http://ip:8091/git/test.git

克隆仓库中的test.git项目到本地。这里会提示输入用户和密码(前面设置的用户testuser,密码为自己输入的)即可在当前路径下产生test项目文件夹,当然 目前是空的。
至此已经成功搭建http服务的git服务器。接下来就可以通过git命令进行文件的同步管理了。

### 三级标题:安装 GitLinux 系统上搭建 Git 服务端的第一步是安装 Git。可以通过包管理器(如 `yum` 或 `apt`)安装 Git。以基于 `yum` 的系统(如 CentOS 或 RHEL)为例: ```bash # 安装 Git sudo yum install -y git # 查看 Git 版本以确认安装是否成功 git --version ``` 如果系统需要多个用户管理 Git 服务,则可以创建一个专用的 `git` 用户[^4]。 ### 三级标题:创建 Git 用户 创建一个专用的 `git` 用户可以增强系统的安全性,确保 Git 服务由独立的用户管理: ```bash # 添加 git 用户 sudo useradd git # 给 git 用户设置密码 sudo passwd git ``` 完成设置后,切换到 `git` 用户并继续后续操作: ```bash # 切换到 git 用户 su - git ``` ### 三级标题:初始化 Git 仓库 在服务器上创建一个目录用于存放 Git 仓库,并初始化一个裸仓库(bare repository),这是 Git 服务器的标准做法: ```bash # 创建仓库目录 mkdir -p /home/git/repositories # 进入仓库目录 cd /home/git/repositories # 初始化裸仓库 git init --bare example.git ``` ### 三级标题:配置 SSH 访问 为了确保客户端可以通过 SSH 协议访问 Git 仓库,需要配置 SSH 公钥认证: 1. 在客户端生成 SSH 密钥对(如果尚未生成): ```bash ssh-keygen -t rsa -b 4096 ``` 2. 将客户端的公钥文件(通常是 `~/.ssh/id_rsa.pub`)内容添加到服务器端的 `~/.ssh/authorized_keys` 文件中。 3. 确保 `.ssh` 目录和 `authorized_keys` 文件的权限正确: ```bash chmod 700 ~/.ssh chmod 600 ~/.ssh/authorized_keys ``` ### 三级标题:限制 Git 用户的 Shell 访问 为了进一步增强安全性,可以限制 `git` 用户仅能使用 Git 命令,而不能登录系统 shell。这可以通过修改 `/etc/passwd` 文件实现: ```bash # 修改 git 用户的 shell sudo usermod -s /usr/bin/git-shell git ``` 确保 `/etc/passwd` 文件中 `git` 用户的行如下所示: ``` git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell ``` ### 三级标题:客户端克隆仓库 客户端可以通过 SSH 协议克隆远程仓库: ```bash # 克隆远程仓库 git clone git@your_server_ip:/home/git/repositories/example.git ``` ### 三级标题:相关问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值