运行SilverStripe在Nginx(LEMP)在Debian Wheezy / Ubuntu 13.04

运行SilverStripe On Nginx(LEMP)在Debian Wheezy / Ubuntu 13.04

本教程将介绍如何在安装了nginx而不是Apache的Debian Wheezy或Ubuntu 13.04系统上安装和运行SilverStripe(LEMP = L inux + nginx(发音为“ e ngine x”)+ M ySQL + P HP)。 nginx是一个HTTP服务器,比Apache使用的资源少得多,并且提供了更快的网页,特别是静态文件。

我不会保证这将为您工作!

1初步说明

我想使用文件根/var/www/www.example.com/web将名称为www.example.com / example.com的虚拟机安装SilverStripe

您应该有一个工作的LEMP安装,如本教程所示:

Ubuntu用户注意事项:

因为我们必须使用root权限运行本教程的所有步骤,所以我们可以使用字符串sudo在本教程中添加所有命令,也可以通过键入来成为root

sudo su

2安装APC

APC是一个免费开放的PHP操作码cacher,用于缓存和优化PHP中间代码。 它类似于其他PHP操作码cacher,如eAccelerator和XCache。 强烈建议您安装其中一个以加快您的PHP页面。

APC可以安装如下:

apt-get install php-apc

重新载入PHP-FPM如下:

/etc/init.d/php5-fpm reload

3安装SilverStripe

我的www.example.com网站的文档根目录是/var/www/www.example.com/web - 如果不存在,创建如下:

mkdir -p /var/www/www.example.com/web

接下来从SilverStripe网站 (我在这里使用“CMS&Framework”版本)下载SilverStripe到您的服务器,解压缩并将其放在文档根目录中:

cd /tmp
wget http://www.silverstripe.org/assets/releases/SilverStripe-cms-v3.1.1.tar.gz
tar xvfz SilverStripe-cms-v3.1.1.tar.gz
rm -f SilverStripe-cms-v3.1.1.tar.gz
cd SilverStripe-cms-v3.1.1
mv * .htaccess /var/www/www.example.com/web/

建议将文件根和SilverStripe文件写入作为用户www-data和组www-data运行的nginx守护程序:

chown -R www-data:www-data /var/www/www.example.com/web

如果您尚未为SilverStripe(包括MySQL SilverStripe用户)创建了MySQL数据库,则可以按如下方式(在此示例中命名数据库silverstripe ,用户名为sstripe_admin ,密码为sstripe_admin_password ):

mysqladmin -u root -p create silverstripe
mysql -u root -p
GRANT ALL PRIVILEGES ON silverstripe.* TO 'sstripe_admin'@'localhost' IDENTIFIED BY 'sstripe_admin_password';
GRANT ALL PRIVILEGES ON silverstripe.* TO 'sstripe_admin'@'localhost.localdomain' IDENTIFIED BY 'sstripe_admin_password';
FLUSH PRIVILEGES;
quit;

接下来,我们在/ etc / nginx / sites-available /目录中为www.example.com vhost创建一个nginx vhost配置,如下所示:

vi /etc/nginx/sites-available/www.example.com.vhost
server {
       listen 80;
       server_name www.example.com example.com;
       root /var/www/www.example.com/web;

       if ($http_host != "www.example.com") {
                 rewrite ^ http://www.example.com$request_uri permanent;
       }

       index index.php index.html;

       location = /favicon.ico {
                log_not_found off;
                access_log off;
       }

       location = /robots.txt {
                allow all;
                log_not_found off;
                access_log off;
       }

       # Deny all attempts to access hidden files such as .htaccess, .htpasswd, .DS_Store (Mac).
       location ~ /\. {
                deny all;
                access_log off;
                log_not_found off;
       }

       client_max_body_size 100M;

       location ^~ /assets/ {
                try_files $uri =404;
                expires max;
                access_log off;
                log_not_found off;
       }
       location ~ \.ss {
                allow 127.0.0.1;
                deny all;
       }
       location ~ web\.config {
                deny all;
       }
       location ~ \.(ya?ml|bak|swp)$ {
                deny all;
       }
       location ~ ~$ {
                deny all;
       }
       location ^~ /silverstripe-cache/ {
                deny all;
       }
       location ^~ /vendor/ {
                deny all;
       }
       location ~ /composer\.(json|lock) {
                deny all;
       }
       location ~ ^/framework/(.+/)?(main|rpc|tiny_mce_gzip)\.php$ {
                try_files /6c1ec1bb21001dd913db95cfb05d78d7.htm @php;
       }
       location ~ ^/(cms|framework|mysite)/.+\.(php|php[345]|phtml|inc)$ {
                deny all;
       }
       location ~ ^/(cms|framework)/silverstripe_version$ {
                deny all;
       }

       error_page 404 /assets/error-404.html;
       error_page 500 /assets/error-500.html;

       location / {
                 if (!-f $request_filename) {
                    rewrite ^/(.*?)(\?|$)(.*)$ /framework/main.php?url=$1&$3 last;
                 }
       }

       location ~ ^/(index|install)\.php/ {
                fastcgi_split_path_info ^((?U).+\.php)(/?.+)$;
                include /etc/nginx/fastcgi_params;
                fastcgi_pass unix:/var/run/php5-fpm.sock;
                fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
       }

       location ~ \.php$ {
                try_files /6c1ec1bb21001dd913db95cfb05d78d7.htm @php;
       }

       location @php {
                try_files $uri =404;
                include /etc/nginx/fastcgi_params;
                fastcgi_pass unix:/var/run/php5-fpm.sock;
                fastcgi_index index.php;
                fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
                fastcgi_intercept_errors on;
                fastcgi_temp_file_write_size 10m;
                fastcgi_busy_buffers_size    512k;
                fastcgi_buffer_size          512k;
                fastcgi_buffers           16 512k;
                fastcgi_read_timeout 1200;
       }
}

要启用vhost,我们从/ etc / nginx / sites-enabled /目录创建一个符号链接:

cd /etc/nginx/sites-enabled/
ln -s /etc/nginx/sites-available/www.example.com.vhost www.example.com.vhost

重新加载nginx以使更改生效:

/etc/init.d/nginx reload

现在,我们可以通过访问http://www.example.com/install.php启动基于Web的SilverStripe安装程序 - 填写您的数据库详细信息,然后单击重新检查要求

然后填写管理员帐户的密码,然后选择您的语言。 然后向下滚动...

...并选择您的主题(您可以选择一个空白的模板从头开始或包含一些演示数据的简单模板开始)。 然后点击安装SilverStripe

SilverStripe正在安装。 几秒钟之后,您将得到一个安装成功消息:

index.php和install.php文件不再需要,因此您可以删除它们:

rm -f /var/www/www.example.com/web/index.php /var/www/www.example.com/web/install.php

这是SilverStripe网站的外观(简单的它们包含一些演示数据):

后端可以访问http://www.example.com/admin - 这是它的外观:

4链接

赞(52) 打赏
未经允许不得转载:优客志 » 系统运维
分享到:

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏