502 Bad Gateway Nginx Mac OS X Yosemite php56 php-fpm

Mao*_*o8a 5 php mysql nginx php-5.6 osx-yosemite

我正在Mac OS X 上酿造 PHP、MySQL 和 Nginx,但我无法完成这项工作。

知道我做错了什么吗?

phpinfo 正在运行

/log/nginx/access.log

127.0.0.1 - - [14/Mar/2015:21:21:16 -0500] "GET /wp/wp-admin/install.php HTTP/1.1" 502 574 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/43.0.2331.4 Safari/537.36"
Run Code Online (Sandbox Code Playgroud)

/log/virtualhost/error.log

2015/03/14 21:21:16 [error] 82682#0: *59 upstream prematurely closed connection while reading response header from upstream, client: 127.0.0.1, server: localhost, request: "GET /wp/wp-admin/install.php HTTP/1.1", upstream: "fastcgi://unix:/usr/local/var/run/php-fpm/php-fpm.sock:", host: "localhost"
Run Code Online (Sandbox Code Playgroud)

/log/php-fpm.log

[14-Mar-2015 21:21:16] WARNING: [pool www] child 6851 exited on signal 11 (SIGSEGV) after 11147.271614 seconds from start
[14-Mar-2015 21:21:16] NOTICE: [pool www] child 82712 started
Run Code Online (Sandbox Code Playgroud)

我的 Nginx conf /usr/local/etc/nginx/nginx.conf

worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    include sites-enabled/*.conf;
}
Run Code Online (Sandbox Code Playgroud)

我的 Nginx 虚拟服务器 conf /usr/local/etc/nginx/sites-available/local.conf

server {
  listen                *:80;
  server_name           localhost;
  error_log            /log/virtualhost/error.log;
  root                 /server;
  location / {
    try_files  $uri  $uri/  /index.php?$args;
    index index.php;
  }
  location ~ \.php$ {
    fastcgi_index   index.php;
    fastcgi_pass    unix:/usr/local/var/run/php-fpm/php-fpm.sock;
    include         fastcgi_params;
    fastcgi_param   SCRIPT_FILENAME    $document_root$fastcgi_script_name;
    fastcgi_param   SCRIPT_NAME        $fastcgi_script_name;
  }
}
Run Code Online (Sandbox Code Playgroud)

我的 php-fpm conf /usr/local/etc/php/5.6/php-fpm.conf

; Unix user/group of processes
; Note: The user is mandatory. If the group is not set, the default user's group
;       will be used.
;user = _www
;group = _www
listen = /usr/local/var/run/php-fpm/php-fpm.sock
Run Code Online (Sandbox Code Playgroud)

Bar*_*fen 4

我遇到了这个问题,并通过使用不同的选项重新编译 php 解决了它:

brew uninstall php56 && brew install php56 --with-debug --without-apache
Run Code Online (Sandbox Code Playgroud)

原始构建似乎出了问题,可能是那些标志,也可能是工具链。我似乎记得它抱怨第一次没有 xcode cli 工具,然后安装它们并再次运行构建。不管怎样,这对我有用。

FPM 日志中的 SIGSEGV 意味着“分段错误”,这是错误中的错误......我认为 PHP 的内在,不是配置问题......当然,更聪明的人可以对此进行扩展;-)