В настоящее время я разворачиваю свой веб-сайт PHP от стадии подготовки к работе, используя следующий ручной процесс:
Весь этот процесс довольно запутанный и занимает около 5-10 минут, и мне приходится делать это каждый раз, когда я вношу изменения в веб-сайт, поэтому это стало рутиной.
Есть ли способ автоматизировать этот процесс с помощью какого-нибудь скриптового инструмента? Или есть хороший инструмент развертывания, который люди используют, чтобы все это делать? Мои промежуточные и производственные машины основаны на сервере Ubuntu 12.04, поэтому потенциально я мог бы использовать сценарии bash для выполнения некоторых работ.
Вот некоторые улучшения, которые, как я вижу, можно было бы сделать на данный момент:
Одна компания, в которой я работал, использовала Инструмент командной строки Fabric для автоматизации развертывания и подобных вещей. Однако это хороший вариант или есть лучший инструмент?
Ткань идеально подойдет для такого рода задач. Если вы знакомы с python, у вас есть большая гибкость в том, что вы можете делать.
Capistrano - еще один вариант, который может быть полезен, я использовал его для развертывания Rails, и у меня не было проблем. Позволяет легко запускать команды оболочки на удаленных хостах.
Другой вариант может заключаться в использовании Ant (способ Python с тканью намного лучше imo).
Вы используете систему управления версиями, например git? Вы можете добавить некоторые из этих задач в качестве обработчиков после фиксации, когда будете помещать их в свою «производственную» ветку.
Rsync будет самым быстрым и безопасным вариантом. Убедитесь, что вы исключили все файлы, которые не должны находиться в производстве (файлы резервных копий, файлы vim .swp и т. Д.).
В конце концов, я использовал Fabric и придумал сценарий, который делает именно то, что я хочу. Через 48 секунд все копируется во временный каталог, все файлы минимизируются, затем на сайте отображается «страница выполнения загрузки», все передается на сервер с помощью SSH, а затем снова запускается.
from fabric.api import *
import datetime
# Format the current date as string 20120908-221521 (8 Sep 2012, 22:15:21)
# This will be used to append to the folder of the deployment directory so there's a backup of what was deployed
currentDate = datetime.datetime.now().strftime("%Y%m%d-%H%M%S")
# Where the files for this deployment are stored
deploymentDir = "/var/www/deployments/mysite-deployment-" + currentDate
# SSH config for production server
env.use_ssh_config = True
env.hosts = ["mysite.net"]
env.user = "root"
env.port = 44
# Test connection to live server
def test():
run("ls -al")
#--------------------------------------------------------------------------------------
# Main functions - to run use "fab live" from command line to update production server
#--------------------------------------------------------------------------------------
def live():
backupToDeploymentDir()
switchToProductionFiles()
minifyCssAndJavaScript()
switchToUpdatesInProgress()
rsyncToProduction()
switchToLive()
print("Deployment " + currentDate + " complete")
# Alias for the clearCachedFiles method - to run use "fab cc" or "fab live cc"
def cc():
clearCachedFiles()
#-------------------
# Utility functions
#-------------------
# Backup to deployment directory
def backupToDeploymentDir():
local("cp -a /var/www/staging/ %s" % deploymentDir)
# Remove development cache and log files, switch into production mode for htaccess and front controller
def switchToProductionFiles():
local("rm -rf " + deploymentDir + "/temp/cache/*")
local("rm -rf " + deploymentDir + "/temp/logs/*")
local("rm -rf " + deploymentDir + "/fabfile.pyc")
local("rm -rf " + deploymentDir + "/nbproject")
local("rm " + deploymentDir + "/.htaccess")
local("rm " + deploymentDir + "/index.php")
local("mv " + deploymentDir + "/live-.htaccess " + deploymentDir + "/" + ".htaccess")
# Minify CSS and JavaScript files
def minifyCssAndJavaScript():
# Compress CSS
local("sudo yui-compressor --line-break 1 -o " + deploymentDir + "/public/css/main.css " + deploymentDir + "/public/css/main.css --type css")
local("sudo yui-compressor --line-break 1 -o " + deploymentDir + "/public/css/pdf.css " + deploymentDir + "/public/css/pdf.css --type css")
local("sudo yui-compressor --line-break 1 -o " + deploymentDir + "/public/css/print.css " + deploymentDir + "/public/css/print.css --type css")
local("sudo yui-compressor --line-break 1 -o " + deploymentDir + "/public/css/reset.css " + deploymentDir + "/public/css/reset.css --type css")
# Compress CSS external library files
local("sudo yui-compressor --line-break 1 -o " + deploymentDir + "/public/css/lib/fullcalendar.css " + deploymentDir + "/public/css/lib/fullcalendar.css --type css")
local("sudo yui-compressor --line-break 1 -o " + deploymentDir + "/public/css/lib/fullcalendar.print.css " + deploymentDir + "/public/css/lib/fullcalendar.print.css --type css")
# Compress JavaScript
local("sudo yui-compressor -o " + deploymentDir + "/public/js/ajax.js " + deploymentDir + "/public/js/ajax.js")
local("sudo yui-compressor -o " + deploymentDir + "/public/js/common.js " + deploymentDir + "/public/js/common.js")
local("sudo yui-compressor -o " + deploymentDir + "/public/js/default.js " + deploymentDir + "/public/js/default.js")
local("sudo yui-compressor -o " + deploymentDir + "/public/js/global.js " + deploymentDir + "/public/js/global.js")
local("sudo yui-compressor -o " + deploymentDir + "/public/js/organisation.js " + deploymentDir + "/public/js/organisation.js")
# Compress JavaScript external library files
local("sudo yui-compressor -o " + deploymentDir + "/public/js/lib/fullcalendar.js " + deploymentDir + "/public/js/lib/fullcalendar.js")
local("sudo yui-compressor -o " + deploymentDir + "/public/js/lib/head.load.js " + deploymentDir + "/public/js/lib/head.load.js")
local("sudo yui-compressor -o " + deploymentDir + "/public/js/lib/jquery.js " + deploymentDir + "/public/js/lib/jquery.js")
local("sudo yui-compressor -o " + deploymentDir + "/public/js/lib/jquery-ui.js " + deploymentDir + "/public/js/lib/jquery-ui.js")
local("sudo yui-compressor -o " + deploymentDir + "/public/js/lib/sha512.js " + deploymentDir + "/public/js/lib/sha512.js")
# Switch out the main index.php file for updates in progress one, before we rsync
def switchToUpdatesInProgress():
run("mv /var/www/updates-index.php /var/www/index.php")
# Sync all files from deployment directory to live site then run permissions
def rsyncToProduction():
local("rsync -azvv -e \"ssh -p 44\" " + deploymentDir + "/ root@mysite.net:/var/www")
run("chown -R root:www-data /var/www")
run("chmod -R 750 /var/www")
run("chmod -R 770 /var/www/temp/cache")
run("chmod -R 770 /var/www/temp/logs")
run("chmod -R 770 /var/www/temp/sessions")
run("chmod -R 770 /var/www/library/mPDF/ttfontdata")
run("chmod -R 770 /var/www/library/mPDF/tmp")
run("chmod -R 770 /var/www/library/mPDF/graph_cache")
# Clear cached files from the production server, useful if the PDF or JSON cache output has changed
def clearCachedFiles():
run("rm -rf /var/www/temp/cache/*")
print("Cached files cleared")
# Switch out the updates index.php file for the live one which will put the website live
def switchToLive():
run("rm /var/www/index.php")
run("mv /var/www/live-index.php /var/www/index.php")