Серверы · 4 min read · Dec 12, 2025

Идеальный сервер - Fedora 12 x86_64 [ISPConfig 2] - Страница 5

11 Apache2 с PHP, Ruby, Python, WebDAV

Теперь мы устанавливаем Apache с PHP5 (это PHP 5.3.0):

yum install php php-devel php-gd php-imap php-ldap php-mysql php-odbc php-pear php-xml php-xmlrpc php-eaccelerator php-magickwand php-magpierss php-mapserver php-mbstring php-mcrypt php-mhash php-mssql php-shout php-snmp php-soap php-tidy curl curl-devel perl-libwww-perl ImageMagick libxml2 libxml2-devel

Затем редактируем /etc/httpd/conf/httpd.conf:

vi /etc/httpd/conf/httpd.conf

и изменяем DirectoryIndex на

| [...] DirectoryIndex index.html index.htm index.shtml index.cgi index.php index.php3 index.pl [...] |

Теперь настройте вашу систему для автоматического запуска Apache при загрузке:

chkconfig --levels 235 httpd on

Запустите Apache:

/etc/init.d/httpd start

11.1 Отключение PHP глобально

(Если вы не планируете устанавливать ISPConfig на этом сервере, пропустите этот раздел!)

В ISPConfig вы будете настраивать PHP для каждого сайта отдельно, т.е. вы можете указать, какой сайт может запускать PHP-скрипты, а какой нет. Это может работать только если PHP отключен глобально, потому что в противном случае все сайты смогут запускать PHP-скрипты, независимо от того, что вы укажете в ISPConfig.

Чтобы отключить PHP глобально, редактируем /etc/httpd/conf.d/php.conf и закомментируем строки AddHandler и AddType:

vi /etc/httpd/conf.d/php.conf

| # # PHP — это встроенный в HTML язык сценариев, который пытается упростить разработчикам написание динамически генерируемых веб-страниц. # LoadModule php5_module modules/libphp5.so LoadModule php5_module modules/libphp5-zts.so # # Заставьте интерпретатор PHP обрабатывать файлы с расширением .php. # #AddHandler php5-script .php #AddType text/html .php # # Добавьте index.php в список файлов, которые будут обслуживаться как индексы директорий. # DirectoryIndex index.php # # Раскомментируйте следующую строку, чтобы разрешить PHP красиво выводить .phps # файлы как исходный код PHP: # #AddType application/x-httpd-php-source .phps |

После этого мы перезапускаем Apache:

/etc/init.d/httpd restart

11.2 Ruby

Начиная с версии 2.2.20, ISPConfig имеет встроенную поддержку Ruby. Вместо использования CGI/FastCGI, ISPConfig зависит от наличия mod_ruby в Apache сервера.

Для Fedora 12 пакет mod_ruby недоступен, поэтому мы должны скомпилировать его сами. Сначала установим некоторые предварительные зависимости:

yum install httpd-devel ruby ruby-devel

Затем мы загружаем и устанавливаем mod_ruby следующим образом:

cd /tmp  
wget http://modruby.net/archive/mod_ruby-1.3.0.tar.gz  
tar zxvf mod_ruby-1.3.0.tar.gz  
cd mod_ruby-1.3.0/  
./configure.rb --with-apr-includes=/usr/include/apr-1  
make  
make install

Наконец, мы должны добавить модуль mod_ruby в конфигурацию Apache, поэтому создаем файл /etc/httpd/conf.d/ruby.conf…

vi /etc/httpd/conf.d/ruby.conf

| LoadModule ruby_module modules/mod_ruby.so |

… и перезапускаем Apache:

/etc/init.d/httpd restart

Вы можете найти больше деталей о mod_ruby в этой статье.

11.3 Установка mod_python

Чтобы установить mod_python, просто выполните…

yum install mod_python

… и затем перезапустите Apache:

/etc/init.d/httpd restart

11.4 WebDAV

WebDAV должен быть уже включен, но чтобы проверить это, откройте /etc/httpd/conf/httpd.conf и убедитесь, что следующие два модуля активны:

vi /etc/httpd/conf/httpd.conf

| [...] LoadModule dav_module modules/mod_dav.so [...] LoadModule dav_fs_module modules/mod_dav_fs.so [...] |

Если вам нужно изменить /etc/httpd/conf/httpd.conf, не забудьте перезапустить Apache после этого:

/etc/init.d/httpd restart

12 ProFTPd

ISPConfig имеет лучшую поддержку proftpd, чем vsftpd, поэтому давайте удалим vsftpd и установим proftpd:

yum remove vsftpd
yum install proftpd

Теперь мы можем создать системные ссылки для запуска Proftpd и запустить его:

chkconfig --levels 235 proftpd on  
/etc/init.d/proftpd start

13 Webalizer

Чтобы установить webalizer, просто выполните

yum install webalizer

14 Синхронизация системных часов

Если вы хотите, чтобы системные часы синхронизировались с NTP-сервером, выполните следующее:

yum install ntp
chkconfig --levels 235 ntpd on  
ntpdate 0.pool.ntp.org  
/etc/init.d/ntpd start

15 Установка некоторых модулей Perl

ISPConfig поставляется с SpamAssassin, который требует несколько модулей Perl для работы. Мы устанавливаем необходимые модули Perl одной командой:

yum install perl-HTML-Parser perl-DBI perl-Net-DNS perl-Digest-SHA1 perl-ExtUtils-AutoInstall

16 ISPConfig

Конфигурация сервера теперь завершена. Теперь вы можете установить ISPConfig на него, следуя этим инструкциям: http://www.ispconfig.org/manual_installation.htm

Перед установкой ISPConfig есть одна важная вещь, которую вы должны сделать. Откройте /usr/include/stdio.h и замените getline на parseline в строке 653:

vim /usr/include/stdio.h

| [...] /* Как `getdelim', но читает до новой строки. Эта функция не является частью POSIX и, следовательно, не имеет официальной точки отмены. Но из-за сходства с интерфейсом POSIX или из-за реализации это точка отмены и поэтому не помечена как __THROW. */ extern _IO_ssize_t parseline (char **__restrict __lineptr, size_t *__restrict __n, FILE *__restrict __stream) __wur; #endif [...] |

Если вы этого не сделаете, установка завершится неудачей из-за следующей ошибки:

htpasswd.c:101: ошибка: конфликтующие типы для âgetlineâ  
/usr/include/stdio.h:653: примечание: предыдущее объявление âgetlineâ было здесь  
make[2]: * [htpasswd.o] Ошибка 1  
make[2]: Выход из директории `/home/install_ispconfig/compile_aps/apache_1.3.41/src/support'  
make[1]: * [build-support] Ошибка 1  
make[1]: Выход из директории `/home/install_ispconfig/compile_aps/apache_1.3.41'  
make: *** [build] Ошибка 2  
ОШИБКА: Не удалось создать Apache

Вы можете отменить изменения в /usr/include/stdio.h после успешной установки ISPConfig (но не забудьте вернуть его обратно, когда захотите обновить ISPConfig!).

16.1 Примечание о SuExec

Если вы хотите запускать CGI-скрипты под suExec, вы должны указать /var/www как корневую директорию для сайтов, созданных ISPConfig, так как suExec в Fedora скомпилирован с /var/www как Doc_Root. Выполните

/usr/sbin/suexec -V

и вывод должен выглядеть так:

[root@server1 ~]# /usr/sbin/suexec -V  
 -D AP_DOC_ROOT="/var/www"  
 -D AP_GID_MIN=100  
 -D AP_HTTPD_USER="apache"  
 -D AP_LOG_EXEC="/var/log/httpd/suexec.log"  
 -D AP_SAFE_PATH="/usr/local/bin:/usr/bin:/bin"  
 -D AP_UID_MIN=500  
 -D AP_USERDIR_SUFFIX="public_html"  
[root@server1 ~]#

Так что если вы хотите использовать suExec с ISPconfig, не изменяйте корневую директорию по умолчанию (которая является /var/www), если вы используете экспертный режим во время установки ISPConfig (в стандартном режиме вы все равно не сможете изменить корневую директорию, так что вы сможете использовать suExec в любом случае).

17 Ссылки

Share: X/Twitter LinkedIn

Get new posts in your inbox

No spam. Unsubscribe anytime.