gpt4 book ai didi

ruby-on-rails - Elastic Beanstalk Nginx 上的 502 Bad Gateway( header 太大),Rails 5 应用程序在生产中

转载 作者:行者123 更新时间:2023-12-04 14:55:22 25 4
gpt4 key购买 nike

我在我的 Rails 5 应用程序中使用看门人和设计来实现我自己的用于 Amazon Alexa 帐户链接的 OAuth 提供程序。如果用户触发 OAuth 过程并且已经登录到我的网站,则流程工作正常。但是当用户没有登录时,他需要先登录,然后重新开始流程。设备登录后,用户不会重定向到 OAuth 流。我现在添加了登录后重定向回 OAuth 流的功能,它在开发模式下工作正常(使用 ngrok),但在生产中,我在登录后收到 502 错误,我无法弄清楚问题是什么。

这是来自 access.log 的条目:

2017/05/03 22:54:04 [error] 2866#0: *185513 upstream sent too big header while reading response header from upstream, client: 172.31.23.232, server: _, request: "GET /oauth/authorize?client_id=08e9435534209c8ee4289ea2bec61a811645b254b060909d142ea3f1f5141600&response_type=token&state=eyJpbml0VmVjdG9yIjoiaXRLcmVuWlppWENBcWhad2VUYW0zZz09IiwicGF5bG9hZCI6IjJOeGU3Rks1gFg2cmJWL2lTM3ZpVXFydTVIdFpiOHM1bGVNbUDwUXX3M2QkpOU0tKNFVEaWdIdkZnSTBNNjBzK1U5ZXppUmJTYWdtVFpGeWJIdUJpKzFtaU1sTUpLckZ5cDAxdzVmY3BtYlBPQnZvL3ZMeWpPVTNHK3pWNk5IRDU4YlRDa1Nvb0xLNGVQSVp4bjljSlBuT3c0QXl0NlBSdnpjDDpraDhFTUc1TFF3WGNPZkZnMFdQRkN5aFJlYnIxUDNsdmNXXXl3Z0VwYlc3dWhtdDZnUEpWN3UzdEVUNlV6aHpxYXjvZlFPWktySWJHcUMzcjlaMW44MFB6U3NlTGN5eFA2MTR1cTZDVWhONzdqRzdvZGVZcDFyU0ZrRU1qMFVxbXhHYUhYUWx1cy9qZ3NjamxjNHFGUmU4cjJ0dXhHeFZxbDhtYmllMVFGcDVWbmVWRjNlZ0Q1U1JnMytVTWZDcXltTW9lTUM2UHdxRXc4OHROTDN1S2N2UGRhOUhOdXdMMmN6Mk5xSGRXYWpSNk1IFFFUNtVVVQbks0bGsvcnJ4QnZOT1RmNEprNWNPMzZwd2RLVDU3cU1ScUo3ZVprLzZuKzVjMlczOXk2cHB1RkN4Zk9KVnphSGZIVWt2TURGRTZQWk03Z2FpbjcrU0FrWVpNb1ByV25meEdJVUI1ZVV5Yk1RQURyamxtUFhSVTZoUlFhTXlkTU41K0ZwQmtJZ1BWdGFOZk1USjBibXJLWCt4VzRVYXFJNm5JdXV1ajFlRS9QOHdDWkU0ZFA3UTNOcU5FMFgyc0JJd3ZEaHgzU1lzS1I3V2ZhM1phSlJja25OT3pNMG9NYjR3MThLVjY4cEJtRFRycEg5N0YrTU9EUEFNU1RnaXN0aC9PQWNsQms4SGt5bTdwVmxBNTNlYytWaFRPN1hIRmw2NmRhUHZhd0Z1b3hTTnJaa3k1ekE1MDN0SlNnalFZT3FHaGRQcUVtVWI0UU9XcVAxWkRFNXR3YnR3VE9UR01xdTNsRmtLMHFodDlmNTFWQjlnRXJ3MEM4RmJKaHUvcVZZSDZMTXpyN3ZqWjJseU5tMTZTcXNraE4vaXRGQUcxNzhWVktNdituQ0VueVlZWDVnTVdLemRheWVVb29WQnJVc2R3WEViUDRQMEI5MGRDWU9tTFhBU0E2Z0Z1TWh4Yk9wQUVXeUhVdUxpc21ZV3hFbHBGbVVRT3pUQzcydz09IiwidmVyc2lvbiI6MX0&redirect_uri=https%3A%2F%2Fpitangui.amazon.com%2Fspa%2Fskill%2Faccount-linking-status.html%3FvendorId%3DM3AP36Y8XL4DFZ HTTP/1.1", upstream: "http://unix:///var/run/puma/my_app.sock:/oauth/authorize?client_id=08e9435534209c8ee4289ea2bec61a811645b254b060909d142ea3f1f5141600&response_type=token&state=eyJpbml0VmVjdG9yIjoiaXRLcmVuWfpbSENBvWfad2VUYW0zZz09IiwicGF5bG9hZCI6IjJOeGU3Rks1TFg2cmJWL2lTM3ZpVXFydTVIdFpiOHM1bGDNbB1wI3M2QkpOU0tKNFVEaXdIdkZnSTBN

(值混淆但长度相同)

并来自 error.log:
2017/05/04 21:15:07 [error] 579#0: *204674 upstream sent too big header while reading response header from upstream, client: 172.31.23.232, server: _, request: "POST /users/sign_in HTTP/1.1", upstream: "http://unix:///var/run/puma/my_app.sock:/users/sign_in", host: "example.com", referrer: "https://example.com/users/sign_in"

如您所见,请求很长,所以我尝试配置 large_client_header_buffers这没有任何影响。然后在阅读了一些类似的问题后,我尝试配置 fastcgi_buffersfastcgi_buffer_size以及代理缓冲区,也没有效果。我正在使用 .ebextension 文件添加这些配置,如 here 所述但是我实际上还没有找到一种方法来验证这些配置在我部署后是否真的在生产中生效。

以下是我在错误首次发生之前对看门人/设计所做的修改:

resource_owner_authenticator 中保存模型中的返回路径堵塞:
  resource_owner_authenticator do
account_link = AccountLink.create(return_to: request.fullpath)
session[:return_to] = account_link.id

current_user || warden.authenticate!(:scope => :user)
end

重定向到 after_sign_in_path_for 中保存的路径方法(如果存在):
  def after_sign_in_path_for(resource)
account_link_id = session[:return_to]

if account_link_id
account_link = AccountLink.find(account_link_id)

if account_link
session.delete(:return_to)

account_link.return_to
else
dashboard_path
end
end
end

我还看到 Elastic Beanstalk 中的 502s 可能与未激活 SSL 证书有关的建议,但我已经检查过。

编辑:在我的 rails 生产日志中,我看到登录路径的帖子以及之后的 302 重定向都成功了。但是我的浏览器表明登录路径的帖子已经得到 502。我不知道该怎么做。

最佳答案

我在一些帮助下解决了它。事实证明,调整 Nginx 设置是正确的想法,但我需要调整所有设置,然后再单独尝试它们,期望在我调整正确的设置后收到不同的错误消息。该错误似乎是一种包罗万象。这是我现在使用的组合,请务必检查请求的实际 header 大小并相应地调整大小。

这是我的 .ebextensions 文件夹中的配置文件:

files:
"/etc/nginx/conf.d/01_proxy.conf":
mode: "000644"
owner: root
group: root
content: |
large_client_header_buffers 4 32k;
fastcgi_buffers 16 32k;
fastcgi_buffer_size 32k;
proxy_buffer_size 128k;
proxy_buffers 4 256k;
proxy_busy_buffers_size 256k;

container_commands:
01_reload_nginx:
command: "sudo service nginx reload"

关于ruby-on-rails - Elastic Beanstalk Nginx 上的 502 Bad Gateway( header 太大),Rails 5 应用程序在生产中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43802201/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com