Назад | Перейти на главную страницу

nginx не видит MySQL

У меня есть полностью рабочая установка 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 для обоих мест.