首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在Spring Boot的application.properties中使用环境变量

在Spring Boot的application.properties中使用环境变量
EN

Stack Overflow用户
提问于 2016-02-21 10:39:19
回答 8查看 498.8K关注 0票数 293

我们正在开发一个Spring Boot web应用程序,我们使用的数据库是MySQL;

我们的设置是首先测试它

本地

(意味着我们需要在PC上安装MySQL );

然后我们推到Bitbucket;

Jenkins自动检测到Bitbucket的新推送,并在其上进行构建(为了让Jenkins mvn构建通过,我们还需要在运行Jenkins的虚拟机上安装MySQL )。

如果Jenkins构建通过,我们将代码推送到OpenShift上的应用程序(使用Jenkins上的Openshift部署插件)。

我们的问题是,正如你可能已经弄清楚的那样,我们的问题是:

我们不能硬编码MySQL信息。由于我们的项目将在3个不同的地方运行(

本地

詹金斯

,以及

OpenShift

),我们需要使数据源字段在

(我们知道有不同的方法,但我们目前正在研究这个解决方案)。

spring.datasource.url = spring.datasource.username = spring.datasource.password =

我们提出的解决方案是在本地和Jenkins VM中创建系统环境变量(命名方式与OpenShift命名相同),并分别为它们分配正确的值:

代码语言:javascript
运行
复制
export OPENSHIFT_MYSQL_DB_HOST="jdbc:mysql://localhost"
export OPENSHIFT_MYSQL_DB_PORT="3306"
export OPENSHIFT_MYSQL_DB_USERNAME="root"
export OPENSHIFT_MYSQL_DB_PASSWORD="123asd"

我们已经做到了这一点,并且它是有效的。我们还检查了

可以将环境变量转换为java变量,如下所示:

代码语言:javascript
运行
复制
String password = env.get("OPENSHIFT_MYSQL_DB_PASSWORD");   
String userName = env.get("OPENSHIFT_MYSQL_DB_USERNAME");   
String sqlURL = env.get("OPENSHIFT_MYSQL_DB_HOST"); 
String sqlPort = env.get("OPENSHIFT_MYSQL_DB_PORT");

现在剩下的唯一一件事就是我们需要在我们的

,这就是我们遇到麻烦的地方。

我们需要在哪个文件夹中以及如何分配

,以及

变量

为了能够看到它们,以及我们如何将它们包含在

我们尝试了很多方法,其中之一是:

代码语言:javascript
运行
复制
spring.datasource.url = ${sqlURL}:${sqlPort}/"nameofDB"
spring.datasource.username = ${userName}
spring.datasource.password = ${password}

到目前为止还没有发现。我们可能没有将这些环境变量放在正确的类/文件夹中,或者在

..。

EN

Stack Overflow用户

发布于 2020-07-08 08:56:16

如果属性文件被外部化为环境变量,则可以将运行配置添加到IDE中:

票数 1
EN
查看全部 8 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35531661

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档