????????近日同事的一个docker镜像在使用时发现一个问题,springboot应用获取不到一个FeignClient接口的url配置,看下application.yml文件中的相关配置:
aaa:
url: ${AAA_URL:http://xx.xx.xx}
? ? ? ? 本来正常使用是通过AAA_URL这个环境变量来配置url的,所以如果一直使用这种配置不会有任何问题的,但是同事在复制一个服务的docker-compose文件时拷贝了对应的配置,所以问题就来了,导致springboot无法读取到aaa.url配置的值,但是另外一个服务使用aaa.url却没有任何问题,但是同事却一直说这些服务使用的基础配置都一样,所以折腾半天在找原因,最终无果。百度了白天也没找到什么结果,最终去看了这两个服务,发现这两个服务根本不像同事说的那样没有区别,所有服务使用的是同样的公共代码,但是打包使用的Dockerfile却是不一样的。
? ? ? ? 能正常工作的服务使用的CMD? java -jar xxxxx,不能正常工作的服务则是CMD sh -c 这种形式,问题就出在这里:看下docker-library/openjdk的相关描述Add note about OpenJDK, shells, and bad environment variables by tianon · Pull Request #1222 · docker-library/docs · GitHubhttps://github.com/docker-library/docs/pull/1222/commits/f2854b0a019519880f56c2d5226c0121dba13d9c大致意义就是sh -c 在传递环境参数给springboot应用时会自动忽略掉含有.(点号)的环境变量,这个在openjdk:8u131-jre-alpine之后就采取这种处理方式了,因为这种Posix的命名规范是不能含有点号的,所以高级版本的openjdk就忽略掉含有点号的环境变量。实例代码放在了gitee上:
??????bootvars: 该项目用于测试高版本alphine linux不支持sh传递以.分割的环境变量问题,比如spring.mail.host等
PS:
1、使用bash -c 启动springboot应用也能将含点号的环境变量
2、使用sh -c(做好用bash -c代替)就不要使用含有点号的环境变量,完全针对springboot应用完全可以使用大写字符串加下环线的形式代替
参考文章:
1、8u131 Environment Variables with periods (dots) are removed · Issue #135 · docker-library/openjdk · GitHub2With 8u121 lower case environment variables worked, but with 8u131 they do not. Sending lower case environment variables is important because Spring Boot can use them to configure JavaMail, which requires certain lower case properties. F...https://github.com/docker-library/openjdk/issues/135
2、Add note about OpenJDK, shells, and bad environment variables by tianon · Pull Request #1222 · docker-library/docs · GitHubCloses docker-library/openjdk#135https://github.com/docker-library/docs/pull/1222/commits/f2854b0a019519880f56c2d5226c0121dba13d9c3、Could not configure spring.mail.properties using OS env variables · Issue #9902 · spring-projects/spring-boot · GitHubhttps://github.com/spring-projects/spring-boot/issues/99024、GitHub - pluttrell/bootvars: Test project that demonstrates an issue with OpenJDK 8u131 and lower case environment variables.Test project that demonstrates an issue with OpenJDK 8u131 and lower case environment variables. - GitHub - pluttrell/bootvars: Test project that demonstrates an issue with OpenJDK 8u131 and lower case environment variables.https://github.com/pluttrell/bootvars??
|