网站首页 > 知识剖析 正文
1.ssh公钥生成
#查看当前账户
[root@iertf834n89df3ederz ~]# whoami
#切换到nginx用户一定要切换,root生成的公钥不能用
[root@iertf834n89df3ederz ~]# su www
This accout is currently not available.
#如果无法切换
[root@iertf834n89df3ederz ~]# usermode -s /bin/bash www
# 然后就可以切换www用户了
[root@iertf834n89df3ederz ~]# su www
# 进入跟目录,查看是否存在.ssh文件夹,如果木有手动创建一个
[root@iertf834n89df3ederz ~]# cd
[root@iertf834n89df3ederz ~]# cd .ssh
# 生成命令会生成两个文件
[root@iertf834n89df3ederz ~]# ssh-keygen -t rsa -C "gitee邮箱"
id_rsa id_rsa.pub
# 测试
[root@iertf834n89df3ederz ~]# ssh git@gitee.com
# 手动拉取一下
[root@iertf834n89df3ederz ~]# git clone git@gitee.com:wangcb123/api.evmo.cn.git
2.gitee配置公钥
将第一步id_rsa.pub文件全部赋值到公钥输入框,然后点击保存
3.编写php脚本
我这里只让develop分支自动部署可自行修改,composer安装更新不全不知道怎么回事,有大神可以教教。
将下面代码复制到php文件里并保证外网可以访问
$root = '/home/wwwroot/'; //nginx站根目录
$post = json_decode(file_get_contents("php://input"),true);
$dir = $post['root'] ?? ''; //站点目录
if(!$dir) die('not found root');
$ssh_url = $post['project']['ssh_url'];
$branch = explode('/',$post['ref'])[2];
if ($branch != 'develop' || $post['password'] != '123456'){
return false;
}
$path = $root . $dir;
if (is_dir($path)) {
$res = shell_exec("cd {$path} && git checkout {$branch} && git pull 2>&1");
} else {
$res = shell_exec("cd {$root} && git clone {$ssh_url} {$dir} && cd {$dir} && git checkout -b develop origin/develop 2>&1");
}
/*if (file_exists($path.'/composer.json')){
//exec("(sh $path/build.sh >/dev/null & )");
passthru("cd {$path} && (php composer.phar install >/dev/null &)");
}*/
$res .= shell_exec("cd {$path} && chown -R www:www {$path} 2>&1");
/*file_put_contents('./push.log', "[".date('Y-m-d H:i:s')."] ".json_encode([
'path' => $path,
'branch' => $branch,
'ssh_url' => $ssh_url,
'res' => $res
]).PHP_EOL,FILE_APPEND);*/
echo 'success';
4.仓库配置
此时已配置完成自动部署,对个人开发私活比较方便,希望大家共同学习,望哪位大神教教php怎么执行composer 安装命令
猜你喜欢
- 2025-04-30 WordPress使用CDN后显示评论真实IP
- 2025-04-30 webman 事务回滚失效问题记录(事务回滚指令rollback执行的结果是)
- 2025-04-30 如何在WordPress文章分页中添加阅读全文按钮
- 2025-04-30 提权之disable_functions(三)(提权分为哪几个种类)
- 2025-04-30 ThinkPHP后台入口地址查找(thinkphp .htaccess)
- 2025-04-30 Thinkphp3.2.3及以下版本漏洞整理
- 2025-04-30 「某CMS漏洞」SQL注入漏洞分析(sql注入漏洞代码)
- 2025-04-30 php实现一个基本的 MVC 框架(php的mvc设计模式)
- 2025-04-30 PHP漏洞之跨网站请求伪造(php伪造来路跨域跳转)
- 2025-04-30 实现AI API Tokens计费产品方案和技术实现方案设计(PhalApi框架)
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)