我有以下问题:我想在我的 docker-compose 文件中为我的数据库连接定义一些环境变量。
services:
myapp:
build: SessionHandler
container_name: sessionhandler
environment:
- JAVA_OPTS=-DdbUrl=10.5.0.1 -DdbPort=3306 -DdbUsername=root -DdbPassword=root
ports:
- "8080:8080"
volumes:
- ./myapp/tomcat/conf/:/opt/tomcat/conf/
我想以这种方式将这些变量用于我的context.xml:
<Context>
<Resource
auth="Container"
driverClassName="com.mysql.jdbc.Driver"
type="javax.sql.DataSource"
initialSize="0"
maxActive="10"
maxIdle="5"
maxWait="5000"
minIdle="0"
timeBetweenEvictionRunsMillis="34000"
minEvictableIdleTimeMillis="55000"
testOnBorrow="true"
testWhileIdle="true"
testOnReturn="false"
validationQuery="SELECT 1 FROM dual"
validationInterval="30000"
removeAbandoned="true"
removeAbandonedTimeout="10"
name="jdbc/myapp"
username="${dbUsername}"
password="${dbPassword}"
url="jdbc:mysql://${dbUrl}:${dbPort}/myapp?useUnicode=true&characterEncoding=UTF-8&characterSetResults=UTF-8"
/>
</Context>
但它不起作用。(浏览器给我一个 500)
如果我在 context.xml 中显式变量,以这种方式:
<Context>
<Resource
auth="Container"
driverClassName="com.mysql.jdbc.Driver"
type="javax.sql.DataSource"
initialSize="0"
maxActive="10"
maxIdle="5"
maxWait="5000"
minIdle="0"
timeBetweenEvictionRunsMillis="34000"
minEvictableIdleTimeMillis="55000"
testOnBorrow="true"
testWhileIdle="true"
testOnReturn="false"
validationQuery="SELECT 1 FROM dual"
validationInterval="30000"
removeAbandoned="true"
removeAbandonedTimeout="10"
name="jdbc/myapp"
username="root"
password="root"
url="jdbc:mysql://10.5.0.1:3306/myapp?useUnicode=true&characterEncoding=UTF-8&characterSetResults=UTF-8"
/>
</Context>
一切正常。谁能帮我?真的谢谢。
更新
我在catalina.properties文件中插入了以下系统变量:
dbUrl=10.5.0.1
dbPort=3306
dbUsername=root
dbPassword=root
和 context.xml
<Resource
auth="Container"
driverClassName="com.mysql.jdbc.Driver"
type="javax.sql.DataSource"
initialSize="0"
maxActive="10"
maxIdle="5"
maxWait="5000"
minIdle="0"
timeBetweenEvictionRunsMillis="34000"
minEvictableIdleTimeMillis="55000"
testOnBorrow="true"
testWhileIdle="true"
testOnReturn="false"
validationQuery="SELECT 1 FROM dual"
validationInterval="30000"
removeAbandoned="true"
removeAbandonedTimeout="10"
name="jdbc/myapp"
username="${dbUsername}"
password="${dbPassword}"
url="jdbc:mysql://${dbUrl}:${dbPort}/myapp?useUnicode=true&characterEncoding=UTF-8&characterSetResults=UTF-8"
/>
并且有效。所以我尝试将它们定义为空,以便将它们定义到 docker-compose.yml 中:
dbUrl=
dbPort=
dbUsername=
dbPassword=
但它不起作用。请问有什么帮助吗?