Centos6下搭建git服务器,并完成git自动部署

搭建git服务器

sever

1.首先安装git

yum install git

2.新建一个linux用户,起名为git

adduser git

3.在git用户目录中新建目录 .ssh

cd /home/git
mkdir .ssh

4.在/home/git/.ssh/目录中新建authorized_keys文件,并将客户端提供的公钥(id_rsa.pub)黏贴到该文件中

vim authorized_keys

5.在项目目录创建一个git裸仓库,假如当前项目目录为/home/git/project.git

git init --bare project.git

6.将项目目录和git用户目录下的.ssh目录的所有者和所属组都设置成git

chown -R git.git project.git  
chown -R git.git /home/git/.ssh/

7.为了安全考虑,禁用git用户的shell登录

vim /etc/passwd
注释 #git:x:500:500::/home/git:/bin/bash 
改为 git:x:500:500::/home/git:/usr/bin/git-shell

8.git服务器打开RSA认证

vim /etc/ssh/sshd_config
下面3个打开
 1.RSAAuthentication yes     
 2.PubkeyAuthentication yes     
 3.AuthorizedKeysFile  .ssh/authorized_keys

client

1.查看公钥

cat ~/.ssh/id_rsa.pub

如果没有的话,可以执行以下命令

ssh-keygen -t rsa

2.在本地新建git仓库

git init

3.新建一个文件并推送到服务器

touch readme.txt
git add readme.txt
git commit -m "readme"
git remote add origin git@xxx.xxx.xxx.xxx:/home/git/project.git
git push origin master

注:如果提示需要密码,请检测公钥是否配置成功或RSA是否开启。

报错信息为ssh: connect to host 104.224.152.22 port 22: Connection refused的时候注意下,sshd服务是否开启(一般都是默认开启的)

sever端解决办法

这个时候,我们要检查sshd服务的端口是否为22

netstat -lnp|grep 22

sshd服务的端口号不为22,我们可以在/etc/ssh/sshd_config修改默认端口

client端解决办法

1.直接修改URL为SSH://开头

git remote set-url origin ssh://git@domain.com:3022/~/Projects/p1.git

2.修改本地配置文件

vim ~/.ssh/config
# 映射一个别名
host newdomain
hostname domain.com
port 3022

git自动部署

添加钩子文件post-receive

#!/bin/bash 
IS_BARE=$(git rev-parse --is-bare-repository) 
if [ -z "$IS_BARE" ]; 
then echo >&2 "fatal: post-receive: IS_NOT_BARE" exit 1 
fi unset GIT_DIR DeployPath="/var/www/blog" #这里写项目实际部署的目录 
cd $DeployPath 
git fetch --all
git reset --hard origin/master

服务器端创建部署项目的文件

cd /var/www
git clone /home/git/project.git 项目名

注:权限问题
在实际使用的时候,会遇到Permission Denied 之类的事情。
那么你要检查下 /var, /var/www, /var/www/your_git 三个目录的权限是否至少开到了 770 上. 然后还要考虑是否有 SELinux 在挡道。
我的处理方式是权限全部开启(因为是个人的服务器,而且也没什么人访问,主要是拿来玩的)

chmod -R 777 /var/www/xxx

还有一个问题,就是push和clone的时候,仓库是最开始创建的空仓库(本文是/home/git/project.git)

最后还有一个问题
Git: push 出错的解决 master -> master (branch is currently checked out)
在使用Git Push代码到数据仓库时,提示如下错误:

[remote rejected] master -> master (branch is currently checked out)
remote: error: refusing to update checked out branch: refs/heads/master
remote: error: By default, updating the current branch in a non-bare repository
remote: error: is denied, because it will make the index and work tree inconsistent
remote: error: with what you pushed, and will require 'git reset --hard' to match
remote: error: the work tree to HEAD.
remote: error:
remote: error: You can set 'receive.denyCurrentBranch' configuration variable to
remote: error: 'ignore' or 'warn' in the remote repository to allow pushing into
remote: error: its current branch; however, this is not recommended unless you
remote: error: arranged to update its work tree to match what you pushed in some
remote: error: other way.
remote: error:
remote: error: To squelch this message and still keep the default behaviour, set
remote: error: 'receive.denyCurrentBranch' configuration variable to 'refuse'.
To git@xxx.xxx.xxx.xxx:/xxx/xxxx/xxxx
 ! [remote rejected] master -> master (branch is currently checked out)
error: failed to push some refs to 'git@xxx.xxx.xxx.xxx:/xxx/xxxx/xxxx'

这是由于git默认拒绝了push操作,需要进行设置,修改.git/config添加如下代码:

git config receive.denyCurrentBranch ignore

参考资料:

Centos搭建GIT服务器---老高的技术博客
利用Git自动部署环境
GIT服务器实现web代码自动部署
Git服务器端代码自动部署

这个人比较懒,什么都没留下

16 声望
2 粉丝
0 条评论
推荐阅读
默克尔树(Merkle Tree)
默克尔树(又叫哈希树)是一种典型的二叉树结构,有一个根节点、一组中间节点和一组叶节点组成。默克尔树最早由 Merkle Ralf 在 1980 年提出,曾广泛用于文件系统和P2P系统中。比如 git、区块链、IPFS 等。

hickey1阅读 4.7k评论 1

封面图
Laravel入门及实践,快速上手ThinkSNS+二次开发
【摘要】自从ThinkSNS+不使用ThinkPHP框架而使用Laravel框架之后,很多人都说技术门槛抬高了,其实你与TS+的距离仅仅只是学习一个新框架而已,所以,我们今天来说说Laravel的入门。

ThinkSNS1阅读 2.5k

C++编译器和链接器的完全指南
C++是一种强类型语言,它的编译和链接是程序开发过程中不可或缺的两个环节。编译器和链接器是两个非常重要的概念。本文将详细介绍C++中的编译器和链接器以及它们的工作原理和使用方法。

小万哥2阅读 1.1k

封面图
confluence7.2.1的部署与迁移---呕心沥血版
Confluence是一个专业的企业知识管理与协同软件,也可以用于构建企业wiki。使用简单,但它强大的编辑和站点管理特征能够帮助团队成员之间共享信息、文档协作、集体讨论,信息推送。 到官网下载最新版本,截止目前...

暗涌阅读 7.9k

Ubuntu 20.04 读写 Windows 10 共享目录(qbit)
本文实验环境中,Windows 操作系统版本为 Windows Server 2016,应该对 Windows 10 和 Windows Server 2019 同样适用

qbit1阅读 6.3k

Ubuntu 20.04 搭建 Elasticsearch 7.x 小集群(qbit)
环境ES 节点硬件:3 台 AWS m5.4xlarge(16 vCPU/64GB 内存)Kibana 硬件:1 台 AWS m5.large(2 vCPU/8GB 内存)操作系统:Ubuntu 20.04 LTSElasticsearch 7.9.3Kibana 7.9.3机器示意图操作系统这里主要讲 EBS ...

qbit阅读 4.2k

ubuntu 常见操作笔记
PHP CLIsudo sed -i 's/display_errors = .*/display_errors = On/' /etc/php/7.4/cli/php.inisudo sed -i 's/error_reporting = .*/error_reporting = E_ALL/' /etc/php/7.4/cli/php.inisudo sed -i 's/memory_l...

zhiqiang1阅读 1.5k

这个人比较懒,什么都没留下

16 声望
2 粉丝
宣传栏