疯狂java


您现在的位置: 疯狂软件 >> 新闻资讯 >> 正文

部署Spring与数据库的应用到CloudFoundry


 

 将Spring应用部署到CloudFoundry.com很简单,就像SpringSource网站说的那样在注册申请到Cloud Foundry beta账号后,第一件事请就是在STS for Eclipse中安装CloudFoundry的支持。这里有一份博客详细的说明了如何安装,这里就不在赘述。

为了部署运行一个使用数据库的应用,要比部署一个单独的应用多一点步骤,但也只是一点。

为了给应用分配数据库资源,首先必须声明使用的是哪个数据源。在Eclipse中打开Cloud Foundry server点击add按钮打开service控制盘。

在接下来的界面中,选择数据源的类型和名称。点击"Finish"按钮,这样,数据源就注册了。

在注册一个数据源后,需要告诉应用使用哪个数据源。简单的直接将数据源拖到Application Services面板。

以上就是服务器所需要的所有的配置。在部署应用之前,还需要一些改变以指定哪里需要数据源。

因为我部署的是一个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="springframework.org/schema/beans"



xmlns:cloud="schema.cloudfoundry.org/spring"



schema.cloudfoundry.org/spring

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控制应用的部署,启动和停止