我们正在开发一个Spring Boot web应用程序,我们使用的数据库是MySQL;
我们的设置是我们首先在本地测试它(意味着我们需要在我们的PC上安装MySQL);
然后我们推送到Bitbucket;
Jenkins自动检测到新的推送到Bitbucket,并在其上进行构建(为了让Jenkins mvn构建通过,我们还需要在运行Jenkins的虚拟机上安装MySQL)。
如果Jenkins构建通过,我们将代码推送到OpenShift上的应用程序(在Jenkins上使用OpenShift部署插件)。
你可能已经发现了,我们的问题是:
在应用程序中。属性我们不能硬编码MySQL信息。由于我们的项目将在3个不同的地方运行(local、Jenkins和OpenShift),我们需要在应用程序中使数据源字段动态。属性(我们知道有不同的方法,但我们现在正在研究这个解决方案)。
spring.datasource.url =
spring.datasource.username =
spring.datasource.password =
我们提出的解决方案是在本地和Jenkins VM中创建系统环境变量(命名方式与OpenShift相同),并分别为它们分配正确的值:
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"
我们已经这么做了,而且很有效。我们还检查了Map<String, String> env = System.getenv();环境变量可以像这样变成Java变量:
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");
现在,我们需要在应用程序中使用这些java变量。属性,这就是我们遇到的麻烦。
我们需要在哪个文件夹中以及如何为应用程序分配密码、userName、sqlURL和sqlPort变量。属性以便能够看到它们以及我们如何在application。Properties中包含它们?
我们尝试了很多东西,其中之一是:
spring.datasource.url = ${sqlURL}:${sqlPort}/"nameofDB"
spring.datasource.username = ${userName}
spring.datasource.password = ${password}
到目前为止还没有。我们可能没有将这些环境变量放在正确的类/文件夹中,或者在application.properties中错误地使用了它们。
我和问题的作者面临着同样的问题。对于我们的案例,这个问题的答案是不够的,因为我的团队中的每个成员都有不同的本地环境,我们肯定需要.gitignore具有不同的db连接字符串和凭据的文件,这样人们就不会错误地提交公共文件并破坏其他人的db连接。
最重要的是,当我们遵循下面的步骤时,它很容易部署到不同的环境中,作为额外的奖励,我们根本不需要在版本控制中保留任何敏感信息。
从具有参数的PHP Symfony 3框架中获得思想。Yml (.gitignored)和parameters.yml.dist(这是通过composer install创建第一个样本),
我结合以下答案中的知识做了以下工作:https://stackoverflow.com/a/35534970/986160和https://stackoverflow.com/a/35535138/986160。
从本质上讲,这让您可以自由地使用spring配置的继承,并通过顶部的配置以及任何额外的敏感凭证选择活动配置文件,如下所示:
application.yml.dist (sample)
spring:
profiles:
active: local/dev/prod
datasource:
username:
password:
url: jdbc:mysql://localhost:3306/db?useSSL=false&useLegacyDatetimeCode=false&serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8
应用程序。yml(。Gitignore-d开发服务器)
spring:
profiles:
active: dev
datasource:
username: root
password: verysecretpassword
url: jdbc:mysql://localhost:3306/real_db?useSSL=false&useLegacyDatetimeCode=false&serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8
应用程序。yml(。Gitignore-d在本地机器上)
spring:
profiles:
active: dev
datasource:
username: root
password: rootroot
url: jdbc:mysql://localhost:3306/xampp_db?useSSL=false&useLegacyDatetimeCode=false&serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8
application-dev。Yml(额外环境特定属性不敏感)
spring:
datasource:
testWhileIdle: true
validationQuery: SELECT 1
jpa:
show-sql: true
format-sql: true
hibernate:
ddl-auto: create-drop
naming-strategy: org.hibernate.cfg.ImprovedNamingStrategy
properties:
hibernate:
dialect: org.hibernate.dialect.MySQL57InnoDBDialect
使用.properties也可以做到这一点
这是获得不同配置的最简单方法
对于不同的环境是使用弹簧配置文件。
参见外部化配置。
这给了你很大的灵活性。
我在我的项目中使用它,它是非常有用的。
在你的情况下,你将有3个配置文件:
" local " " jenkins "和" openshift "
然后你有3个配置文件特定的属性文件:
application-local.properties,
application-jenkins.properties,
和application-openshift.properties
在那里,您可以为相关环境设置属性。
当你运行应用程序时,你必须像这样指定配置文件来激活:
-Dspring.profiles.active =詹金斯
Edit
根据spring文档,可以设置系统环境变量
SPRING_PROFILES_ACTIVE来激活概要文件,而不需要
将其作为参数传递。
有没有办法在运行时为web应用程序传递活动配置文件选项?
不。
Spring将活动概要文件确定为第一步,
在构建应用程序上下文时。
然后使用活动概要文件来决定读取哪些属性文件以及实例化哪些bean。
一旦应用程序启动,就不能更改这一点。
Flyway不识别应用程序中的直接环境变量。属性(Spring-Boot V2.1)。
如
spring.datasource.url=jdbc:mysql://${DB_HOSTNAME}:${DB_PORT}/${DB_DATABASE}
spring.datasource.username=${DB_USER}
spring.datasource.password=${DB_PASS}
为了解决这个问题,我做了这个环境变量,通常我创建文件.env:
SPRING_DATASOURCE_URL=jdbc:mysql://127.0.0.1:3306/place
SPRING_DATASOURCE_USERNAME=root
SPRING_DATASOURCE_PASSWORD=root
并导出变量到我的环境:
export $(cat .env | xargs)
最后运行命令
mvn spring-boot:run
或者运行jar文件
java -jar target/your-file.jar
这里还有另一种方法:https://docs.spring.io/spring-boot/docs/2.1.0.RELEASE/maven-plugin/examples/run-env-variables.html