我正在尝试使用 grails 教程将我的应用程序连接到共享数据库 5MB。我正在使用 grails 2.1.0。在我的本地机器上,当我运行 heroku config 时,我可以看到 DATABASE_URL 已设置,但是在执行 git push 之后...我的构建停止并出现错误:
Error packaging application: Error loading DataSource.groovy: null (Use --stacktrace to see the full trace)
Failed to build app
Heroku push rejected, failed to compile Grails app
因此,我添加了日志记录以查看环境在 heroku 上的外观。我已将 println System.env 添加到 Datasource.groovy,但找不到任何 DATABASE_URL:
.[OLDPWD:/app/tmp/repo.git/.cache, SHELL:/bin/bash, SHLVL:2, GIT_DIR:., JAVA_HOME:/usr/lib/jvm/java-6-openjdk, PATH:/app/tmp/repo.git/.cache/.grails/bin::/usr/local/bin:/usr/local/sbin:/usr/bin:/bin:/usr/sbin:/sbin, SSH_CLIENT:XXX, MAIL:XXX, USER:XXX, LOG_TOKEN:t.9e79a5be-dfa2-446e-9f83-f6b4ebbc4eb7, GRAILS_HOME:/app/tmp/repo.git/.cache/.grails, PWD:XXX, HOME:/app/, LOGNAME:u11846, _:/app/tmp/repo.git/.cache/.grails/bin/grails, SSH_CONNECTION:XXX, LD_LIBRARY_PATH:/usr/lib/jvm/java-6-openjdk/jre/lib/amd64/server:/usr/lib/jvm/java-6-openjdk/jre/lib/amd64:/usr/lib/jvm/java-6-openjdk/jre/../lib/amd64]
我已经检查了 Heroku 插件,为我的应用程序安装了共享数据库:
heroku addons
=== XXX Configured Add-ons
shared-database:5mb
当我执行 heroku config
heroku config
=== Config Vars for XXX
DATABASE_URL: postgres://XXX
JAVA_OPTS: -Xmx384m -Xss512k -XX:+UseCompressedOops
SHARED_DATABASE_URL: postgres://XXX
数据源.groovy:
production {
dataSource {
dbCreate = "update"
driverClassName = "org.postgresql.Driver"
dialect = org.hibernate.dialect.PostgreSQLDialect
println System.env
println System.env.DATABASE_URL
uri = new URI(System.env.DATABASE_URL)
println uri
url = "jdbc:postgresql://" + uri.host + uri.path
username = uri.userInfo.split(":")[0]
password = uri.userInfo.split(":")[1]
}
}
在 BuildConfig.groovy 我添加了
runtime 'postgresql:postgresql:8.4-702.jdbc3'
我可以在 DATABASE_URL 设置为本地 postgresql 的情况下在本地启动应用程序。我正在建造战争并在码头上运行它。
谁能告诉我我错过了什么?