centos 安装git服务器,配置使用证书登录并你用hook实现代码自动部署
安装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
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
使用webhooks自动更新代码
很多时候我们代码托管在github或其他地方,更新代码时每次都需要去服务器上git pull,很不方便,这时候我们就可以使用webhooks来更新代码
1、创建一个文件webhooks.php,这个文件需要能url访问http://test.com/webhooks.php
2、在文件里面加入以下代码
<?php
// 获取push数据内容的方法
#$requestBody = file_get_contents("php://input");
//echo exec("id -a");//查看web运行的用户
// 只需这一行代码便可拉取,使用 2>&1,命令就会输出shell执行时的错误到$log变量, 输出该变量即可分析。
exec('cd /home/wwwroot/test/ && git pull 2>&1',$log,$status);
//print_r($log);
?>
3、切换到web运行账号su www,生成ssh key,把key加入到git管理,然后git clone 拉取代码。(切记不能使用root等其他账号拉取代码)
提示www This account is currently not available.解决办法
more /etc/passwd查看账号信息,发现www的shell是“/sbin/nologin”,所以需要将起改成“/bin/bash”
访问http://test.com/webhooks.php 查看能否运行成功,成功后把地址放到github的webhooks就可以了
centos 安装git服务器,配置使用证书登录并你用hook实现代码自动部署的更多相关文章
- CentOS安装Git服务器
1.安装Git $ yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel perl-devel $ yum ...
- Centos安装git并配置ssh
1.下载git安装包 git-2.9.4.tar.gz 2.解压 tar -xzvf git-2.9.4.tar.gz 3.修改解压后的文件名 mv git-2.9.4 git 4.安装git依赖的库 ...
- centos安装nginx并配置SSL证书
安装nginx的命令 sudo yum install epel-release sudo yum install nginx 让nginx随系统启动而启动 sudo systemctl enable ...
- CentOS安装Git服务器 Centos 6.5 + Git 1.7.1.0 + gitosis
1.安装扩展 yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel perl-devel 2.下载git ...
- CentOS_6.5 64位系统,安装git服务器+客户端
================ git服务器安装 ==================== CentOS安装Git服务器 Centos 6.4 + Git 1.8.2.2 + gitosis## . ...
- 自定义Git之使用centos搭建git 服务器
Github 公开的项目是免费的,但是如果你不想让其他人看到你的项目就需要收费. 这时我们就需要自己搭建一台Git服务器作为私有仓库使用. 接下来我们将以 Centos 为例搭建 Git 服务器. 1 ...
- CentOS搭建Git服务器及权限管理
声明:本教程,仅作为配置的记录,细节不展开,需要您有一点linux的命令基础,仅作为配置参考. 1. 系统环境 系统: Linux:CentOS 7.2 64位 由于CentOS已经内置了OpenSS ...
- CentOS7 安装git服务器
在CentOS7系统中安装git服务器有两种方法,分别为yum安装和下载git安装包手动安装,这篇文章只有下载git安装包手动安装方法. 方法一:使用yum安装 暂无 方法二:下载git安装包手动安装 ...
- CentOS7 安装 Git 服务器
1.安装Git $ yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel perl-devel $ yum ...
随机推荐
- centos 安装npm node
最近那vue全套造了个管理系统的轮子,发现node简直太好用了. elment-UI的出现就是不懂ui设计的后台工程师的福音~ 正好自己买的两个云服务器空闲着没用,就拿来试试看了 首先软件都安装在/u ...
- Python 编程快速上手 第九章 组织文件
上一章节,主要讲了如何用 Python 进行创建并写入新文件.这一章节,讲了对如何用 Python 对文件进行进一步的操作,包括: 移动,复制,删除文件 改名 压缩文件 [shutil]移动,复制,删 ...
- every day a practice —— morning(5)
Huawei has not been accused of wrongdoing. As an administrative subpoena, the Treasury document does ...
- 正睿 2018 提高组十连测 Day4 T3 碳
记'1'为+1,'0'为-1; 可以发现 pre[i],suf[i]分别为前/后缀和 a[i]=max(pre[l.....i]); b[i]=max(suf[i+1....r]); ans=max( ...
- 【洛谷p2669】【一本通p1100】金币
(今天高产) 金币[传送门] 洛谷上的算法标签 自我感觉主要靠循环 这道题是2015年NOIp普及组的题,其实还是很简单的.但为什么写这道题呢? 这道题第一次接触是在一本通刷题的时候,当时学循环结构, ...
- Pandas读取文件
如何使用pandas的read_csv模块以及其他读取文件的模块?? 一起来看一看 Pandas中read_csv和read_table的区别 注:使用pandas读取文件格式为pandas特有的da ...
- 20165309 实验二 Java面向对象程序设计
2017-2018-2 20165309实验二<Java面向对象程序设计>实验报告 一.实验内容 1. 初步掌握单元测试和TDD 2. 理解并掌握面向对象三要素:封装.继承.多态 3. 初 ...
- tornado 异步
引言 注:正文中引用的 Tornado 代码除特别说明外,都默认引用自 Tornado 4.0.1. tornado.gen 模块是一个基于 python generator 实现的异步编程接口.通过 ...
- python-爬虫-selenium模块
一 介绍 selenium最初是一个自动化测试工具,而爬虫中使用它主要是为了解决requests无法直接执行JavaScript代码的问题 selenium本质是通过驱动浏览器,完全模拟浏览器的操作, ...
- Oracle11g温习-第十八章:role管理
2013年4月27日 星期六 10:52 role 的功能:简化用户的权限管理 建立角色——给角色授权——将角色授予用户/角色 2.查看系统建立的role SYS @ prod > selec ...