Google应用引擎TCP连接失败

时间:2018-02-26 16:02:55

标签: java spring-boot tcp google-cloud-platform app-engine-flexible

部署到谷歌应用引擎的Spring启动应用程序和对端点的请求正确地响应了预期的硬编码文本。除了公开的默认端口8080之外,还会公开另一个TCP:8595,其中数据可以通过跟踪设备发布到该端口。

问题是当我测试得到与telnet projectid.appspot.com 8595的tcp连接时,我得到了这个响应Connecting To projectid.appspot.com...Could not open connection to the host, on port 8595: Connect failed,在本地认为连接没有失败。

应用程序引擎中托管的应用程序如何公开端口?

免责声明:我是App Engine和GCP的新手

1 个答案:

答案 0 :(得分:6)

正如docs中所述,您应该可以在app.yaml中设置端口转发,然后通过防火墙规则公开它。

1.。)端口转发

network:
  forwarded_ports:
    - 2222/tcp

调试思路:使用AppEngine Flex,您可以通过SSH进入实例进行进一步调试(App Engine>实例,实例旁边的SSH按钮)。

登录后,您应该能够运行此docker命令以查看暴露的端口(在我的情况下,我在app.yaml中暴露了8081):

$ sudo docker port gaeapp
8080/tcp -> 172.17.0.1:8080
8081/tcp -> 0.0.0.0:8081

您甚至可以检查它是否收听(在我的情况下,它是正确回复的HTTP服务404):

curl localhost:8081
{"timestamp":1519837414455,"status":404,"error":"Not Found","message":"No message available","path":"/"}

(对于telnet,您需要使用sudo apt-get update && sudo apt-get install -y telnet

进行安装

如果显示您的端口,则下一步是仔细检查您的防火墙设置。

2.。)防火墙设置

gcloud compute firewall-rules create myrule --allow=tcp:8595 --source-ranges=0.0.0.0/0

但是,这只会让您直接通过VM实例IP访问您的应用程序!(您可以在控制台中找到您的IP或列出您的实例gcloud compute instances list

请参阅docs

中的forwarded_ports说明
  

forwarded_ports 可选。您可以从实例转发端口   (HOST_PORT)到Docker容器(CONTAINER_PORT)。如果你只是   指定一个PORT,然后App Engine假定它是相同的端口   主机和容器。默认情况下,TCP和UDP流量都是   转发。 流量必须直接发送到目标实例   而不是通过appspot.com域或您的自定义域。