运行Shopware社区版(版本3.5.6)在Nginx(LEMP)在Debian Squeeze / Ubuntu 12.04

运行Shopware社区版(3.5.6版)在Nginx(LEMP)上Debian Squeeze / Ubuntu 12.04

本教程将介绍如何在安装了nginx的Debian Squeeze或Ubuntu 12.04系统上安装并运行Shopware Community Edition (3.5.6版),而不是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安装,如这些教程所示:

Ubuntu用户注意事项:

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

sudo su

2安装Xcache和ionCube装载机

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

Xcache可以安装如下:

apt-get install php5-xcache

Shopware Community Edition要求安装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作为FastCGI守护程序(如在中中 ,请重新加载如下:

/etc/init.d/php5-fpm reload

如果您使用lighttpd的spawn-fcgi程序作为FastCGI守护进程(例如在使用Debian Squeeze安装Nginx with PHP5和MySQL支持 )中,我们必须终止当前的spawn-fcgi进程(在端口9000上运行),并创建一个新的。 跑

netstat -tap

找出当前的spawn-fcgi进程的PID:

root@server1:~# netstat -tap
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 *:sunrpc                *:*                     LISTEN      734/portmap
tcp        0      0 *:www                   *:*                     LISTEN      2987/nginx
tcp        0      0 *:ssh                   *:*                     LISTEN      1531/sshd
tcp        0      0 *:57174                 *:*                     LISTEN      748/rpc.statd
tcp        0      0 localhost.localdom:smtp *:*                     LISTEN      1507/exim4
tcp        0      0 localhost.localdom:9000 *:*                     LISTEN      1542/php5-cgi
tcp        0      0 localhost.localdo:mysql *:*                     LISTEN      1168/mysqld
tcp        0     52 server1.example.com:ssh 192.168.0.198:2462      ESTABLISHED 1557/0
tcp6       0      0 [::]:www                [::]:*                  LISTEN      2987/nginx
tcp6       0      0 [::]:ssh                [::]:*                  LISTEN      1531/sshd
tcp6       0      0 ip6-localhost:smtp      [::]:*                  LISTEN      1507/exim4
root@server1:~#

在上面的输出中,PID是1542 ,所以我们可以杀死当前的进程如下:

kill -9 1542

之后我们创建一个新的spawn-fcgi进程:

/usr/bin/spawn-fcgi -a 127.0.0.1 -p 9000 -u www-data -g www-data -f /usr/bin/php5-cgi -P /var/run/fastcgi-php.pid

3安装Shopware

我的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软件包(具有或不具有演示数据的ionCube软件包),并将其放在/ tmp / shopware目录中。 我在这里使用了带有演示数据ionCube软件包,以便我在商店里玩一些演示项目(如果你想要一个空的商店,使用没有演示数据的软件包)。

cd /tmp/shopware
wget -O demo_ioncube_3.5.6.zip http://files.shopware.de/download.php?package=demo_ioncube

现在解压缩Shopware并将其移动到文档根目录( /var/www/www.example.com/web ):

unzip demo_ioncube_3.5.6.zip
rm -f demo_ioncube_3.5.6.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;

然后转到文档根目录( /var/www/www.example.com/web/ ),并将SQL转储import.sql导入到Shopware MySQL数据库中:

cd /var/www/www.example.com/web/
mysql -h localhost -u shopware_admin -pshopware_admin_password shopware < import.sql
rm -f import.sql

(请注意, mysql命令中-pshopware_admin_password之间没有空格!)

下次登录你的商店 MySQL数据库...

mysql -u shopware_admin -p
USE shopware;

...并为您的Shopware安装设置正确的主机名和基准线:

UPDATE s_core_config SET value = 'www.example.com' WHERE name = 'sHOST';
UPDATE s_core_config SET value = 'www.example.com' WHERE name = 'sBASEPATH';
UPDATE s_core_multilanguage SET domainaliase = 'www.example.com' WHERE id = 1;
quit;

然后编辑config.php并设置正确的数据库详细信息:

vi config.php
<?php
/**
 * Shopware 3.5.4.1 - Database-Config
 */
$DB_HOST = 'localhost';
$DB_USER = 'shopware_admin';
$DB_PASSWORD = 'shopware_admin_password';
$DB_DATABASE = 'shopware';

几个目录需要777个权限:

chmod 777 cache/database
chmod 777 cache/templates
chmod 777 images/*
chmod 777 files/*
chmod 777 uploads
chmod 777 engine/Shopware/Proxies
chmod 777 engine/Enlight/Vendor/mpdf/tmp
chmod 777 engine/Enlight/Vendor/mpdf/ttfontdata

因为您可以在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 / {
                # Set DirectoryIndex
                index  shopware.php index.php;

                # Deny direct access to all smarty templates
                location ~ ^/templates/.*/*.tpl {
                         deny all;
                }

                # Deny access to php files in web readable directories
                location ~ ^/cache/.*/.*\.(php|cgi|php5|php3|php4|phtml|pl|py) {
                         deny all;
                }
                location ~ ^/images/.*/.*\.(php|cgi|php5|php3|php4|phtml|pl|py) {
                         deny all;
                }
                location ~ ^/files/.*/.*\.(php|cgi|php5|php3|php4|phtml|pl|py) {
                         deny all;
                }
                location ~ ^/upload/.*/.*\.(php|cgi|php5|php3|php4|phtml|pl|py) {
                         deny all;
                }

                # Defining rewrite rules
                rewrite /images/ayww/(.*) /images/banner/$1 last;
                rewrite /files/documents/.* /engine last;
                rewrite /templates/(.*(css|js))$ /engine/backend/php/sCacheTemplate.php?file=/templates/$1 last;
                rewrite /sitemap.xml(.*) /shopware.php?controller=SitemapXml;
                rewrite /application.yaml /engine last;
                rewrite /engine/core/php/sAjaxSearch.php$ /engine/backend/php/sAjaxSearch.php last;
                rewrite /engine/core/php/campaigns.php$ /engine/backend/php/campaigns.php last;

                # Defining controller based route processing behaviour
                if (!-e $request_filename) {
                         rewrite . /shopware.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

现在已经安装了Shopware Community Edition。 您可以通过访问http://www.example.com/backend登录后端 - 使用用户名演示和密码演示登录:

这就是后端的样子:

您应该做的第一件事是更改演示用户的用户名和密码。 点击Shop-Ansicht右下角的蓝色图标(在底部) - 这将带您进入用户管理。 点击管理员用户...

...并将用户名从demo更改为(例如) admin ,并指定新密码。 您还应该更改电子邮件地址:

该商店可以通过http://www.example.com访问

在Nginx下玩你的Shopware商店!

4链接

关于作者

Falko Timme是所有者 Timme Hosting(超快nginx网页托管)。 他是youcl(自2005年以来)的主要维护者, 也是ISPConfig的核心开发人员之一 (自2000年起)。 他还为O'Reilly的“Linux系统管理”一书作出了贡献。

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

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

支付宝扫一扫打赏

微信扫一扫打赏