Cloud Foundry提供的服务实例本质上就是访问信息:IP、端口、用户名、密码等,使用的进程固然可以写死在代码或配置文件里,但是高级1点儿的办法固然是让程序可以自动依照环境适配服务实例信息,切换数据库,消息中间件,云存储等代码连接的位置。这篇先写1下在web.xml里配置了listener的spring程序如何自动获得CF的服务实例信息,示例代码由Maven管理。
在web.xml里配置了以下listener的spring程序,PaaS里绑定的服务信息可以被自动获得,只需要在context配置文件中使用指定的语法定义bean便可。
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
比如,要使用redis服务,只需在context配置文件中定义以下:
<cloud:redis-connection-factory id="redisConnectionFactory"/>
然后在程序中使用下面的代码,便可取得绑定了的redis服务信息:
@Autowired(required=false) RedisConnectionFactory redisConnectionFactory;
Hostname = ((JedisConnectionFactory) redisConnectionFactory).getHostName();
Port = ((JedisConnectionFactory) redisConnectionFactory).getPort());
针对redis,这个bean可以直接通过spring-data-redis进行操作。
由于Spring与Cloud Foundry及其相干服务(如Redis)的兼容问题,不同版本的spring库可能致使兼容性问题,比如spring 3.2.8和spring-cloud 1.0.0放在1起会致使绑定了redis服务的程序没法在PaaS上启动。确保可兼容的版本可参见样例程序(是个Maven工程)的pom.xml。