1

我使用默认的内存 h2 数据库在本地开发了我的应用程序。一切都很完美。

现在我尝试通过推送到 Heroku 来部署我的应用程序。

在此之前,我使用以下行将 Procfile 添加到我的应用程序的根文件夹中:

web: target/start -Dhttp.port=${PORT} -DapplyEvolutions.default=true -Ddb.default.url=${DATABASE_URL} -Ddb.default.driver=org.postgresql.Driver

我的 application.conf 看起来像:

db.default.driver=org.h2.Driver
db.default.url="jdbc:h2:mem:play;MODE=PostgreSQL"

所以我推动了它,然后,当我尝试访问我的应用程序时,我得到:

Salieri:addressManager administrator$ heroku ps
=== web (1X): `target/start -Dhttp.port=${PORT} -DapplyEvolutions.default=true -Ddb.default.url=${DATABASE_URL} -Ddb.default.driver=org.postgresql.Driver`
web.1: crashed 2013/06/27 22:04:16 (~ 4m ago)

在heroku日志中:

2013-06-27T20:04:14.511136+00:00 app[web.1]: [error] play - ERROR: syntax error at or near "user"
2013-06-27T20:04:14.515578+00:00 app[web.1]: at play.api.db.evolutions.Evolutions$.databaseEvolutions(Evolutions.scala:334)
2013-06-27T20:04:14.515153+00:00 app[web.1]: @6emdb57b1: Database 'default' is in inconsistent state!

我试图删除整个数据库

heroku pg:reset HEROKU_POSTGRESQL_ROSE_URL

然后我又推了一次,但没有成功。

不得不提的是,我之前做过推送,当时我的应用是在 Heroku 上运行的。唯一的问题是,我无法使用我的设备中提供的凭据登录(Global.java 文件,在应用程序启动时有一个工作)。

有什么建议么?

4

2 回答 2

0

PostgreSQL 解释user为关键字。如果您app/models/User的应用程序中有一个类,play 将尝试创建一个名为user. 避免这种情况的最简单方法是将您的User类重命名为MyUser. (如果您在其中一个类中使用名为 user 的属性,也会发生同样的情况。在这里,您也应该重命名它)。

然后您应该在本地运行您的应用程序并在浏览器中打开它,以便更新进化脚本文件。然后,您可以在 中找到进化脚本conf/evolutions/default/1.sql。根据这个例子,它应该创建一个名为my_usernow 的表。

于 2013-08-08T14:26:20.597 回答
0

从这个错误:

ERROR: syntax error at or near "user"

我猜你的进化脚本是错误的。User是 SQL 中的保留字。请尝试在开发 PostgreSQL 数据库中本地运行 Evolution 脚本。工作后,您可以尝试再次部署。

我还建议禁用生产应用程序的演进,有时这是一个有风险的系统。

于 2013-06-28T14:19:49.340 回答