centos 安装git服务器,配置使用证书登录并你用hook实现代码自动部署
2017-05-22 21:04
1186 查看
安装git服务器
先安装依赖软件:yum -y install gcc zlib-devel openssl-devel perl cpio expat-devel gettext-devel openssl zlib curl autoconf tk
1、下载最新的git文件:https://www.kernel.org/pub/software/scm/git/git-2.13.0.tar.gz
2、tar xzf git-2.11.1.tar.gz
3、cd git-2.11.1
4、./configure --prefix=/usr/local
5、make && make install
6、git version 查看版本,完工。
配置git证书登录
1.添加个一个git用户
groupadd git
adduser git -g git
passwd git 修改密码
2.拷贝本地公匙文件到服务器
scp /Users/wanghui/.ssh/id_rsa.pub git@118.178.138.113:~/
3.导入公匙到服务器
使用git账号登录,查看/home/git目录下是否有.ssh目录,没有就新建
mkdir ~/.ssh
chmod 700 ~/.ssh
touch .ssh/authorized_keys
chmod 600 .ssh/authorized_keys
将刚才上传到服务端的id_rsa.pub文件中的内容添加到目录/.ssh/authorized_keys中, 删除刚才上传到服务端的的id_rsa.pub
cat ~/id_rsa.pub >> ~/.ssh/authorized_keys
rm ~/id_rsa.pub
然后就可以使用证书登录了
如果以上步骤不能实现不输密码登陆的话,需要检查sshd服务的Pubkey认证功能是否默认打开
修改/etc/ssh/sshd_config, 改以下条目
PubkeyAuthentication yes 修改后需要重启ssh service sshd restart
创建仓库
cd /home
mkdir gitrepos
cd gitrepo
git init --bare test.git
记得把仓库所属用户改为git chown -R git:git test.git
git clone git@ip地址:test.git的绝对路径 拉取
网上很多说需要禁止git用户shell登录,发现操作后证书也就无法访问了,所以一定不要禁用这个。
正确的应该是git:x:1001:1001:,,,:/home/git:/bin/bash这样
你用hook钩子自动部署代码
1.进入到项目下的hooks目录 cd /home/git/test.git/hooks/
2.添加post-receive文件然后编辑 vim post-receive 插入以下代码
3.给钩子可执行权限和所属用户和用户组
4.给git用户生成ssh证书并加入到git的authorized_keys
5.需要项目目录777权限,如果提示error: cannot open .git/FETCH_HEAD: Permission denied错误,需要设置项目下.git/FETCH_HEAD文件用户和用户组为git
先安装依赖软件:yum -y install gcc zlib-devel openssl-devel perl cpio expat-devel gettext-devel openssl zlib curl autoconf tk
1、下载最新的git文件:https://www.kernel.org/pub/software/scm/git/git-2.13.0.tar.gz
2、tar xzf git-2.11.1.tar.gz
3、cd git-2.11.1
4、./configure --prefix=/usr/local
5、make && make install
6、git version 查看版本,完工。
配置git证书登录
1.添加个一个git用户
groupadd git
adduser git -g git
passwd git 修改密码
2.拷贝本地公匙文件到服务器
scp /Users/wanghui/.ssh/id_rsa.pub git@118.178.138.113:~/
3.导入公匙到服务器
使用git账号登录,查看/home/git目录下是否有.ssh目录,没有就新建
mkdir ~/.ssh
chmod 700 ~/.ssh
touch .ssh/authorized_keys
chmod 600 .ssh/authorized_keys
将刚才上传到服务端的id_rsa.pub文件中的内容添加到目录/.ssh/authorized_keys中, 删除刚才上传到服务端的的id_rsa.pub
cat ~/id_rsa.pub >> ~/.ssh/authorized_keys
rm ~/id_rsa.pub
然后就可以使用证书登录了
如果以上步骤不能实现不输密码登陆的话,需要检查sshd服务的Pubkey认证功能是否默认打开
修改/etc/ssh/sshd_config, 改以下条目
PubkeyAuthentication yes 修改后需要重启ssh service sshd restart
创建仓库
cd /home
mkdir gitrepos
cd gitrepo
git init --bare test.git
记得把仓库所属用户改为git chown -R git:git test.git
git clone git@ip地址:test.git的绝对路径 拉取
网上很多说需要禁止git用户shell登录,发现操作后证书也就无法访问了,所以一定不要禁用这个。
正确的应该是git:x:1001:1001:,,,:/home/git:/bin/bash这样
你用hook钩子自动部署代码
1.进入到项目下的hooks目录 cd /home/git/test.git/hooks/
2.添加post-receive文件然后编辑 vim post-receive 插入以下代码
#!/bin/sh unset GIT_DIR NowPath=`pwd` DeployPath="/data0/web/www/" cd $DeployPath git pull origin master cd $NowPath exit 0
3.给钩子可执行权限和所属用户和用户组
chmod +x post-receive chown git:git post-receive
4.给git用户生成ssh证书并加入到git的authorized_keys
5.需要项目目录777权限,如果提示error: cannot open .git/FETCH_HEAD: Permission denied错误,需要设置项目下.git/FETCH_HEAD文件用户和用户组为git
相关文章推荐
- 使用Git的hook实现代码的自动部署
- CentOS利用WebHook实现PHP自动部署Git代码
- 搭建内部开发git服务器并使用hook实现自动部署
- (git)Bitbucket使用WebHook实现自动部署PHP代码
- GIT服务器实现web代码自动部署
- 使用 Git Hook 实现网站的自动部署
- git hook实现代码自动部署
- jenkins安装与配置maven+git\svn+ssh实现远程自动部署
- **使用 Git Hook 实现网站的自动部署
- Linux CentOS SVN 设置钩子hooks/post-commit来同步更新服务器web目录,实现代码自动部署
- git实现代码提交自动部署到相应的web服务器
- 利用WebHook实现PHP自动部署Git代码
- 使用 Git Hook 实现网站的自动部署
- GIT服务器实现web代码自动部署
- git码云配置web hook钩子实现自动部署,git权限等问题,LAMP
- git的安装使用和代码自动部署
- GitHook+JGit实现最新代码的自动克隆或者项目的自动部署
- Jenkins进阶-Gitlab使用Webhook实现Push代码自动部署(3)
- GIT服务器实现web代码自动部署
- gitblit git SERVER window 安装配置 hook post-receive 自动部署