2013-07-21 4 views
10

Я использую эту конфигурацию на свежую установку php5-FPM и Nginx на Ubuntu 13.04:Мои Nginx + FastCGI загрузки конфигурации PHP файлов вместо выполнения их

server { 
    listen 80 default_server; 
    listen [::]:80 default_server ipv6only=on; 

    root /usr/share/nginx/html; 
    index index.php index.html index.htm; 

    server_name localhost; 

    location/{ 
      try_files $uri $uri/ /index.html; 
    } 

    location /doc/ { 
      alias /usr/share/doc/; 
      autoindex on; 
      allow 127.0.0.1; 
      allow ::1; 
      deny all; 
    } 

    error_page 404 /404.html; 

    location ~ \.php$ { 
      fastcgi_split_path_info ^(.+\.php)(/.+)$; 
      # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini 

      # With php5-cgi alone: 
      fastcgi_pass 127.0.0.1:9000; 
      # With php5-fpm: 
      fastcgi_pass unix:/var/run/php5-fpm.sock; 
      fastcgi_index index.php; 
      include fastcgi_params; 
    } 
} 

Но, мой веб-браузер видящего PHP как текст вместо выполненных результатов. Где я должен искать устранение неполадок?

ответ

8

Ваш php-код отображается непосредственно, потому что он не отправляется в php-движок, это означает, что блок местоположения сопоставляется и файл php обслуживается, но php-файл не захватывается блоком php , поэтому ваша проблема находится в блоке php.

В этом блоке у вас есть 2 fastcgi_pass, один с портом (9000), а другой - в unix-сокет, вы не можете обойтись вместе, но поскольку вы отметили свой вопрос fastcgi, поэтому я буду считать вы используете fastcgi, попробуйте прокомментировать эту строку.

#fastcgi_pass unix:/var/run/php5-fpm.sock; 
+0

Это было странно. Мне удалось увидеть, что fastcgi запущен, но я не смог получить php-вывод, используя любую линию для соединения. Я переустановил все и последовал этому руководству (http://askubuntu.com/questions/134666/what-is-the-easiest-way-to-enable-php-on-nginx), и все, кажется, работает. Благодаря! – arby

2

Похоже, что вы получаете неправильный набор заголовков Content-Type. Вы можете проверить это с помощью различных инструментов. Например, откройте вкладку «Сеть» разработчика «Инструменты» в Chrome, а затем запросите страницу. Вы увидите «Тип содержимого», возвращенный в одном из столбцов, и вы можете щелкнуть по запросу в левом столбце, чтобы увидеть полные заголовки ответов. Я подозреваю, что вы увидите, что возвращаемый заголовок является либо «text/plain», либо «application/octet-stream» вместо text/html, который, вероятно, вам нужен.

Nginx обычно устанавливает заголовок Content-Type по умолчанию на основе расширения. Это делается с помощью директивы types, о которой я не упоминал выше, поэтому вы можете проверить свои настройки там, чтобы подтвердить, что расширение php сопоставляется с текстом/html. Явное назначение заголовка Content-Type в вашем приложении также может помочь.

0

я был в состоянии исправить это обновление моего Nginx виртуальных хостов, изменив

default_type application/octet-stream;

в

default_type text/html;

Смежные вопросы