使用 nginx 作为代理的 Spring Boot 应用程序部署在 Heroku 上

Posted

技术标签:

【中文标题】使用 nginx 作为代理的 Spring Boot 应用程序部署在 Heroku 上【英文标题】:Springboot application with nginx as proxy deploy on Heroku 【发布时间】:2018-09-26 01:58:41 【问题描述】:

我正在尝试使用 nginx 作为 Heroku 上的代理部署 Spring Boot 应用程序。如果前面没有 nginx,我可以毫无问题地部署应用程序,但是当我尝试使用 https://github.com/heroku/heroku-buildpack-nginx 构建包添加 nginx 时,应用程序会获取部署文件,但它会崩溃并显示以下错误消息。根据我在日志中阅读的内容,这是因为 Spring Boot 应用程序和 nginx 都尝试使用相同的端口而不是使用单独的端口。

2018-04-14T17:09:24.427513Z app[web.1]: buildpack=nginx at=nginx-start
2018-04-14T17:09:24.440105Z app[web.1]: nginx: [emerg] bind() to 0.0.0.0:10949 failed (98: Address already in use)
2018-04-14T17:09:24.440137Z app[web.1]: 2018/04/14 17:09:24 [emerg] 159#0: bind() to 0.0.0.0:10949 failed (98: Address already in use)
2018-04-14T17:09:24.940239Z app[web.1]: nginx: [emerg] bind() to 0.0.0.0:10949 failed (98: Address already in use)
2018-04-14T17:09:24.940285Z app[web.1]: 2018/04/14 17:09:24 [emerg] 159#0: bind() to 0.0.0.0:10949 failed (98: Address already in use)
2018-04-14T17:09:25.440529Z app[web.1]: nginx: [emerg] bind() to 0.0.0.0:10949 failed (98: Address already in use)
2018-04-14T17:09:25.440569Z app[web.1]: 2018/04/14 17:09:24 [emerg] 159#0: bind() to 0.0.0.0:10949 failed (98: Address already in use)
2018-04-14T17:09:25.940679Z app[web.1]: nginx: [emerg] bind() to 0.0.0.0:10949 failed (98: Address already in use)
2018-04-14T17:09:25.940746Z app[web.1]: 2018/04/14 17:09:24 [emerg] 159#0: bind() to 0.0.0.0:10949 failed (98: Address already in use)
2018-04-14T17:09:26.440833Z app[web.1]: nginx: [emerg] bind() to 0.0.0.0:10949 failed (98: Address already in use)
2018-04-14T17:09:26.440876Z app[web.1]: 2018/04/14 17:09:24 [emerg] 159#0: bind() to 0.0.0.0:10949 failed (98: Address already in use)
2018-04-14T17:09:26.940976Z app[web.1]: nginx: [emerg] still could not bind()
2018-04-14T17:09:26.941031Z app[web.1]: 2018/04/14 17:09:24 [emerg] 159#0: still could not bind()
2018-04-14T17:09:26.941552Z app[web.1]: buildpack=nginx at=exit process=nginx
2018-04-14T17:09:26.946943Z system[web.1]: Process exited (exit status 1)
2018-04-14T17:09:26.965949+00:00 system[web.1]: State changed from up to crashed

下面是我已有的 procfile,请注意,如果我删除 nginx 部分,它可以正常工作,应用程序可以正常工作,但如果我将 nginx 保留在两者之间,则无法正常工作。

web: bin/start-nginx java -D server.port=$PORT -jar target/some-test-0.0.1-SNAPSHOT.jar

我的 nginx 配置与 buildpack 中提到的几乎相同。 https://github.com/ryandotsmith/nginx-buildpack/blob/master/config/nginx.conf.erb位置。

有人可以帮忙解决这个问题吗?

【问题讨论】:

【参考方案1】:

我能够使用以下更改解决此问题。我对 nginx 配置文件进行了以下更改。

nginx buildpack 的默认更改如下:

upstream app_server 
    server unix:/tmp/nginx.socket fail_timeout=0;

我们已将这些配置文件更改如下。

upstream app_server 
   server localhost:<%= ENV["APP_PORT"] %> fail_timeout=0;

下面还有我添加了新环境变量 APPLICATION_PORT 的 proc 文件更改,它为我解决了这个问题。

web: bin/start-nginx java -Dserver.port=$APP_PORT -jar target/dashery-complete-0.0.1-SNAPSHOT.jar

【讨论】:

以上是关于使用 nginx 作为代理的 Spring Boot 应用程序部署在 Heroku 上的主要内容,如果未能解决你的问题,请参考以下文章

spring-boo hello world程序

nginx代理转发url接口请求路径到spring boot后端实现真正响应

nginx代理转发url接口请求路径到spring boot后端实现真正响应

使用nginx对spring boot项目进行代理

NGINX 反向代理背后的 Spring Boot API REST

使用 nginx 作为 websocket 连接的代理