我设法用phpMyAdmin在所有的OpenShift上建立MySQL数据库。 我被告知我的数据库的主机名和端口分别是$ OPENSHIFT_MYSQL_DB_HOST和$ OPENSHIFT_MYSQL_DB_PORT,我把它放在我的context.xml文件中:
<context-param>
<param-name>driver</param-name>
<param-value>com.mysql.jdbc.Driver</param-value>
</context-param>
<context-param>
<param-name>url</param-name>
<param-value>jdbc:mysql://$OPENSHIFT_MYSQL_DB_HOST:$OPENSHIFT_MYSQL_DB_PORT/burgerjoint</param-value>
</context-param>
<context-param>
<param-name>user</param-name>
<param-value>admin******</param-value>
</context-param>
<context-param>
<param-name>password</param-name>
<param-value>*********</param-value>
</context-param>
设置连接的代码是:
public void contextInitialized(ServletContextEvent event) {
// Connect
String driver = event.getServletContext().getInitParameter(PARAM_DRIVER);
String url = event.getServletContext().getInitParameter(PARAM_URL);
String username = event.getServletContext().getInitParameter(PARAM_USERNAME);
String password = event.getServletContext()
.getInitParameter(PARAM_PASSWORD);
try {
Class.forName(driver);
Connection connection = DriverManager.getConnection(url, username,
password);
event.getServletContext().setAttribute(ATTR_CONNECTION, connection);
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
}
但问题是服务器上的连接为空,我不明白为什么。我做错什么了吗?当我在localhost上尝试时,代码可以正常工作。据我所知,我有所有必要的库:
感谢您的帮助:)
更新
我修改了连接代码,如下所示:
{
if (connection != null) return connection;
try
{
Properties dbProperties = new Properties();
InputStream input = DatabaseUtil.class.getClassLoader().getResourceAsStream(DB_PROPERTIES_FILE);
dbProperties.load(input);
String url = "";
if (appIsDeployed)
{
String host = System.getenv("$OPENSHIFT_MYSQL_DB_HOST");
String port = System.getenv("$OPENSHIFT_MYSQL_DB_PORT");
String name = "burgerjoint";
url = "jdbc:mysql://" + host + ":" + port + "/" + name;
} else
{
url = dbProperties.getProperty(PARAM_URL);
}
String driver = dbProperties.getProperty(PARAM_DRIVER);
String username = dbProperties.getProperty(PARAM_USERNAME);
String password = dbProperties.getProperty(PARAM_PASSWORD);
Class.forName(driver);
connection = DriverManager.getConnection(url, username, password);
但它仍然提供null连接。 System.getenv("$OPENSHIFT_MYSQL_DB_HOST")
和System.getenv("$OPENSHIFT_MYSQL_DB_PORT")
的值为null。
答案 0 :(得分:4)
这是不正确的:
jdbc:mysql://$OPENSHIFT_MYSQL_DB_HOST:$OPENSHIFT_MYSQL_DB_PORT/burgerjoint
这个美元符号表示你认为一个合适的主机和数据库名称将被替换,但事实并非如此。
对主机和数据库名称进行编码以查看它是否有效,然后了解.properties文件以将其外部化。
答案 1 :(得分:2)
删除美元符号:
String host = System.getenv("OPENSHIFT_MYSQL_DB_HOST");
String port = System.getenv("OPENSHIFT_MYSQL_DB_PORT");
它会很好用(我在我的机器和OpenShift上测试过它)。
答案 2 :(得分:0)
请您先尝试启动端口转发。
rhc port-forward -a your-app-name
一旦开始,不要杀死这个cmd&amp;只需使用生成的本地地址/端口。
答案 3 :(得分:0)
如果您使用的是MySQL盒式磁带,则连接到数据库的信息位于应用程序的环境变量中。如果您使用JDBC pure,则需要先检索值。 e.g:
String host = System.getenv("OPENSHIFT_MYSQL_DB_HOST");
String port = System.getenv("OPENSHIFT_MYSQL_DB_PORT");
String username = System.getenv("OPENSHIFT_MYSQL_DB_USERNAME");
String password = System.getenv("OPENSHIFT_MYSQL_DB_PASSWORD");
String url = String.format(":mysql://%s:%s/jbossas", host, port);
Connection conn = DriverManager.getConnection(url, username, password);
字符串url中的jbossas
是架构。更改您的架构(burgerjoint
)。