将Spring应用部署到CloudFoundry.com很简单,就像SpringSource网站说的那样在注册申请到Cloud Foundry beta账号后,第一件事请就是在STS for Eclipse中安装CloudFoundry的支持。这里有一份博客详细的说明了如何安装,这里就不在赘述。
为了部署运行一个使用数据库的应用,要比部署一个单独的应用多一点步骤,但也只是一点。
以上就是服务器所需要的所有的配置。在部署应用之前,还需要一些改变以指定哪里需要数据源。
因为我部署的是一个Spring 应用,我需要改动 application context文件将数据源指定到Cloud Foundry的数据库,而不是指向本地。在Cloud Foundry的云上使用数据库带来的好处就是,你不用再去配置数据库了,你所需要的就是配置一下应用中的servlet-context.xml文件中的数据源。
这里看一下本地的配置:
对于本地的部署来讲配置通常看起来像这样:
- <bean id="dataSource"
- class="org.springframework.jdbc.datasource.DriverManagerDataSource"
- p:driverClassName="${jdbc.driverClassName}"
- p:url="${jdbc.url}" />
而对于在Cloud Foundry上的MySQL数据库配置是这样:
- <cloud:data-source id="dataSource" />
Spring3.1包含了一个新特性允许这些配置放在同一个context文件中,但是在Spring3中并没有这个特性,我们需要将规则的数据源配置(传统的)和新的cloud data-source的方式配置数据源中选择其中一种。
要使用新的cloud标签,servlet-context.xml需要做相关改变引入cloud 命名空间。
- <beans xmlns="http://www.springframework.org/schema/beans"
- ... xmlns:cloud="http://schema.cloudfoundry.org/spring"
- ... http://schema.cloudfoundry.org/spring
- http://schema.cloudfoundry.org/spring/cloudfoundry-spring-0.6.xsd">
部署应用的最后一步是添加Cloud Foundry的支持。可以通过在应用的pom.xml文件中添加以下依赖的方式添加Cloud Foundry支持。
- <!-- CloudFoundry -->
- <dependency>
- <groupId>org.cloudfoundry</groupId>
- <artifactId>cloudfoundry-runtime</artifactId>
- <version>${org.cloudfoundry-version}</version>
- </dependency>
- <properties>
- <org.cloudfoundry-version>0.6.0</org.cloudfoundry-version>
- </properties>
在这些改变都OK后,Cloud Foundry应用就可以通过STS for eclipse控制应用的部署,启动和停止。