У меня есть полностью рабочая установка Joomla 2.5.6, управляемая локальным сервером MySQL, но я хотел бы протестировать nginx, чтобы узнать, работает ли он быстрее, чем Apache.
Кажется, Nginx установил нормально через yum, он может обрабатывать файл PHP-info через FastCGI отлично (http://37.128.190.241/php.php), но когда я останавливаю Apache, запускаю вместо этого nginx и посещаю свой сайт, я получаю: «Ошибка подключения к базе данных (1): адаптер MySQL 'mysqli' недоступен».
Я попытался настроить свой Joomla configuration.php для использования mysql вместо mysqli, но получаю ту же основную ошибку, только на этот раз «Ошибка подключения к базе данных (1): адаптер MySQL 'mysql', конечно, недоступен»!
Может кто подумает, в чем может быть проблема пожалуйста? Я попытался явно установить extension = mysqli.so и extension = mysql.so в моем php.ini, чтобы попытаться вызвать проблему (несмотря на то, что php -m показывает, что они оба были успешно загружены в любом случае) - без разницы.
У меня довольно стандартный nginx default.conf:
server {
listen 80;
server_name www.MYDOMAIN.com;
server_name_in_redirect off;
access_log /var/log/nginx/localhost.access_log main;
error_log /var/log/nginx/localhost.error_log info;
root /var/www/html/MYROOT_DIR;
index index.php index.html index.htm default.html default.htm;
# Support Clean (aka Search Engine Friendly) URLs
location / {
try_files $uri $uri/ /index.php?q=$uri&$args;
}
# deny running scripts inside writable directories
location ~* /(images|cache|media|logs|tmp)/.*\.(php|pl|py|jsp|asp|sh|cgi)$ {
return 403;
error_page 403 /403_error.html;
}
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include /etc/nginx/fastcgi.conf;
}
# caching of files
location ~* \.(ico|pdf|flv)$ {
expires 1y;
}
location ~* \.(js|css|png|jpg|jpeg|gif|swf|xml|txt)$ {
expires 14d;
}
}
Фрагмент вывода из phpinfo под nginx:
Server API FPM/FastCGI
Virtual Directory Support disabled
Configuration File (php.ini) Path /etc
Loaded Configuration File /etc/php.ini
Scan this dir for additional .ini files /etc/php.d
Additional .ini files parsed /etc/php.d/curl.ini, /etc/php.d/fileinfo.ini, /etc/php.d/json.ini, /etc/php.d/phar.ini, /etc/php.d/zip.ini
Фрагмент вывода phpinfo под Apache:
Server API Apache 2.0 Handler
Virtual Directory Support disabled
Configuration File (php.ini) Path /etc
Loaded Configuration File /etc/php.ini
Scan this dir for additional .ini files /etc/php.d
Additional .ini files parsed /etc/php.d/curl.ini, /etc/php.d/fileinfo.ini, /etc/php.d/json.ini, /etc/php.d/mysql.ini, /etc/php.d/mysqli.ini, /etc/php.d/pdo.ini, /etc/php.d/pdo_mysql.ini, /etc/php.d/pdo_sqlite.ini, /etc/php.d/phar.ini, /etc/php.d/sqlite3.ini, /etc/php.d/zip.ini
Похоже, что с Apache PHP загружает значительно больше дополнительных файлов .ini, в том числе относящихся к mysql (mysql.ini, mysqli.ini, pdo_mysql.ini), чем nginx.
Есть идеи, как заставить nginix называть эти дополнительные .ini?
Заранее спасибо,
Стив
Вам нужно проверить установку вашей версии php-fpm / FastCGI для nginx, судя по всему, у вас не включены mysql и mysqli для этой конкретной установки.
Если у вас установлена одна и та же версия php как для Apache, так и для nginx с одинаковой потоковой настройкой (либо ZTS включен для обоих, либо отключен для обоих), вам просто нужно скопировать mysql.so
и mysqli.so
из extension_dir
установки Apache в extension_dir
установки nginx php-fpm / FastCGI, которую вы можете легко получить, открыв phpinfo()
php сначала в Apache, затем в nginx.
После этого вам необходимо включить эти модули в php-fpm / FastCGI, если они не включены в /etc/php.d/
каталог просто укажите это прямо в /etc/php.ini
добавив следующие строки:
extension=mysql.so
extension=mysqli.so
И перезапустите php-fpm.
Есть разные файлы php.ini для apache и fcgi. проверьте папку конфигурации php (/ etc / php5 в ubuntu), и вы увидите как минимум две папки apache2 и cli. Убедитесь, что в обоих файлах включен драйвер mysql. Также убедитесь, что у вас есть ini-файлы в conf.d для обоих мест.