在Nginx(LEMP)上运行简单的组件在Debian Squeeze / Ubuntu 11.10

在Debian Squeeze / Ubuntu 11.10上运行Nginx(LEMP)上的简单组件

本教程将介绍如何在安装了nginx而不是Apache的Debian Squeeze或Ubuntu 11.10系统上安装和运行Simple Groupware (LEMP = L inux + nginx(发音为“ e ngine x”)+ M ySQL + P HP)。 Simple Groupware是一个开放源码的企业集团,提供电子邮件,日历,联系人,任务,文档管理,项目管理,与Outlook和手机的同步,全文搜索,扩展等等。 nginx是一个HTTP服务器,比Apache使用的资源少得多,并且提供了更快的网页,特别是静态文件。

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

1初步说明

我想使用文件根/var/www/www.example.com/web在名为www.example.com / example.com的虚拟机中安装Simple Groupware

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

Ubuntu用户注意事项:

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

sudo su

2配置PHP

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

APC可以安装如下:

apt-get install php-apc

我们还需要为Simple Groupware安装以下先决条件:

apt-get install catdoc ppthtml imagemagick unzip poppler-utils mp3info exiv2 graphviz php5-gd

现在我们必须配置PHP以允许大的上传 - 默认值是2MB不是很多。 我想把这个限制提高到512MB。 打开你的php.ini - 如果你使用PHP-FPM,它是/etc/php5/fpm/php.ini ...

vi /etc/php5/fpm/php.ini

...如果你使用spawn-fcgi,它是/etc/php5/cli/php.ini

vi /etc/php5/cli/php.ini
[...]
memory_limit = 512M
[...]
post_max_size = 512M
[...]
upload_max_filesize = 512M
[...]

如果您使用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安装简单组件

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

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

接下来,我们从http://www.simple-groupware.de/cms/Download下载Simple Groupware安装程序脚本,并将其放在我们的文档根目录中:

cd /var/www/www.example.com/web
wget http://downloads.sourceforge.net/project/simplgroup/simplegroupware%20installer/0.8/sgs_installer.php.gz
gunzip sgs_installer.php.gz

建议使用作为用户www-data和group www-data运行的nginx守护进程将文档根和Simple Groupware安装程序写入:

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

如果您还没有为Simple Groupware(包括MySQL Simple Groupware用户)创建了一个MySQL数据库,则可以按照以下方式进行操作(在此示例中我命名数据库sgware ,用户称为sgware_admin ,而且他的密码是sgware_admin_password ):

mysqladmin -u root -p create sgware
mysql -u root -p
GRANT ALL PRIVILEGES ON sgware.* TO 'sgware_admin'@'localhost' IDENTIFIED BY 'sgware_admin_password';
GRANT ALL PRIVILEGES ON sgware.* TO 'sgware_admin'@'localhost.localdomain' IDENTIFIED BY 'sgware_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;
       }

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

       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 1000M;
       dav_methods PUT DELETE MKCOL COPY MOVE;
       create_full_put_path on;
       dav_access user:rw group:rw all:r;

       # WebDAV server
       location ~ ^/sgdav {
                rewrite . /bin/webdav.php;
       }
       # CMS real URLs
       location ~ ^/cms/ {
                rewrite ^/cms/ext/(.*)$ /bin/ext/cms/$1 last;
                rewrite ^/cms/thumbs/(.*)$ /bin/preview.php?filename=$1 last;
                rewrite ^/cms/(.*?)/file/(.*)$ /bin/cms.php?page=$1&file=$2 last;
                rewrite ^/cms/(.*)$ /bin/cms.php?page=$1 last;
       }
       # Root
       location = / {
                if ($request_method = "OPTIONS") {
                   rewrite . /bin/webdav.php last;
                }
                try_files /bin/index.php /src/index.php /sgs_installer.php =404;

                include /etc/nginx/fastcgi_params;
                fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
                fastcgi_pass   127.0.0.1:9000; # use spawn-fcgi (!!)
       }
       # Root PHP /*.php
       location ~ ^/([^/]+\.php)$ {
                try_files /bin/$1 /src/$1 $uri =404;
                include /etc/nginx/fastcgi_params;
                fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
                fastcgi_pass   127.0.0.1:9000; # use spawn-fcgi (!!)
       }
       # sgs src/*.php bin/*.php
       location ~ ^/(src|bin)/([^/]+\.php|ext/.+\.php)$ {
                include /etc/nginx/fastcgi_params;
                fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
                fastcgi_pass   127.0.0.1:9000; # use spawn-fcgi (!!)
       }
       # Redirect static files
       location ~ ^/(src/|bin/)?(ext/.*|docs/.*)$ {
                try_files /custom/$2 /ext/$2 /bin/$2 /src/$2 $uri =404;
       }
       # Drop all other stuff
       location / {
                if (!-f $request_filename) { return 404; }
                #return 403;
       }
}

要启用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
赞(52) 打赏
未经允许不得转载:优客志 » 系统运维
分享到:

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

支付宝扫一扫打赏

微信扫一扫打赏