运行OXID eShop社区版(4.5.9版)在Debian Squeeze / Ubuntu 11.10上的Nginx(LEMP)上
本教程将介绍如何在Debian Squeeze或Ubuntu 11.10系统上安装并运行OXID eShop Community Edition (版本4.5.9),该系统已安装nginx而不是Apache(LEMP = L inux + nginx(发音为“ e ngine x”)+ M ySQL + P HP)。 OXID eShop是一个功能丰富的电子商务平台; 我将使用根据开放源代码认证许可证(GPL v3.0)许可的社区版本。 nginx是一个HTTP服务器,比Apache使用的资源少得多,并且提供了更快的网页,特别是静态文件。
我不会保证这将为您工作!
1初步说明
我想在名为www.example.com
/ example.com
的虚拟机中安装OXID eShop,文件根目录是/var/www/www.example.com/web
。
您应该有一个工作的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作为FastCGI守护进程(例如在Ubuntu 11.10中安装使用PHP5(和PHP-FPM)和MySQL支持的Nginx中 ),请重新启动它,如下所示:
/etc/init.d/php5-fpm restart
如果您使用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安装OXID eShop
我的www.example.com
网站的文档根目录是/var/www/www.example.com/web
- 如果不存在,创建如下:
mkdir -p /var/www/www.example.com/web
创建文件夹/ tmp /氧化物
,我们将放置OXID eShop存档:
mkdir /tmp/oxid
下载OXID eShop社区版从http://www.oxid-esales.com/de/download/open-source-software-oxid-eshop-community-edition下载到您的客户端PC,并将其从那里上载到/ tmp /氧化
(例如使用WinSCP)。
确保已解压缩:
apt-get install unzip
现在解压缩OXID eShop并将其移动到文档根目录( /var/www/www.example.com/web
):
cd /tmp/oxid
unzip OXID_ESHOP_CE_4.5.9_*.zip
rm -f OXID_ESHOP_CE_4.5.9_*.zip
mv * .htaccess /var/www/www.example.com/web/
建议使用作为用户www-data
和group www-data
运行的nginx守护进程将文档根目录和OXID eShop文件写入:
chown -R www-data:www-data /var/www/www.example.com/web
如果您还没有为OXID eShop(包括MySQL OXID eShop用户)创建了一个MySQL数据库,您可以按照以下方式进行操作(在本示例中,我将数据库命名为氧化物
,用户名为: oxid_admin
,密码为: 氧化_admin_password
):
mysql -u root -p
CREATE DATABASE oxid;
GRANT ALL PRIVILEGES ON oxid.* TO 'oxid_admin'@'localhost' IDENTIFIED BY 'oxid_admin_password';
GRANT ALL PRIVILEGES ON oxid.* TO 'oxid_admin'@'localhost.localdomain' IDENTIFIED BY 'oxid_admin_password';
FLUSH PRIVILEGES;
quit;
因为您可以在http和https下运行您的OXID eShop网站(如果您想提供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; if ($request_method ~ ^(TRACE|TRACK)$ ) { return 403; } location = /favicon.ico { log_not_found off; access_log off; } location = /robots.txt { allow all; log_not_found off; access_log off; } location ~ (/\.|EXCEPTION_LOG\.txt|\.log$|\.tpl$|pkg.rev) { deny all; } location ~ /out/pictures/.*(\.jpg|\.gif|\.png)$ { try_files $uri /core/utils/getimg.php; } location ~ ^/(admin|setup)/?$ { } location ~ /(core|export|modules|out|tmp|views)/ { } location / { try_files $uri $uri/ /oxseo.php; } location = /oxseo.php { if ($args ~ "mod_rewrite_module_is=off") { rewrite /oxseo.php /oxseo.php?mod_rewrite_module_is=on? break; } 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; } 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