walle代码发布系统配置
walle
Walle 一个web部署系统工具,配置简单、功能完善、界面流畅、开箱即用! 支持git、svn版本管理,支持各种web代码发布, PHP,Python,JAVA等代码的发布、回滚,可以通过web来一键完成。
walle架构图

walle工作流程

部署walle代码发布系统
环境: 操作系统为centos7.3,并配置好epel源
- 拓扑图

- 配置gitlab服务(可以参考下面这篇博客)
http://www.cnblogs.com/python-gm/p/GitLab.html
- 配置walle服务
# 配置remi源 walle依赖5.4以上的版本php才能运行。
[root@walle ~]# cat /etc/yum.repos.d/remi.repo
[remi]
name=Remi’s RPM repository for Enterprise Linux 7 – $basearch
mirrorlist=http://rpms.remirepo.net/enterprise/6/remi/mirror
enabled=1
gpgcheck=0
[remi-php56]
name=Remi’s PHP 5.6 RPM repository for Enterprise Linux 7 – $basearch
mirrorlist=http://rpms.remirepo.net/enterprise/6/php56/mirror
enabled=1
gpgcheck=0
# 创建用户 以便后面创建nginx用户的密钥
[root@walle ~]# useradd nginx
# 安装软件包
[root@walle ~]# yum -y install nginx php-fpm php-mysql php-mbstring mariadb-server composer
# 修改php-fpm配置文件
[root@walle ~]# sed -i 's/user = apache/user = nginx/' /etc/php-fpm.d/www.conf
[root@walle ~]# sed -i 's/group = apache/group = nginx/' /etc/php-fpm.d/www.conf
# 配置mysql
[root@walle ~]# service mysqld start
[root@walle ~]# mysql -e 'CREATE DATABASE walle'
[root@walle ~]# mysql -e "GRANT ALL ON walle.* TO walle@'localhost' IDENTIFIED BY 'wallepass'"
# 创建网页文件目录
[root@walle ~]# mkdir /data/www -pv
# 下载walle项目源代码
[root@walle ~]# cd /data/www/
[root@walle webdata]# git clone https://github.com/meolu/walle-web.git
# 修改项目文件的属主和属组,
[root@walle webdata]# chown -R nginx.nginx walle-web/
# 设置mysql链接。修改项目目录下的config/local.php中的第12行和第13行
[root@walle webdata]# cd walle-web
[root@walle walle-web]# cat config/local.php
...
'username' => isset($_ENV['WALLE_DB_USER']) ? $_ENV['WALLE_DB_USER'] : 'walle',
'password' => isset($_ENV['WALLE_DB_PASS']) ? $_ENV['WALLE_DB_PASS'] : 'wallepass',
...
# 安装vendor
[root@walle walle-web]$ composer install --prefer-dist --no-dev --optimize-autoloader -vvvv
# 将bower-asset目录改名
[root@walle walle-web]# cd vendor/
[root@walle vendor]# cp -a bower-asset/ bower
# 初始化walle
[root@walle walle-web]# ./yii migrate/up
# 或者
[root@walle walle-web]# ./yii walle/setup # 需要你的yes
# 为nginx提供以下配置,确保/etc/nginx/conf.d/walle.conf配置文件中存在以下内容
server {
listen 8080;
server_name walle.evescn.com; # 改你的host
root /data/www/walle-web/web; # 根目录为web
index index.php index.html;
# 建议放内网
# allow 192.168.0.0/24;
# deny all;
location / {
try_files $uri $uri/ /index.php$is_args$args;
}
location ~ \.php$ {
try_files $uri = 404;
fastcgi_pass 127.0.0.1:9000;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
# 启动nginx
[root@walle ~]# systemctl start nginx
[root@walle ~]# systemctl enable nginx
# 启动php-fpm
[root@walle ~]# systemctl start php-fpm
[root@walle ~]# systemctl enable php-fpm
- 测试。使用浏览器访问http://X.X.X.X。若能出现登录界面则表示walle项目部署成功。管理员账号密码默认都是admin

配置一个walle项目
- 登录进walle系统后,点击页面左上角的项目配置
- 点击搜索栏右侧新建项目,将跳转到页面中的内容修改为下图中的配置。

- 在所有的app服务器上都创建deploy用户,并添加密码。
[root@appN ~]$ useradd deploy [root@appN ~]$ echo "movekj.com" | passwd --stdin deploy
- walle默认是使用scp传输文件到应用服务器上,因此需要在所有的app服务器上安装openssh-clients软件包
[root@appN ~]$ yum -y install openssh-clients
- 在所有的app服务器上创建/walle/release、/webdata目录,并修改其属主和属组为deploy
[root@appN ~]$ mkdir -pv /walle/release /webdata [root@appN ~]$ chown deploy.deploy /walle/release/ /webdata/
- 配置walle服务器。以下步骤在walle服务器上执行
# 创建/walle/deploy目录,并修改其属主和属组 [root@walle ~]$ mkdir -pv /walle/deploy [root@walle ~]$ chown nginx.nginx /walle/deploy/ # 切换到nginx用户。同时为nginx用户生成密钥,并配置无密码使用deploy用户登录app服务器 [nginx@walle ~]$ su - nginx [nginx@walle ~]$ ssh-keygen [nginx@walle ~]$ ssh-copy-id -i ~/.ssh/id_rsa.pub deploy@X.X.X.X [nginx@walle ~]$ ssh-copy-id -i ~/.ssh/id_rsa.pub deploy@X.X.X.X # 将walle主机上nginx用户的公钥添加至gitlab中的deploy keys列表中后,执行以下操作并且保证操作成功以确保后续操作没问题 # 向gitlab的账户中添加nginx用户的公钥以便可以拉取代码 [nginx@walle ~]$ git clone git@X.X.X.X:evescn/python-code.git
- 发起代码一次上线操作
点击页面左侧提交上线单按钮,填写好标题并选择需要上线的分支和版本后点击提交 点击页面左侧我的上线单按钮,找到刚才创建的上线单并确认上线commit号后点击上线再点击部署

浙公网安备 33010602011771号