Walle 瓦力 安裝部署

Walle 瓦力 安裝部署

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

apt-get install ansible # Debian/Ubuntu

emerge -avt ansible  # Gentoo/Funtoo

pip install ansible # will also install  paramiko PyYAML jinja2

二、宿主機無需其餘配置,兼容 ~/.ssh/config 名稱、證書配置

三、目標機無需額外配置

walle

  1. 項目配置 中 開啓Ansible

  2. (可選) config/params.php 配置 ansible_hosts 文件存放路徑

  3. 按正常流程發佈、上線代碼,傳輸文件、遠程執行命令均會經過ansible併發執行

php5.6環境CentOS安裝

刪除老的安裝包

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```


安裝部署 Walle      

1.簡潔安裝指南

git clone git@github.com:meolu/walle-web.git
cd walle-web
vi config/web.php # 設置mysql鏈接
composer install  # 若是缺乏bower-asset的話, 先安裝:composer global require "fxp/composer-asset-plugin:*"
./yii walle/setup   # 初始化項目
配置nginx/apache的webroot指向walle-web/web

2.最最最詳細安裝指南

如下安裝,均在宿主機(一臺配置了LAMP/LNMP的linux機器,而且安裝git/svn)上操做,若有問題,詳見Q&A

若是尚未安裝php 5.4+環境的,請先安裝php5.4+,詳情看php 5.6安裝

1.代碼檢出

mkdir -p /data/www/walle-web && cd /data/www/walle-web  # 新建目錄
git clone git@github.com:meolu/walle-web.git .          # 代碼檢出

2.設置mysql鏈接

vi config/local.php +14
'db' => [
   'dsn'       => 'mysql:host=127.0.0.1;dbname=walle', # 新建數據庫walle
   'username'  => 'username',                          # 鏈接的用戶名
   'password'  => 'password',                          # 鏈接的密碼
],

3.安裝composer,若是已安裝跳過

curl -sS https://getcomposer.org/installer | php
mv composer.phar /usr/local/bin/composer                # PATH目錄

4.安裝vendor

cd walle-web
composer install --prefer-dist --no-dev --optimize-autoloader -vvvv

安裝速度慢或失敗,可直接下載vendor解壓到項目根目錄

5.初始化項目

cd walle-web
./yii walle/setup # 須要你的yes

6.配置nginx

凡是在第7步刷新頁面看到50x均是前5步安裝不完整,自行檢查

凡是在第7步刷新頁面看到404均是nginx配置不當,自行檢查

nginx簡單配置

server {
   listen       80;
   server_name  walle.compony.com; # 改你的host
   root /the/dir/of/walle-web/web; # 根目錄爲web
   index index.php;

   # 建議放內網
   # 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;
   }
}

7.恭喜:)

訪問地址:localhost

固然,可能你配置nginx時的server_name是walle.company.com時,配置本地hosts以後,直接訪問:walle.company.com亦可。

安裝錯誤       

composer安裝速度慢

好吧,我已經猜到會有人問有沒有現成的,有! 下載百度網盤,解壓vendor放到walle-web根目錄便可。

第一次使用composer可能會出現的問題:1 沒有添加git的token

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):

解決辦法:

第一次使用composer可能會出現的問題:2 composer install 可能會出現的錯誤

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:*"

如何添加用戶key到git的ssh-keys列表

su - www           # 假如www爲你的php進程用戶
ssh-keygen -t rsa     # 若是你都沒有生成過rsa_key的話
cat ~/.ssh/id_rsa.pub  # 複製
打開github/gitlab添加到你的ssh-keys或者deploy-keys裏

如何添加用戶ssh-key到目標機羣部署用戶ssh-key信任

宿主機操做

ps aux|grep php         # 假如www_php爲你的php進程用戶
su - www_php           # 切換用戶
ssh-keygen -t rsa        # 若是你都沒有生成過rsa_key的話,若是有則跳過
ssh-copy-id -i ~/.ssh/id_rsa.pub www_remote@remote_host  # 加入目標機羣信任,須要輸入www_remote密碼

初始化walle時失敗:could not find driver

缺乏pdo擴展,解決辦法:添加pdo擴展

ubuntu
apt-get install php5 php5-fpm php5-mysql

或者在源碼包裏編譯
cd php-src/ext/pdo_mysql
phpize
./configure --with-php-config=/php/install/dir/bin/php-config
make && make install
vi php.ini # 添加pdo_mysql.so
restart php-fpm

7.nginx簡單配置

server {
   listen       80;
   server_name  walle.company.com; # 改你的host
   root /the/dir/of/walle-web/web; # 根目錄爲web
   index index.php;

   # 建議放內網
   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;
   }
}

切換用戶(www)時:this account is currently not available

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

Call to undefined function yii\web\mb_parse_str()

缺乏mbstring擴展,安裝mbstring擴展重啓php便可。mbstring擴展:http://php.net/manual/zh/mbstring.installation.php

Git項目配置      

git 項目配置指南

git部署是最推薦的方式,它不管對於何種語言都是合適的。

1、基本要求:

  1. 宿主機php進程用戶www_php(假如,可經過配置的檢測查看或ps aux|grep php)的ssh-key要加入git/gitlab的deploy-keys。固然也能夠http地址帶用戶名密碼(不推薦):https://username:password@github.com/meolu/walle-web.git

  2. 宿主機php進程用戶www_php(假如,可經過配置的檢測查看或ps aux|grep php)要加入目標機羣部署用戶www_remote(配置中)ssh-key信任,具體怎麼添加可找sa或者百度或者,這通常是用戶最不理解的地方,建議先花半小時理解linux用戶概念和php配置。

2、配置項目


3、檢測項目配置

配置完畢以後,先檢測下,如無問題則能夠發起上線單了:)

4、檢測的錯誤和解決辦法

  • 宿主機代碼檢出檢測出錯,請確認php進程用戶{user}有代碼存儲倉庫{path}讀寫權限,且把ssh-key加入git的deploy-keys列表。詳細錯誤:{error}

    • 問題:請確認php進程用戶{user}有代碼存儲倉庫{path}讀寫權限

      沒有權限,是由於用戶{user}對目錄{path}沒有讀寫權限,給權限便可
      ll {path}
      chown {user} -R {path}
      chmod 755 -R {path}
    • 問題:把ssh-key加入git的deploy-keys列表

      su {user} && cat ~/.ssh/id_rsa.pub
      打開 github/gitlab/bitbucket 網站, 添加 ssh-key 到ssh-keys列表

可能的緣由之一是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信任列表

    添加機器信任,仍是沒理解請百度吧(由於太多的同窗問這問題,實在沒辦法只能這麼囉嗦)
    su {local_user} && ssh-copy-id -i ~/.ssh/id_rsa.pub remote_user@remote_server
    # need remote_user's password
  • 問題:{remote_user}有目標機器發佈版本庫{path}寫入權限

    su remote_user
    ll {path}
    chown {remote_user} -R {path}
    chmod 755 -R {path}

Svn項目配置      

svn 項目配置

svn部署上線與git有點不太同樣,svn是推薦增量發佈(固然也能夠全量更新),在開發者提交文件列表(可能帶版本號),管理員審覈上線單。發起部署時,爲該上線單開闢一個獨立空間,檢出代碼,選擇上線單中的文件(可能帶版本號)同步到目標機羣。有不瞭解宿主機和目標機羣關係、上線流程的同窗先到項目主頁瞭解。

由於svn沒有git的版本快照,因此在部署須要全量代碼編譯操做時,只能選擇全量更新,此時要求發佈的分支/tag/trunk是可發佈狀態。建議java + git組合。同理其它須要全量代碼在宿主機作編譯相關的操做的語言,且爲svn版本管理,請慎用。

1、基本要求:

  1. svn目錄推薦如下規範,詳細能夠註冊riouxsvn,做爲svn測試地址。固然三無(無trunk、無branches、無tags)也是支持:)

    • branches

    • tags

    • trunk

  2. 宿主機php進程用戶www_php(假如,可經過配置的檢測查看或ps aux|grep php)要加入目標機羣部署用戶www_remote(配置中)ssh-key信任,具體怎麼添加可找sa或者百度或者,這通常是用戶最不理解的地方,建議先花半小時理解linux用戶概念和php配置。

2、配置項目


3、檢測項目配置

配置完畢以後,先檢測下,如無問題則能夠發起上線單了:)

4、檢測的錯誤和解決辦法

  • 宿主機代碼檢出檢測出錯,請確認php進程用戶{user}有代碼存儲倉庫{path}讀寫權限。詳細錯誤:{error}

    沒有權限,是由於用戶{user}對目錄{path}沒有讀寫權限,給權限便可
    ll {path}
    chown {user} -R {path}
    chmod 755 -R {path}
  • 目標機器部署出錯,請確認php進程{local_user}用戶ssh-key加入目標機器的{remote_user}用戶ssh-key信任列表,且{remote_user}有目標機器發佈版本庫{path}寫入權限。詳細錯誤:{error}

    • 問題:請確認php進程{local_user}用戶ssh-key加入目標機器的{remote_user}用戶ssh-key信任列表

      添加機器信任,仍是沒理解請百度吧(由於太多的同窗問這問題,實在沒辦法只能這麼囉嗦)
      su {local_user} && ssh-copy-id -i ~/.ssh/id_rsa.pub remote_user@remote_server
      # need remote_user's password
    • 問題:{remote_user}有目標機器發佈版本庫{path}寫入權限

      su remote_user
      ll {path}
      chown {remote_user} -R {path}
      chmod 755 -R {path}

高級任務配置      

高級任務方便用戶自定義一些操做,不管是在代碼檢出先後,仍是切換版本先後。

1、java配置實例


pre_deploy任務

echo pre_deploy >> /tmp/cmd        # 初始化一些東西,自由發揮

post_deploy任務

mvn package -Dmaven.test.skip=true # 編譯java
mvn clean                          # 打掃
mv WEB-INF/config.Properties.test WEB-INF/config.Properties # 切換環境相應的配置
rm -rf src                         # 甚至刪除無用代碼

pre_release任務

./xx.sh stop                       # 暫停服務

post_release任務

./xx.sh start                      # 啓動服務

2、若是我想執行sudo命令?


想執行sudo命令的前提是用戶有root權限,要執行哪些命令?

  • 添加用戶到sudoers

    visudo
    www    ALL=(ALL)       ALL
  • 添加免密碼命令

    visudo
    www ALL = (ALL) NOPASSWD: /usr/local/nginx/bin/nginx
  • 設置用戶的tty(宿主機執行sudo須要此步,目標機能夠跳過此步)

    Defaults:www    !requiretty

項目用戶配置      

角色分爲管理員(註冊可選)、開發者(註冊可選)、項目審覈管理員(前面兩者都可是)。

1.管理員

註冊時,選擇角色爲管理員,註冊後郵件驗證,但此時也不是馬上擁有管理員權限,須要其它管理員審覈經過才行。

管理員的權限列表

  • 配置新的項目、修改本身的項目配置

  • 審覈新管理員

  • 設置項目的成員、項目審覈管理員

  • 審覈上線單

  • 上線

2.項目審覈管理員

註冊時無此用戶角色,爲管理員爲減輕本身審覈上線單壓力、防止管理員不在線而影響上線而須要一兩個代理審覈管理員。但不能編輯項目配置,也不能添加項目成員,只比開發者多一個審覈上線單的權限。

管理員的權限列表

  • 審覈上線單

  • 上線


3.開發者

普通開發者可提交上線單,上線部署

管理員的權限列表

檢測錯誤     

  • 宿主機代碼檢出檢測出錯,請確認php進程用戶{user}有代碼存儲倉庫{path}讀寫權限,且把ssh-key加入git的deploy-keys列表。詳細錯誤:{error}

    • 問題:請確認php進程用戶{user}有代碼存儲倉庫{path}讀寫權限

      沒有權限,是由於用戶{user}對目錄{path}沒有讀寫權限,給權限便可
      ll {path}
      chown {user} -R {path}
      chmod 755 -R {path}
    • 問題:把ssh-key加入git的deploy-keys列表

      su {user} && cat ~/.ssh/id_rsa.pub
      打開 github/gitlab/bitbucket 網站, 添加 ssh-key 到ssh-keys列表
  • 目標機器部署出錯,請確認php進程{local_user}用戶ssh-key加入目標機器的{remote_user}用戶ssh-key信任列表,且{remote_user}有目標機器發佈版本庫{path}寫入權限。詳細錯誤:{error}

    • 問題:請確認php進程{local_user}用戶ssh-key加入目標機器的{remote_user}用戶ssh-key信任列表

      添加機器信任,仍是沒理解請百度吧(由於太多的同窗問這問題,實在沒辦法只能這麼囉嗦)
      su {local_user} && ssh-copy-id -i ~/.ssh/id_rsa.pub remote_user@remote_server
      # need remote_user's password
      # 爲何我把{local_user}的ssh-key加到遠程機器的{remote_user}下的~/.ssh/authorized_keys仍是不能免密碼登陸
      # 免密碼登陸須要遠程機器權限知足如下三個條件:
        /home/{remote_user} 755
        ~/.ssh 700
        ~/.ssh/authorized_keys 644 或 600
    • 問題:{remote_user}有目標機器發佈版本庫{path}寫入權限

      su remote_user
      ll {path}
      chown {remote_user} -R {path}
      chmod 755 -R {path}

提交上線單          

上線單包括兩種方式:gitsvn

1、git 項目提交上線單

2、svn 項目提交上線單

svn上線單與git相似,但有些區別,會有全量上線和增量上線兩種主要形式,增量上線支持指定文件的版本號。分別看下能夠有哪些格式填寫上線單:

  • 上線全量文件

    *
  • 增量上線指定文件

    file_name1
    file_name2
  • 增量上線指定文件的指定版本

    file_name1 commit_id
    file_name2 commit_id

部署出錯          

1.上線至全量更新服務器時出錯:mv -fT

緣由分析:更新目標機羣是以軟鏈方式來更新webroot,若是提早在目標機羣建立了webroot目錄,軟鏈覆蓋將會失敗。

解決辦法:直接刪除目標機羣webroot目錄,肯定其父目錄有讀寫的權限便可,由瓦力系統生成webroot軟連接。

2.上線出錯,想知道到底發生了什麼事情

有些錯誤walle捕捉不到,默認操做日誌在/tmp/walle/下,具體可在config/local.phplog.dir配置路徑,tail着日誌,部署看日誌。

3./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

致此瓦力已經部署成功!若有任何問題可聯繫博主或者登陸官網查看詳情。

相關文章
相關標籤/搜索