我正在尝试在 Openshift 上部署 Grails 应用程序。我正在使用本地构建的战争文件部署应用程序。现在,我正在使用 DataSource.groovy 文件中 rhc-app-show 命令给出的 url 进行数据库配置。每当我尝试使用 Openshift 的环境变量(例如 $OPENSHIFT_MYSQL_DB_HOST)时,它都会崩溃。关于如何在配置文件中使用它们的任何想法或指示?
谢谢。
我正在尝试在 Openshift 上部署 Grails 应用程序。我正在使用本地构建的战争文件部署应用程序。现在,我正在使用 DataSource.groovy 文件中 rhc-app-show 命令给出的 url 进行数据库配置。每当我尝试使用 Openshift 的环境变量(例如 $OPENSHIFT_MYSQL_DB_HOST)时,它都会崩溃。关于如何在配置文件中使用它们的任何想法或指示?
谢谢。
我没有使用过 OpenShift,但 Google 将我带到了显示这些环境变量的常见问题解答:
OPENSHIFT_MYSQL_DB_HOST
OPENSHIFT_MYSQL_DB_PASSWORD
OPENSHIFT_MYSQL_DB_USERNAME
OPENSHIFT_MYSQL_DB_URL
OPENSHIFT_MYSQL_DB_PORT
所以看起来这会起作用:
production {
dataSource {
driverClassName = 'com.mysql.jdbc.Driver'
dialect = org.hibernate.dialect.MySQL5InnoDBDialect
String host = System.getenv('OPENSHIFT_MYSQL_DB_HOST')
String port = System.getenv('OPENSHIFT_MYSQL_DB_PORT')
String dbName = System.getenv('OPENSHIFT_APP_NAME')
url = "jdbc:mysql://$host:$port/$dbName"
username = System.getenv('OPENSHIFT_MYSQL_DB_USERNAME')
password = System.getenv('OPENSHIFT_MYSQL_DB_PASSWORD')
properties {
...
}
}
}
缺少的部分是数据库名称 - 这是您可以使用的吗?我不确定的格式,OPENSHIFT_MYSQL_DB_URL
但看起来你可能只是能够使用url = "jdbc:${System.getenv('OPENSHIFT_MYSQL_DB_URL')}"
production {
dataSource {
dbCreate = "update"
driverClassName = "org.postgresql.Driver"
dialect = org.hibernate.dialect.PostgreSQLDialect
uri = new URI(System.getenv('OPENSHIFT_POSTGRESQL_DB_URL'))
url = "jdbc:postgresql://"+uri.host+uri.path+"/"+System.getenv('OPENSHIFT_APP_NAME')
username = System.getenv('OPENSHIFT_POSTGRESQL_DB_USERNAME')
password = System.getenv('OPENSHIFT_POSTGRESQL_DB_PASSWORD')
}
production {
dataSource {
dbCreate = "update"
driverClassName = "org.postgresql.Driver"
dialect = org.hibernate.dialect.PostgreSQLDialect
uri = new URI(System.getenv('OPENSHIFT_POSTGRESQL_DB_URL').toString())
appname = System.getenv('OPENSHIFT_APP_NAME').toString()
url = "jdbc:postgresql://"+uri.host.toString()+uri.path.toString()+"/"+appname
username = System.getenv('OPENSHIFT_POSTGRESQL_DB_USERNAME').toString()
password = System.getenv('OPENSHIFT_POSTGRESQL_DB_PASSWORD').toString()
}
在 Grails 3.0.11 中,文件 application.yml
System.getenv 不起作用,所以我不得不手动配置 mysql 中数据库的 url 连接......使用文档命令https://developers.openshift.com/en/managing-port-forwarding.html
dataSource:
dbCreate: update
url : jdbc:mysql://thisIsTheUrlGetWithPort-ForwardCommandAndThePort:48381/server?verifyServerCertificate=false&autoReconnect=true&useSSL=false&requireSSL=false
driverClassName: com.mysql.jdbc.Driver
dialect: org.hibernate.dialect.MySQL5InnoDBDialect
username : admin9CzsS #this is a username example
password : RR7y9uKw3t #this is a password example
properties:
jmxEnabled: true
initialSize: 5
maxActive: 50
minIdle: 5
maxIdle: 25
maxWait: 10000
maxAge: 600000
timeBetweenEvictionRunsMillis: 5000
minEvictableIdleTimeMillis: 60000
validationQuery: SELECT 1
validationQueryTimeout: 3
validationInterval: 15000
testOnBorrow: true
testWhileIdle: true
testOnReturn: false
jdbcInterceptors: ConnectionState
defaultTransactionIsolation: 2 # TRANSACTION_READ_COMMITTED