我有一个托管在App 中的站点(A),需要由另一个站点(B)在其他地方访问proxy_pass。
以前,这个站点(A)是在Kubernetes中托管的,入口配置看起来是这样的,它完美地工作了:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: webapp
annotations:
kubernetes.io/ingress.class: "nginx"
spec:
rules:
- host: my-webapp.com
http:
paths:
- path: /
backend:
serviceName: webapp
servicePort: 80
- host: www.remote-server.com
http:
paths:
- path: /
backend:
serviceName: webapp
servicePort: 80这样,通过将www.emote-server.com添加到主机列表中,就可以通过nginx proxy_pass呈现my-webapp.com。
现在,我的问题是,我们如何在App灵活环境(nodejs运行时)中配置相同的东西?--如果我们在App中没有任何特殊的配置来尝试这一点的话:

这是因为远程服务器(在这种情况下它是用于测试的本地主机)不允许代理到App服务(这是我的假设)。
作为参考,这是我在本地用于测试以下内容的nginx配置:
server {
listen 8080;
server_name localhost;
root /path/to/folder/;
location / {
index index.html index.htm;
}
location /shopping {
proxy_set_header Host $host;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass https://url-to-my-appengine-app.appspot.com;
proxy_redirect default;
}
}我希望这是有意义的。
发布于 2018-09-08 18:57:14
我不相信应用程序引擎灵活环境上的底层码头形象运行时使用NGINX作为web服务器,因此您可能会追求一条在部署时无法工作的路径,即使您让它在本地工作。
我相信,为了在您的情况下启用CORS支持,您必须在应用程序的代码中而不是在配置文件中设置Access-Control-Allow-Origin头。
https://stackoverflow.com/questions/52226519
复制相似问题