http://www.walle-web.io/docs/ 瓦力官網
php
Walle 一個web部署系統工具,配置簡單、功能完善、界面流暢、開箱即用!支持git、svn版本管理,支持各類web代碼發佈,PHP,Python,JAVA等代碼的發佈、回滾,能夠經過web來一鍵完成。html
用戶分身份註冊、登陸java
開發者發起上線任務申請、部署mysql
管理者審覈上線任務jquery
支持多項目部署linux
支持多項目多任務並行nginx
快速回滾git
項目的用戶權限管理github
部署前準備任務pre-deploy(前置檢查)web
代碼檢出後處理任務post-deploy(如vendor)
同步後更新軟鏈前置任務pre-release
發佈完畢後收尾任務post-release(如重啓)
執行sql構建(不要擔憂忘記測試環境sql同步)
線上文件指紋確認
支持git、svn版本管理
宿主機、目標機羣、操做用戶關係以下圖所示,宿主機(walle所在的機器),是一箇中間機器,是代碼託管與遠程目標機羣的紐帶。
因此宿主機須要與代碼託管(github/gitlab)和遠程目標機羣都創建ssh-key信任。
Bash(git、ssh)
意味着不支持win、mac的zsh
LNMP/LAMP(php5.4+)
php須要開啓pdo_mysql,exec函數執行
Composer
若是國內環境安裝極慢,能夠直接下載vendor解壓到項目根目錄
ansible
一、宿主機安裝 ansible
yum install ansible # RHEL/CentOS/Fedora |
二、宿主機無需其餘配置,兼容 ~/.ssh/config 名稱、證書配置
三、目標機無需額外配置
項目配置 中 開啓Ansible
(可選) config/params.php 配置 ansible_hosts 文件存放路徑
按正常流程發佈、上線代碼,傳輸文件、遠程執行命令均會經過ansible併發執行
刪除老的安裝包
remove php.x86_64 php-cli.x86_64 php-common.x86_64 php-gd.x86_64 php-ldap.x86_64 php-mbstring.x86_64 php-mcrypt.x86_64 php-mysql.x86_64 php-pdo.x86_64```
CentOs 6.x
rpm -Uvh http://mirror.webtatic.com/yum/el6/latest.rpm
CentOs 7.X
rpm -Uvh https://mirror.webtatic.com/yum/el7/epel-release.rpm
|
安裝php-fpm 5.6
yum install php56w-fpm
git clone git@github.com:meolu/walle-web.git |
如下安裝,均在宿主機(一臺配置了LAMP/LNMP的linux機器,而且安裝git/svn)上操做,若有問題,詳見Q&A。
若是尚未安裝php 5.4+環境的,請先安裝php5.4+,詳情看php 5.6安裝。
mkdir -p /data/www/walle-web && cd /data/www/walle-web # 新建目錄 |
vi config/local.php +14 |
curl -sS https://getcomposer.org/installer | php |
cd walle-web |
安裝速度慢或失敗,可直接下載vendor解壓到項目根目錄
cd walle-web |
凡是在第7步刷新頁面看到50x均是前5步安裝不完整,自行檢查
凡是在第7步刷新頁面看到404均是nginx配置不當,自行檢查
nginx簡單配置
server { |
訪問地址:localhost
固然,可能你配置nginx時的server_name是walle.company.com時,配置本地hosts以後,直接訪問:walle.company.com亦可。
好吧,我已經猜到會有人問有沒有現成的,有! 下載百度網盤,解壓vendor放到walle-web根目錄便可。
Could not fetch https://api.github.com/repos/jquery/jquery, please create a GitHub OAuth token to go over the API rate limit
Head to https://github.com/settings/tokens/new?scopes=repo&description=Composer+on+localhost+2015-10-08+1123
to retrieve a token. It will be stored in 「/root/.composer/auth.json」 for future use by Composer.
Token (hidden):
解決辦法:
複製提示裏的地址到瀏覽器,點擊生成git token,如上面的:https://github.com/settings/tokens/new?scopes=repo&description=Composer+on+localhost+2015-10-08+1123
複製token到命令行,認證,繼續
Loading composer repositories with package information
Installing dependencies (including require-dev)
Your requirements could not be resolved to an installable set of packages.Problem 1
yiisoft/yii2 2.0.x-dev requires bower-asset/jquery 2.1.@stable | 1.11.@stable -> no matching package found.
….
解決辦法:composer global require "fxp/composer-asset-plugin:*"
su - www # 假如www爲你的php進程用戶 |
宿主機操做
ps aux|grep php # 假如www_php爲你的php進程用戶 |
缺乏pdo擴展,解決辦法:添加pdo擴展
ubuntu |
server { |
cat /etc/passwd | grep www # 查看是否爲 /sbin/nolgin |
解決辦法:
vipw /etc/passwd 修改/sbin/nolgin爲/bin/bash |
The file or directory to be published does not exists: /data/www/walle-web/vendor/bower/jquery/dist
新建此目錄便可:/data/www/walle-web/vendor/bower/jquery/dist
缺乏mbstring擴展,安裝mbstring擴展重啓php便可。mbstring擴展:http://php.net/manual/zh/mbstring.installation.php
git部署是最推薦的方式,它不管對於何種語言都是合適的。
宿主機php進程用戶www_php(假如,可經過配置的檢測查看或ps aux|grep php)的ssh-key要加入git/gitlab的deploy-keys。固然也能夠http地址帶用戶名密碼(不推薦):https://username:password@github.com/meolu/walle-web.git
宿主機php進程用戶www_php(假如,可經過配置的檢測查看或ps aux|grep php)要加入目標機羣部署用戶www_remote(配置中)ssh-key信任,具體怎麼添加可找sa或者百度或者,這通常是用戶最不理解的地方,建議先花半小時理解linux用戶概念和php配置。
配置完畢以後,先檢測下,如無問題則能夠發起上線單了:)
宿主機代碼檢出檢測出錯,請確認php進程用戶{user}有代碼存儲倉庫{path}讀寫權限,且把ssh-key加入git的deploy-keys列表。詳細錯誤:{error}
問題:請確認php進程用戶{user}有代碼存儲倉庫{path}讀寫權限
沒有權限,是由於用戶{user}對目錄{path}沒有讀寫權限,給權限便可 |
問題:把ssh-key加入git的deploy-keys列表
su {user} && cat ~/.ssh/id_rsa.pub |
可能的緣由之一是clone git代碼的時候,須要手工確認: git clone git@gitlab.xxx.com:yyy/zzz.git
目標機器部署出錯,請確認php進程{local_user}用戶ssh-key加入目標機器的{remote_user}用戶ssh-key信任列表,且{remote_user}有目標機器發佈版本庫{path}寫入權限。詳細錯誤:{error}
問題:請確認php進程{local_user}用戶ssh-key加入目標機器的{remote_user}用戶ssh-key信任列表
添加機器信任,仍是沒理解請百度吧(由於太多的同窗問這問題,實在沒辦法只能這麼囉嗦) |
問題:{remote_user}有目標機器發佈版本庫{path}寫入權限
su remote_user |
svn部署上線與git有點不太同樣,svn是推薦增量發佈(固然也能夠全量更新),在開發者提交文件列表(可能帶版本號),管理員審覈上線單。發起部署時,爲該上線單開闢一個獨立空間,檢出代碼,選擇上線單中的文件(可能帶版本號)同步到目標機羣。有不瞭解宿主機和目標機羣關係、上線流程的同窗先到項目主頁瞭解。
由於svn沒有git的版本快照,因此在部署須要全量代碼編譯操做時,只能選擇全量更新,此時要求發佈的分支/tag/trunk是可發佈狀態。建議java + git組合。同理其它須要全量代碼在宿主機作編譯相關的操做的語言,且爲svn版本管理,請慎用。
svn目錄推薦如下規範,詳細能夠註冊riouxsvn,做爲svn測試地址。固然三無(無trunk、無branches、無tags)也是支持:)
branches
tags
trunk
宿主機php進程用戶www_php(假如,可經過配置的檢測查看或ps aux|grep php)要加入目標機羣部署用戶www_remote(配置中)ssh-key信任,具體怎麼添加可找sa或者百度或者,這通常是用戶最不理解的地方,建議先花半小時理解linux用戶概念和php配置。
配置完畢以後,先檢測下,如無問題則能夠發起上線單了:)
宿主機代碼檢出檢測出錯,請確認php進程用戶{user}有代碼存儲倉庫{path}讀寫權限。詳細錯誤:{error}
沒有權限,是由於用戶{user}對目錄{path}沒有讀寫權限,給權限便可 |
目標機器部署出錯,請確認php進程{local_user}用戶ssh-key加入目標機器的{remote_user}用戶ssh-key信任列表,且{remote_user}有目標機器發佈版本庫{path}寫入權限。詳細錯誤:{error}
問題:請確認php進程{local_user}用戶ssh-key加入目標機器的{remote_user}用戶ssh-key信任列表
添加機器信任,仍是沒理解請百度吧(由於太多的同窗問這問題,實在沒辦法只能這麼囉嗦) |
問題:{remote_user}有目標機器發佈版本庫{path}寫入權限
su remote_user |
高級任務方便用戶自定義一些操做,不管是在代碼檢出先後,仍是切換版本先後。
pre_deploy任務
echo pre_deploy >> /tmp/cmd # 初始化一些東西,自由發揮 |
post_deploy任務
mvn package -Dmaven.test.skip=true # 編譯java |
pre_release任務
./xx.sh stop # 暫停服務 |
post_release任務
./xx.sh start # 啓動服務 |
sudo
命令?想執行sudo
命令的前提是用戶有root權限,要執行哪些命令?
添加用戶到sudoers
visudo |
添加免密碼命令
visudo |
設置用戶的tty(宿主機執行sudo須要此步,目標機能夠跳過此步)
Defaults:www !requiretty |
角色分爲管理員(註冊可選)、開發者(註冊可選)、項目審覈管理員(前面兩者都可是)。
註冊時,選擇角色爲管理員,註冊後郵件驗證,但此時也不是馬上擁有管理員權限,須要其它管理員審覈經過才行。
管理員的權限列表
配置新的項目、修改本身的項目配置
審覈新管理員
設置項目的成員、項目審覈管理員
審覈上線單
上線
註冊時無此用戶角色,爲管理員爲減輕本身審覈上線單壓力、防止管理員不在線而影響上線而須要一兩個代理審覈管理員。但不能編輯項目配置,也不能添加項目成員,只比開發者多一個審覈上線單的權限。
管理員的權限列表
審覈上線單
上線
普通開發者可提交上線單,上線部署
管理員的權限列表
宿主機代碼檢出檢測出錯,請確認php進程用戶{user}有代碼存儲倉庫{path}讀寫權限,且把ssh-key加入git的deploy-keys列表。詳細錯誤:{error}
問題:請確認php進程用戶{user}有代碼存儲倉庫{path}讀寫權限
沒有權限,是由於用戶{user}對目錄{path}沒有讀寫權限,給權限便可 |
問題:把ssh-key加入git的deploy-keys列表
su {user} && cat ~/.ssh/id_rsa.pub |
目標機器部署出錯,請確認php進程{local_user}用戶ssh-key加入目標機器的{remote_user}用戶ssh-key信任列表,且{remote_user}有目標機器發佈版本庫{path}寫入權限。詳細錯誤:{error}
問題:請確認php進程{local_user}用戶ssh-key加入目標機器的{remote_user}用戶ssh-key信任列表
添加機器信任,仍是沒理解請百度吧(由於太多的同窗問這問題,實在沒辦法只能這麼囉嗦) |
問題:{remote_user}有目標機器發佈版本庫{path}寫入權限
su remote_user |
上線單包括兩種方式:git和svn
svn上線單與git相似,但有些區別,會有全量上線和增量上線兩種主要形式,增量上線支持指定文件的版本號。分別看下能夠有哪些格式填寫上線單:
上線全量文件
* |
增量上線指定文件
file_name1 |
增量上線指定文件的指定版本
file_name1 commit_id |
mv -fT
緣由分析:更新目標機羣是以軟鏈方式來更新webroot,若是提早在目標機羣建立了webroot目錄,軟鏈覆蓋將會失敗。
解決辦法:直接刪除目標機羣webroot目錄,肯定其父目錄有讀寫的權限便可,由瓦力系統生成webroot軟連接。
有些錯誤walle捕捉不到,默認操做日誌在/tmp/walle/
下,具體可在config/local.php
裏log.dir
配置路徑,tail
着日誌,部署看日誌。
/tmp/walle
下無日誌文件緣由centos 7 yum 安裝的php-fpm默認/tmp
目錄不可寫:/usr/lib/systemd/system/php-fpm.service
中的 PrivateTmp=true
禁止了向tmp目錄寫日誌
解決:
vi /usr/lib/systemd/system/php-fpm.service
PrivateTmp=false
systemctl daemon-reload
systemctl reload php-fpm
致此瓦力已經部署成功!若有任何問題可聯繫博主或者登陸官網查看詳情。