如何将 GAE 连接到 Amazon RDS?

Joh*_*tos 5 mysql google-app-engine google-eclipse-plugin amazon-web-services amazon-rds

我在 Amazon RDS 上有一个配置的数据库实例:

亚马逊 RDS 实例

我的 VPC 安全组,入站和出站配置如下:

专有网络安全组

我的 VPC DNS 解析和 DNS 主机名已激活。我可以连接到这个实例并从 MySQLWorkbench 毫无问题地执行查询。我在我的 GAE Eclipse 中使用 persistence.xml 配置它:

 <persistence-unit name="myworld">
   <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider > 

   <!--             MODELS            -->
   ...

   <properties>
       <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
       <property name="javax.persistence.jdbc.url" value="jdbc:mysql://myworld.cy3caqn3kkz0.eu-west-1.rds.amazonaws.com:3306/myworld"/>
       <property name="javax.persistence.jdbc.user" value="myworld"/>
       <property name="javax.persistence.jdbc.password" value="******"/>
       <property name="eclipselink.target-database" value="org.eclipse.persistence.platform.database.MySQLPlatform" />
   </properties>  
Run Code Online (Sandbox Code Playgroud)

还有我的 appengine_web.xml:

<threadsafe>true</threadsafe>

 <system-properties>
    <property name="java.util.logging.config.file" value="WEB-INF/logging.properties"/>
    <property name="ae-cloudsql.cloudsql-database-url" value="jdbc:mysql://myworld.cy3caqn3kkz0.eu-west-1.rds.amazonaws.com:3306/myworld?user=myworld&amp;password=******" />
    <property name="cloudsql.url" value="jdbc:mysql://myworld.cy3caqn3kkz0.eu-west-1.rds.amazonaws.com:3306/myworld?user=myworld&amp;password=******"/>
 </system-properties>
Run Code Online (Sandbox Code Playgroud)

当我在本地启动我的 GAE 项目时,我能够连接和执行查询,一切正常,但是当我在线部署它时,我收到以下异常:

Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.5.1.v20130918-f2b9fc5): org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Could not create connection to database server.
Error Code: 0
Run Code Online (Sandbox Code Playgroud)

我已经阅读了很多关于 stackoverflow 的帖子、博客、问题和答案,但我没有弄清楚我做错了什么。

拜托,一旦我在过去一周内尝试修复它,任何建议、线索、提示都会非常感激。

谢谢你们!

Joh*_*tos 1

我终于可以让它工作了!这对我来说听起来很愚蠢,但对于遇到同样问题的人来说可能很有用。项目及其配置一切都很好,我唯一没有做的就是激活我的 PROJECT 的计费

是的,您在 GAE 上创建帐户后即可激活计费帐户,但在创建项目时,您需要将项目计费链接到已创建的计费帐户。

就是这样。我希望它对其他人有帮助。