如何设置Apache2与mod_fcgid和PHP5在Ubuntu 8.10

如何设置Apache2与mod_fcgid和PHP5在Ubuntu 8.10 本教程介绍如何使用mod_fcgid安装Apache2 和PHP5在Ubuntu上...

如何在Ubuntu 8.10中使用mod_fcgid和PHP5设置Apache2

版本1.0
作者:Falko Timme

本教程介绍如何在Ubuntu 8.10上安装带有mod_fcgid和PHP5的Apache2。 mod_fcgid是旧的mod_fastcgi的兼容替代方案。 它允许您使用其所有者的权限执行PHP脚本,而不是Apache用户。

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

1初步说明

本教程中使用的是Ubuntu 8.10服务器,主机名为server1.example.com ,IP地址为192.168.0.100

我将在本教程www.example1.comwww.example2.com中创建两个Apache vhost,以演示mod_fcgid的用法。

确保您以root身份登录:

sudo su

/ bin / sh/ bin / dash的符号链接,但是我们需要/ bin / bash ,not / bin / dash 。 所以我们这样做:

ln -sf /bin/bash /bin/sh

除此之外,我们必须禁用AppArmor:

/etc/init.d/apparmor stop
update-rc.d -f apparmor remove
apt-get remove apparmor apparmor-utils

2安装Apache2 / mod_fcgi / PHP5

为了安装Apache2,mod_fcgid和PHP5,运行

apt-get install apache2 apache2-suexec libapache2-mod-fcgid php5-cgi

如果Apache2已经安装了PHP5作为Apache模块,请立即禁用PHP5模块:

a2dismod php5

然后启用以下模块...

a2enmod rewrite
a2enmod suexec
a2enmod include
a2enmod fcgid

...并打开/etc/php5/cgi/php.ini

vi /etc/php5/cgi/php.ini

在文件末尾添加行cgi.fix_pathinfo = 1

[...]
cgi.fix_pathinfo = 1

然后重新加载Apache:

/etc/init.d/apache2 force-reload

3为www.example1.com和www.example2.com创建Vhosts

现在我将创建两个vhosts: www.example1.com (使用文档root / var / www / web1 / web )和www.example2.com (使用文档root / var / www / web2 / web )。 www.example1.com将由用户和组web2由用户和组web1www.example2.com所有。

首先我们创建用户和组:

groupadd web1
groupadd web2
useradd -s /bin/false -d /var/www/web1 -m -g web1 web1
useradd -s /bin/false -d /var/www/web2 -m -g web2 web2

然后,我们创建文档根,并使其由用户/组web1或它们拥有。 web2

mkdir -p /var/www/web1/web
chown web1:web1 /var/www/web1/web
mkdir -p /var/www/web2/web
chown web2:web2 /var/www/web2/web

我们将使用suExec运行PHP; suExec的文档根目录是/ var / www ,如下所示:

/usr/lib/apache2/suexec -V

root@server1:~# /usr/lib/apache2/suexec -V
 -D AP_DOC_ROOT="/var/www"
 -D AP_GID_MIN=100
 -D AP_HTTPD_USER="www-data"
 -D AP_LOG_EXEC="/var/log/apache2/suexec.log"
 -D AP_SAFE_PATH="/usr/local/bin:/usr/bin:/bin"
 -D AP_UID_MIN=100
 -D AP_USERDIR_SUFFIX="public_html"
root@server1:~#

因此,我们不能直接调用PHP二进制( / usr / lib / cgi-bin / php ),因为它位于suExec的文档根目录之外。 由于suExec不允许符号链接,解决问题的唯一方法是为/ var / www子目录中的每个网站创建一个包装脚本; 然后包装脚本将调用PHP二进制文件/ usr / lib / cgi-bin / php 。 包装器脚本必须由每个网站的用户和组拥有,因此我们需要每个网站的一个包装器脚本。 我将在/ var / www / php-fcgi-scripts的子目录中创建包装器脚本,例如/ var / www / php-fcgi-scripts / web1/ var / www / php-fcgi-scripts / web2

mkdir -p /var/www/php-fcgi-scripts/web1
mkdir -p /var/www/php-fcgi-scripts/web2

vi /var/www/php-fcgi-scripts/web1/php-fcgi-starter

#!/bin/sh
PHPRC=/etc/php5/cgi/
export PHPRC
export PHP_FCGI_MAX_REQUESTS=5000
export PHP_FCGI_CHILDREN=8
exec /usr/lib/cgi-bin/php

vi /var/www/php-fcgi-scripts/web2/php-fcgi-starter

#!/bin/sh
PHPRC=/etc/php5/cgi/
export PHPRC
export PHP_FCGI_MAX_REQUESTS=5000
export PHP_FCGI_CHILDREN=8
exec /usr/lib/cgi-bin/php

PHPRC行包含php.ini文件所在的目录(即/ etc / php5 / cgi /转换为/etc/php5/cgi/php.ini )。 PHP_FCGI_MAX_REQUESTS是在fcgid进程停止并启动新请求之前的最大请求数。 PHP_FCGI_CHILDREN定义将启动的PHP子代数

php-fcgi-starter脚本必须是可执行的,它们(以及它们所在的目录)必须由网站的用户和组拥有:

chmod 755 /var/www/php-fcgi-scripts/web1/php-fcgi-starter
chmod 755 /var/www/php-fcgi-scripts/web2/php-fcgi-starter
chown -R web1:web1 /var/www/php-fcgi-scripts/web1
chown -R web2:web2 /var/www/php-fcgi-scripts/web2

现在我们为www.example1.comwww.example2.com创建Apache vhosts:

vi /etc/apache2/sites-available/web1

<VirtualHost *:80>
  ServerName www.example1.com
  ServerAlias example1.com
  ServerAdmin webmaster@example1.com
  DocumentRoot /var/www/web1/web/

  <IfModule mod_fcgid.c>
    SuexecUserGroup web1 web1
    PHP_Fix_Pathinfo_Enable 1
    <Directory /var/www/web1/web/>
      Options +ExecCGI
      AllowOverride All
      AddHandler fcgid-script .php
      FCGIWrapper /var/www/php-fcgi-scripts/web1/php-fcgi-starter .php
      Order allow,deny
      Allow from all
    </Directory>
  </IfModule>

  # ErrorLog /var/log/apache2/error.log
  # CustomLog /var/log/apache2/access.log combined
  ServerSignature Off

</VirtualHost>

a2ensite web1

vi /etc/apache2/sites-available/web2

<VirtualHost *:80>
  ServerName www.example2.com
  ServerAlias example2.com
  ServerAdmin webmaster@example2.com
  DocumentRoot /var/www/web2/web/

  <IfModule mod_fcgid.c>
    SuexecUserGroup web2 web2
    PHP_Fix_Pathinfo_Enable 1
    <Directory /var/www/web2/web/>
      Options +ExecCGI
      AllowOverride All
      AddHandler fcgid-script .php
      FCGIWrapper /var/www/php-fcgi-scripts/web2/php-fcgi-starter .php
      Order allow,deny
      Allow from all
    </Directory>
  </IfModule>

  # ErrorLog /var/log/apache2/error.log
  # CustomLog /var/log/apache2/access.log combined
  ServerSignature Off

</VirtualHost>

a2ensite web2

确保您填写正确的路径(以及SuexecUserGroup行中正确的用户和组)。

之后重新加载Apache:

/etc/init.d/apache2 reload