2017-07-15 152 views
0

我是Laravel的新手,目前正在致力於我的第一個項目。我曾與CI合作過,但從未與Laravel合作過。所以,這是我的Dev服務器的部署腳本。不知道這是否是最好的方法。無論如何,遷移部分給我一個錯誤。之後,我得到這個工作,我會嘗試一些PHP插件來分析代碼的質量,複製,單元測試等與Laravel持續集成與開發

請參見下面

腳本:

rsync -a . /var/www/html/dev/ 

cd /var/www/html/dev/ 

# cfg file for dev 
cp .env.dev .env 

# run composer 
composer clearcache 
composer install --optimize-autoloader 

# optimize 
php artisan cache:clear 
php artisan optimize 
php artisan route:cache | true 

# migrate DB 
php artisan migrate 

錯誤:

[Illuminate\Database\QueryException]           
    SQLSTATE[42S01]: Base table or view already exists: 

我是否應該在遷移之前刪除所有表格?如果是這樣,我不知道使用它們進行自動部署有什麼用處。此外,我們的表格中充滿了測試數據(手動填充,因爲我們不想自動播種)。

+0

如果遷移失敗,然後嘗試重新遷移數據庫時,通常只得到這個消息。 –

+0

@RossWilson,你似乎是對的。那麼,當某些遷移失敗以避免這種情況時,如何繼續? –

+0

您通常會在本地/ dev環境中遇到這些錯誤,並在問題進入生產之前解決問題。當它發生在您的開發環境中時,您可以手動刪除所有表或者只檢查不存在於您的遷移表中的表,然後簡單地刪除該表,然後回滾並遷移。 –

回答

0

在運行遷移之前,不應刪除所有表。

此錯誤來自您的migrations表和您的migrationsdatabase\migrations文件夾有衝突。

在返回以繼續配置Jenkins之前,您應該解決此衝突。

我的建議:

您應該使用Rocketeer爲控制您的項目發佈版本。

您可以通過shared文件夾共享您的.env文件。

你可以運行composer installnpm install默認配置爲火箭手。

這是我的步驟安裝和配置火箭人:

安裝火箭人:

$ wget http://rocketeer.autopergamene.eu/versions/rocketeer.phar 
$ chmod +x rocketeer.phar 
$ mv rocketeer.phar /usr/local/bin/rocketeer 
//TODO Install PHP for Jenkins server 
$ sudo apt-get install php 
//TODO Check rocketeer 
$ rocketeer check 
No connections have been set, please create one: (production) <~ Succeed 

安裝遠程服務器的信息

$ cd /var/lib/jenkins/drone-deploy/drone-deploy/server-dev 
$ rocketeer ignite 
No connections have been set, please create one: (production)develop 
No host is set for [develop], please provide one:35.166.x.x 
No username is set for [develop], please provide one:ec2-user 
No password or SSH key is set for [develop], which would you use? (key) [key/password]key 
Please enter the full path to your key (/var/lib/jenkins/.ssh/id_rs/var/lib/jenkins/.ssh/xxx.pem 
If a keyphrase is required, provide it 
No repository is set for [repository], please provide one:[email protected]:xx/xxxxxx.git 
No username is set for [repository], please provide one:xxx 
No password is set for [repository], please provide one: 
develop/0 | Ignite (Creates Rocketeer's configuration) 
What is your application's name ? (drone-php)drone_deploy 
The Rocketeer configuration was created at server-dev/.rocketeer 

配置

$ cd /var/lib/jenkins/drone-deploy/drone-deploy/drone-php 
$ nano .rocketeer/config.php 
Replace connections name production --> develop //It's Rocketeer bug 
$ nano .rocketeer/remote.php 
'root_directory' => '/var/www/html/', 
'shared'   => [ 
     'storage/logs', 
     'storage/framework/sessions', 
     '.env', 
    ], 
'permissions' => [ 

     // The folders and files to set as web writable 
     'files' => [ 
      //'app/database/production.sqlite', 
      'bootstrap', 
      'storage', 
      'public', 
     ], 

     // Here you can configure what actions will be executed to set 
     // permissions on the folder above. The Closure can return 
     // a single command as a string or an array of commands 
     'callback' => function ($task, $file) { 
      return [ 
       sprintf('chmod -R 777 %s', $file), 
       sprintf('chmod -R g+s %s', $file), 
       sprintf('chown -R ec2-user:ec2-user %s', $file), 
      ]; 
     }, 

    ], 
$ nano .rocketeer/strategies.php 
    //'test'   => 'Phpunit', 
    'test'   => '', 
    //return $composer->install([], ['--no-interaction' => null, '--no-dev' => null, '--prefer-dist' => null]); 
    return $composer->install([]); 

運行TE ST

rocketeer deploy --on="develop" --tests 

enter image description here