jjzjj

PHP7 + curl (SSL/TLS) 给出 502 Bad Gateway

coder 2024-04-27 原文

我正在开发一个使用 Dropbox SDK 来做一些事情的网页。其中大部分通过 CLI 发生,但必须在浏览器中完成一件事。不过,我偶然发现了一个有趣的问题。

$dbxClient = new dbx\Client($accountToken, 'xxx/' . VERSION);
$folderMetadata = $dbxClient->getMetadataWithChildren("/");

在 CLI 中运行这段代码效果很好。然而,在浏览器中运行它会给我一个 502。困惑的我启动了 xdebug 并追踪了问题出现的位置。我发现是 Dropbox 的 curl 调用导致的,所以我写了一个小示例脚本来查看 curl 是否有效。 它没有。

<?php
    $ch = curl_init(); 
    curl_setopt($ch, CURLOPT_URL, "https://example.com"); 
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    $output = curl_exec($ch); 

    curl_close($ch);
    echo $output;

在浏览器中运行此代码会立即给出 502。不过,如果我删除 https://或将其设为 http://(或在 CLI 中运行),它会起作用。问题似乎出在 PHP7 + curl + SSL 中。添加 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); 不起作用。

我该怎么做才能找出发生这种情况的原因以及我该如何解决?

系统信息:

  • OS X 10.11.2
  • nginx 1.8.0,通过自制软件安装
  • PHP 7.0.3,通过自制软件安装
  • curl 7.43.0,通过自制软件安装
  • OpenSSL 1.0.2f,通过自制软件安装

最佳答案

Sooo...经过大量调查,我终于找到了解决方案。希望这对 future 的 Google 员工有所帮助。

第 1 步:调查正在发生的事情。

由于我使用的是自制软件的 php70 软件包,因此 OS X 上的目录与 Linux 上的目录略有不同。我需要找到 php-fpm.conf。通过检查自制软件创建的 homebrew.*.plist 文件,我发现它位于 /usr/local/etc/php/7.0/php-fpm.conf 中。

在那之后,我寻找了二进制文件,幸运的是,它也在 plist 中记录下来了。对我来说,它在 /usr/local/opt/php70/sbin/php-fpm 中。

我修改了配置文件,在/var/log/php-fpm.log中写了一个日志文件:

log_level = notice
error_log = /var/log/php-fpm.log

我给了 /var/log/php-fpm.log chmod 0777(因为我懒),再次启动 php-fpm (launchctl load -w/path/to/php-fpm.plist) 并跟踪新的日志文件:tail -f/var/log/php-fpm.log

这是我发现的(以及 Google 员工可能寻找的):

WARNING: [pool www] child 28580 exited on signal 11 (SIGSEGV) after 1.726773 seconds from start

所以发生了段错误。


第 2 步:修复 SIGSEGV

使用新发现的信息,我用谷歌搜索了段错误的可能原因。我在前几页上找不到任何有用的信息,但在后面的其中一页上,我找到了这个链接:https://stackoverflow.com/a/34951784/1486930

它说的是:

I experienced same problem early and fixed it with running php-fpm as root.

You just killed me. Running php-fpm as root just works well! Thanks!!

这就是我所做的。我再次停止了 php-fpm 并以 root 身份手动运行它:

sudo /usr/local/opt/php70/sbin/php-fpm --fpm-config /usr/local/etc/php/7.0/php-fpm.conf

看,它有效!我不知道为什么会这样,但确实以 root 身份运行它“修复”了它。

希望对您有所帮助。

关于PHP7 + curl (SSL/TLS) 给出 502 Bad Gateway,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35672234/

有关PHP7 + curl (SSL/TLS) 给出 502 Bad Gateway的更多相关文章

  1. ruby-on-rails - 如何优雅地重启 thin + nginx? - 2

    我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server

  2. ruby - 使用 `+=` 和 `send` 方法 - 2

    如何将send与+=一起使用?a=20;a.send"+=",10undefinedmethod`+='for20:Fixnuma=20;a+=10=>30 最佳答案 恐怕你不能。+=不是方法,而是语法糖。参见http://www.ruby-doc.org/docs/ProgrammingRuby/html/tut_expressions.html它说Incommonwithmanyotherlanguages,Rubyhasasyntacticshortcut:a=a+2maybewrittenasa+=2.你能做的最好的事情是:

  3. ruby - 如何计算 Liquid 中的变量 +1 - 2

    我对如何计算通过{%assignvar=0%}赋值的变量加一完全感到困惑。这应该是最简单的任务。到目前为止,这是我尝试过的:{%assignamount=0%}{%forvariantinproduct.variants%}{%assignamount=amount+1%}{%endfor%}Amount:{{amount}}结果总是0。也许我忽略了一些明显的东西。也许有更好的方法。我想要存档的只是获取运行的迭代次数。 最佳答案 因为{{incrementamount}}将输出您的变量值并且不会影响{%assign%}定义的变量,我

  4. arrays - Ruby 数组 += vs 推送 - 2

    我有一个数组数组,想将元素附加到子数组。+=做我想做的,但我想了解为什么push不做。我期望的行为(并与+=一起工作):b=Array.new(3,[])b[0]+=["apple"]b[1]+=["orange"]b[2]+=["frog"]b=>[["苹果"],["橙子"],["Frog"]]通过推送,我将推送的元素附加到每个子数组(为什么?):a=Array.new(3,[])a[0].push("apple")a[1].push("orange")a[2].push("frog")a=>[[“苹果”、“橙子”、“Frog”]、[“苹果”、“橙子”、“Frog”]、[“苹果”、“

  5. += 的 Ruby 方法 - 2

    有没有办法让Ruby能够做这样的事情?classPlane@moved=0@x=0defx+=(v)#thisiserror@x+=v@moved+=1enddefto_s"moved#{@moved}times,currentxis#{@x}"endendplane=Plane.newplane.x+=5plane.x+=10putsplane.to_s#moved2times,currentxis15 最佳答案 您不能在Ruby中覆盖复合赋值运算符。任务在内部处理。您应该覆盖+,而不是+=。plane.a+=b与plane.a=

  6. ruby - 在 Ubuntu 14.04 中使用 Curl 安装 RVM 时出错 - 2

    我试图在Ubuntu14.04中使用Curl安装RVM。我运行了以下命令:\curl-sSLhttps://get.rvm.io|bash-sstable出现如下错误:curl:(7)Failedtoconnecttoget.rvm.ioport80:Networkisunreachable非常感谢解决此问题的任何帮助。谢谢 最佳答案 在执行curl之前尝试这个:echoipv4>>~/.curlrc 关于ruby-在Ubuntu14.04中使用Curl安装RVM时出错,我们在Stack

  7. Ruby SSL 错误 - sslv3 警报意外消息 - 2

    我正在尝试在ruby​​脚本中连接到服务器https://www.xpiron.com/schedule。但是,当我尝试连接时:require'open-uri'doc=open('https://www.xpiron.com/schedule')我收到以下错误消息:OpenSSL::SSL::SSLError:SSL_connectreturned=1errno=0state=SSLv2/v3readserverhelloA:sslv3alertunexpectedmessagefrom/usr/local/lib/ruby/1.9.1/net/http.rb:678:in`conn

  8. ruby - Sinatra + Heroku + Datamapper 使用 dm-sqlite-adapter 部署问题 - 2

    出于某种原因,heroku尝试要求dm-sqlite-adapter,即使它应该在这里使用Postgres。请注意,这发生在我打开任何URL时-而不是在gitpush本身期间。我构建了一个默认的Facebook应用程序。gem文件:source:gemcuttergem"foreman"gem"sinatra"gem"mogli"gem"json"gem"httparty"gem"thin"gem"data_mapper"gem"heroku"group:productiondogem"pg"gem"dm-postgres-adapter"endgroup:development,:t

  9. ruby - 如何在非 SSL 或 http 网站上使用 Stripe? - 2

    我正在使用Rails3.2.6和Stipe进行支付。是否有可能在不购买ssl证书的情况下进行付款。我可以使用Stripe页面作为我的支付页面吗? 最佳答案 您可以使用stripe.js在技术上跳过SSL但我强烈建议您设置SSL。它所做的是将信用卡信息直接传递给stripe,然后stripe会给你一个token,用于实际进行收费。这样做意味着信用卡信息永远不会接触您的服务器,您不必担心PCI合规性。但是,您仍应设置SSL以防止中间人攻击。您可以在https://stripe.com/docs/tutorials/forms找到有关如何

  10. ruby - Ruby 中字符串运算符 + 和 << 的区别 - 2

    我是Ruby和这个网站的新手。下面两个函数是不同的,一个在函数外修改变量,一个不修改。defm1(x)x我想确保我理解正确-当调用m1时,对str的引用被复制并传递给将其视为x的函数。运算符当调用m2时,对str的引用被复制并传递给将其视为x的函数。运算符+创建一个新字符串,赋值x=x+"4"只是将x重定向到新字符串,而原始str变量保持不变。对吧?谢谢 最佳答案 String#+::str+other_str→new_strConcatenation—ReturnsanewStringcontainingother_strconc

随机推荐