在Ubuntu 12.04上运行新的商店版本4.0.x在Nginx(LEMP)上
本教程将介绍如何在Ubuntu 12.04系统上安装并运行新的Shopware 4.0.x版本,该系统已安装nginx而不是Apache(LEMP = L inux + nginx(发音为“ e ngine x”)+ M ySQL + P HP) 。 Shopware是一个功能丰富的电子商务平台; 我将在这里免费使用社区版。 nginx是一个HTTP服务器,比Apache使用的资源少得多,并且提供了更快的网页,特别是静态文件。
我不会保证这将为您工作!
1初步说明
我想在名为www.example.com
/ example.com
的vhost中安装Shopware,其中包含文档根/var/www/www.example.com/web
。
您应该有一个工作的LEMP安装,如本教程所示:
因为我们必须使用root权限运行本教程的所有步骤,所以我们可以使用字符串sudo
在本教程中添加所有命令,也可以通过键入来成为root
sudo su
2安装Xcache和ionCube装载机
Xcache是一个免费开放的PHP操作码cacher,用于缓存和优化PHP中间代码。 它类似于其他PHP操作码cacher,如eAccelerator和APC。 强烈建议您安装其中一个以加快您的PHP页面。
Xcache可以安装如下:
apt-get install php5-xcache
Shopware 4有不同的口味 - 社区版本,专业版,企业版和企业集群。 免费的社区版本不要求在其他版本的情况下安装ionCube Loader 。 但是,即使您使用社区版本,建议您安装ionCube Loader,因为如果您使用商业Shopware插件,则需要使用ionCube Loader。
ionCube Loader可以安装如下:
cd /tmp
下载并解压缩您的架构(x86_64或x86)的正确ionCube Loader软件包。
对于x86_64:
wget http://downloads2.ioncube.com/loader_downloads/ioncube_loaders_lin_x86-64.tar.gz
tar xfvz ioncube_loaders_lin_x86-64.tar.gz
对于x86:
wget http://downloads2.ioncube.com/loader_downloads/ioncube_loaders_lin_x86.tar.gz
tar xfvz ioncube_loaders_lin_x86.tar.gz
步骤如下:
cp ioncube/ioncube_loader_lin_5.3.so /usr/lib/php5/20090626/ioncube.so
vi /etc/php5/conf.d/ioncube.ini
zend_extension = /usr/lib/php5/20090626/ioncube.so |
重新载入PHP-FPM如下:
/etc/init.d/php5-fpm reload
3配置Nginx和PHP
我的www.example.com
网站的文档根目录是/var/www/www.example.com/web
- 如果不存在,创建如下:
mkdir -p /var/www/www.example.com/web
创建文件夹/ tmp / shopware
,我们将把Shopware存档:
mkdir /tmp/shopware
确保已解压缩:
apt-get install unzip
从http://wiki.shopware.de/Downloads_cat_448.html下载Shopware软件包,并将其放在/ tmp / shopware
目录中:
cd /tmp/shopware
wget -O shopware4.zip http://files.shopware.de/download.php?package=install
现在解压缩Shopware并将其移动到文档根目录( /var/www/www.example.com/web
):
unzip shopware4.zip
rm -f shopware4.zip
mv * .htaccess /var/www/www.example.com/web/
建议使用作为用户www-data
和group www-data
运行的nginx守护进程将文档根目录和Shopware文件写入:
chown -R www-data:www-data /var/www/www.example.com/web
如果您还没有为Shopware(包括MySQL Shopware用户)创建了MySQL数据库,则可以按照以下步骤进行操作(在本示例中,我将数据库的商品
命名为“ shopware_admin”
,他的密码是shopware_admin_password
):
mysql -u root -p
CREATE DATABASE shopware;
GRANT ALL PRIVILEGES ON shopware.* TO 'shopware_admin'@'localhost' IDENTIFIED BY 'shopware_admin_password';
GRANT ALL PRIVILEGES ON shopware.* TO 'shopware_admin'@'localhost.localdomain' IDENTIFIED BY 'shopware_admin_password';
FLUSH PRIVILEGES;
quit;
因为您可以在http和https下运行您的Shopware网站(如果您想提供https,那么完全取决于您,但如果您的客户提交敏感数据,如信用卡号码等),我们需要添加以下部分到/etc/nginx/nginx.conf
中的http {}
部分(在两个包含
行之前),它确定访问者是否使用http或https,并设置$ fastcgi_https
变量(我们将在www.example.com
vhost中使用)相应地:
vi /etc/nginx/nginx.conf
[...] http { [...] ## Detect when HTTPS is used map $scheme $fastcgi_https { default off; https on; } ## # Virtual Host Configs ## include /etc/nginx/conf.d/*.conf; include /etc/nginx/sites-enabled/*; } [...] |
接下来,我们在/ etc / nginx / sites-available /
目录中为www.example.com
vhost创建一个nginx vhost配置,如下所示:
vi /etc/nginx/sites-available/www.example.com.vhost
server { listen 80; ## SSL directives might go here ## see https://www.youcl.com/how_to_set_up_ssl_vhosts_under_nginx_plus_sni_support_ubuntu_11.04_debian_squeeze ## if you want to enable SSL for this vhost 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; } location ~ /\. { deny all; } location ~ /(engine|images/[a-z]+|files|templates)/ { } location / { index index.html index.php shopware.php rewrite shopware.dll /shopware.php; rewrite files/documents/.* /engine last; rewrite images/ayww/(.*) /images/banner/$1 last; rewrite backend/media/(.*) /media/$1 last; if (!-e $request_filename){ rewrite . /shopware.php last; } } location ~ \.(tpl|yml|ini)$ { deny all; } location /install { location /install/assets { } if (!-e $request_filename){ rewrite . /install/index.php last; } } location ~ \.php$ { try_files $uri =404; include /etc/nginx/fastcgi_params; fastcgi_pass 127.0.0.1:9000; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param HTTPS $fastcgi_https; } } |
如果要为vhost启用https,请参阅上述配置中的注释。 本教程将介绍该过程: 如何在Nginx + SNI支持下设置SSL Vhosts(Ubuntu 11.04 / Debian Squeeze)
要启用该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
接下来,我们必须配置PHP以满足Shopware的要求。 我假设你在这里使用默认的PHP-FPM池/etc/php5/fpm/pool.d/www.confconf
。 打开该文件...
vi /etc/php5/fpm/pool.d/www.conf
...并在文件末尾设置以下PHP配置:
[...] php_admin_value[memory_limit] = 512M php_admin_value[post_max_size] = 100M php_admin_value[upload_max_filesize] = 100M php_admin_value[max_execution_time] = 1200 php_admin_value[max_input_time] = 1200 php_admin_flag[magic_quotes_gpc] = off php_admin_flag[file_uploads] = Yes php_admin_value[max_file_uploads] = 20 php_admin_flag[phar.readonly] = off php_admin_flag[session.auto_start] = off php_admin_flag[suhosin.session.cryptua] = off php_admin_flag[zend.ze1_compatibility_mode] = off |
数字设置只是示例 - 例如,Shopware需要的内存限制只有128MB,因此您可能希望设置的值低于512MB。 同样, upload_max_filesize
必须至少为10MB。 Shopware 4安装程序将告诉您您的PHP配置是否与Shopware 4要求不匹配。
重新加载PHP-FPM:
/etc/init.d/php5-fpm reload
这就是服务器配置。