今年年初,VMware宣布了CloudFoundry项目,一款平台即服务(PAAS)开源解决方案,其预置提供对MongoDB、MySQL及Redis此类服务的支持。最近它将PostgreSQL和RabbitMQ加入到云服务列表中以便为各应用所使用,同时也提供了一个可运行在单个工作站上的Micro版CloudFoundry。
将PostgreSQL纳入CloudFoundry还是很有趣的,因为它是一个非常有特色的传统数据库,其受众较之MySQL或MongoDB的用户截然不同。为了更好使用PostgreSQL,cloudfoundry并没有直接使用其正常发布的版本而是在vFabric之上定制了一个版本,这在官方博客上有做解释。(译者注:针对云平台对PostgreSQL做了一些优化。)
该博客上给了一个样例说明如何利用Spring Roo在一个Java项目中使用PostgreSQL。我们这里介绍另一种可选方案,针对的Java应用是某个基于Spring使用了JPA的WAR
。
假设你的应用已有的Spring上下文初始化内容如:
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> <property name="persistenceUnitName" value="myJpaManager" /> <property name="dataSource" ref="dataSource"/> </bean> <bean class="org.springframework.jdbc.datasource.DriverManagerDataSource" id="dataSource"> <property name="driverClassName" value="org.postgresql.Driver" /> <property name="url" value="jdbc:postgresql://localhost/postgres" /> <property name="username" value="postgres" /> <property name="password" value="postgres" /> </bean> <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> <property name="entityManagerFactory" ref="entityManagerFactory" /> </bean> <tx:annotation-driven transaction-manager="transactionManager" /> <context:annotation-config />
而META-INF/persistence.xml
文件如:
<persistence xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd" version="1.0"> <persistence-unit name="myJpaManager" transaction-type="RESOURCE_LOCAL"> <provider>org.hibernate.ejb.HibernatePersistence</provider> <properties> <property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect" /> <property name="hibernate.hbm2ddl.auto" value="update" /> </properties> </persistence-unit> </persistence>
多亏了CloudFoundry的自动配置功能,此应用可以被直接上传到CloudFoundry,完全不用做任何修改。
PostgreSQL(包括MySQL和其他平台支持的服务)充分利用了Cloudfoundry提供的自动配置功能。在特定条件下,使用了PostgreSQL的某一本地Java应用可以上传到Cloudfoundry而无需修改任何一行代码。
自动配置利用了Spring核心容器的功能,当下面两个条件都满足的情况下可以生效:
如果满足上述需求,那Cloudfoundry将会自动拦截你的本地数据源,并使用Cloudfoundry服务来代替那些设置在Spring上下文中的值。
剩下唯一要做的就是积极地回答当应用被上传到云上,vmc是何时请求服务绑定的。
对于更加复杂的应用,Spring 3.1预计能增加一个特殊的云命名空间并提供运行时概要支持。
查看英文原文:VMware's CloudFoundry Service Gains Support for PostgreSQL