1

问题:当我在我的上下文 XML 中嵌入环境变量时,当我在本地运行时它们会被扩展。但是当我在 OpenShift 上部署时,他们没有。他们决定为空。

配置:web.xml:

<context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>/WEB-INF/springapp.xml</param-value>
</context-param>

springapp.xml:

<bean id="datasource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://#{systemProperties['OPENSHIFT_MYSQL_DB_HOST']}:#{systemProperties['OPENSHIFT_MYSQL_DB_PORT']}/prepare?characterEncoding=UTF-8"/>
        <property name="username"  value="AAA"/>
        <property name="password" value="BBB"/>
</bean>

pom.xml:

  • 春季版 3.2.0.RELEASE

本地开发环境:

  • Intellij(配置中设置的环境变量)
  • 雄猫7

OpenShift 环境:

  • 雄猫 7 (JBoss EWS 2.0)
  • OpenShift 设置的环境变量。我用“env”命令确认了这些值。
    OPENSHIFT_MYSQL_DB_PORT=3306
    OPENSHIFT_MYSQL_DB_HOST=127.3.xxx.yyy

OpenShift 上的消息(注意服务器和端口为空):

org.apache.commons.dbcp.SQLNestedException:无法为连接 URL 'jdbc:mysql://:/prepare?characterEncoding=UTF-8' 创建类 'com.mysql.jdbc.Driver' 的 JDBC 驱动程序

4

1 回答 1

1

我为本地开发和 OpenShift JBoss 配置的解决方案。

我终于放弃了尝试扩展环境变量。与直接 tomcat 一起工作得很好,但与 JBoss 完全没有关系。所以我改用Nam的方法。

正如 Nam 所说,OpenShift 在 context.xml 中创建了正确的 jdbc 连接。所以我在本地机器上也需要同样的东西。我通过将其放置在 /usr/local/Cellar/tomcat/7.0.39/libexec/conf/context.xml 中来复制它:

<Resource name="jdbc/MysqlDS"
              url="jdbc:mysql://localhost:3306/prepare?characterEncoding=UTF-8"
              driverClassName="com.mysql.jdbc.Driver"
              username="AAA"
              password="BBB"
              auth="Container"
              type="javax.sql.DataSource"
              maxActive="20"
              maxIdle="5"
              maxWait="10000"
              />

然后我<bean id=datasource... 从 springapp.xml 中删除。

最后,我将 sessionFactory 的 dataSource 属性更改为:

<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
    <property name="dataSource">
        <bean class="org.springframework.jndi.JndiObjectFactoryBean">
            <property name="jndiName" value="jdbc/MysqlDS"/>
            <property name="resourceRef" value="true"/>
        </bean>
    </property>
    <property name="packagesToScan" value="com.xxx.yyy.zzz"/>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect"> org.hibernate.dialect.MySQLMyISAMDialect</prop>
            <prop key="hibernate.show_sql">false</prop>
        </props>
    </property>
</bean>

现在,tomcat 的 context.xml 负责本地配置。spring bean 定义具有适当的信息。

于 2013-09-04T15:11:07.500 回答