Spring boot 在spring boot应用程序中使用pivotal cloud foundry redis和rabbitmq服务作为vcap服务
我能够使用pivotal上的REDIS和RABBITMQ服务。绑定服务时,我能够获取凭据并在我的application.properties for spring boot项目中使用该凭据 但我使用的这个配置在application.Properties中是硬编码的 为了动态地进行配置,我知道我们可以使用pivotal提供的vcap服务 因此,我们希望为redis和rabbimq使用运行时凭据 下面是我的代码供参考 应用程序、属性Spring boot 在spring boot应用程序中使用pivotal cloud foundry redis和rabbitmq服务作为vcap服务,spring-boot,redis,rabbitmq,spring-jms,cloud-foundry,Spring Boot,Redis,Rabbitmq,Spring Jms,Cloud Foundry,我能够使用pivotal上的REDIS和RABBITMQ服务。绑定服务时,我能够获取凭据并在我的application.properties for spring boot项目中使用该凭据 但我使用的这个配置在application.Properties中是硬编码的 为了动态地进行配置,我知道我们可以使用pivotal提供的vcap服务 因此,我们希望为redis和rabbimq使用运行时凭据 下面是我的代码供参考 应用程序、属性 rabbitmq.host=hostname rabbitmq.
rabbitmq.host=hostname
rabbitmq.virtual-host=vhostanme
rabbitmq.username=username
rabbitmq.password=password
rabbit.mainqueue=abhi
rabbit.errorqueue=abc
redis.host=redishostname
redis.port=port
redis.password=password
我的配置类:
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
@Component
public class Config {
static String rabbitMqHost;
static String rabbitMqVHost;
static String rabbitMqUsername;
static String rabbitMqPassword;
static String rabbitMqMainQueue;
static String rabbitMqErrorQueue;
static String redisHost;
static int redisPort;
static String redisPassword;
Config() {
}
public static String getRedisHost() {
return redisHost;
}
public static void setRedisHost(String redisHost) {
Config.redisHost = redisHost;
}
public static int getRedisPort() {
return redisPort;
}
public static void setRedisPort(int redisPort) {
Config.redisPort = redisPort;
}
public static String getRedisPassword() {
return redisPassword;
}
public static void setRedisPassword(String redisPassword) {
Config.redisPassword = redisPassword;
}
public static String getRabbitMqMainQueue() {
return rabbitMqMainQueue;
}
public static void setRabbitMqMainQueue(String rabbitMqMainQueue) {
Config.rabbitMqMainQueue = rabbitMqMainQueue;
}
public static String getRabbitMqErrorQueue() {
return rabbitMqErrorQueue;
}
public static void setRabbitMqErrorQueue(String rabbitMqErrorQueue) {
Config.rabbitMqErrorQueue = rabbitMqErrorQueue;
}
public static String getRabbitMqHost() {
return rabbitMqHost;
}
public static void setRabbitMqHost(String rabbitMqHost) {
Config.rabbitMqHost = rabbitMqHost;
}
public static String getRabbitMqVHost() {
return rabbitMqVHost;
}
public static void setRabbitMqVHost(String rabbitMqVHost) {
Config.rabbitMqVHost = rabbitMqVHost;
}
public static String getRabbitMqUsername() {
return rabbitMqUsername;
}
public static void setRabbitMqUsername(String rabbitMqUsername) {
Config.rabbitMqUsername = rabbitMqUsername;
}
public static String getRabbitMqPassword() {
return rabbitMqPassword;
}
public static void setRabbitMqPassword(String rabbitMqPassword) {
Config.rabbitMqPassword = rabbitMqPassword;
}
@Value("${rabbitmq.host}")
public void setRabbitMqHosts(String url) {
setRabbitMqHost(url);
}
@Value("${rabbitmq.virtual-host}")
public void setRabbitMqVHosts(String url) {
setRabbitMqVHost(url);
}
@Value("${rabbitmq.username}")
public void setRabbitUsernames(String url) {
setRabbitMqUsername(url);
}
@Value("${rabbitmq.password}")
public void setRabbitPasswords(String url) {
setRabbitMqPassword(url);
}
@Value("${rabbit.mainqueue}")
public void setRabbitMainQueues(String url) {
setRabbitMqMainQueue(url);
}
@Value("${rabbit.errorqueue}")
public void setRabbitErrorQueues(String url) {
setRabbitMqErrorQueue(url);
}
@Value("${redis.host}")
public void setRedisHosts(String url) {
setRedisHost(url);
}
@Value("${redis.port}")
public void setRedisPorts(int url) {
setRedisPort(url);
}
@Value("${redis.password}")
public void setRedisPasswords(String url) {
setRedisPassword(url);
}
}
我的MessagesConsumer类,在该类中我使用该压缩从rabbitmq jms队列获取消息并保存到redis:
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import javax.annotation.PostConstruct;
import javax.jms.ConnectionFactory;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.Session;
import org.json.JSONObject;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import com.es.consumer.config.Config;
import com.rabbitmq.jms.admin.RMQConnectionFactory;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisShardInfo;
@Component
public class MessagesConsumer {
@Autowired
JmsTemplate jmsTemplate;
final Logger logger = LoggerFactory.getLogger(MessagesConsumer.class);
Jedis jedis;
JedisShardInfo shardInfo;
@PostConstruct
public void init() {
shardInfo = new JedisShardInfo(Config.getRedisHost(), Config.getRedisPort());
shardInfo.setPassword(Config.getRedisPassword());
jedis = new Jedis(shardInfo);
jedis.connect();
jedis.select(2);
}
@Bean
ConnectionFactory connectionFactory() {
RMQConnectionFactory connectionFactory = new RMQConnectionFactory();
connectionFactory.setUsername(Config.getRabbitMqUsername());
connectionFactory.setPassword(Config.getRabbitMqPassword());
connectionFactory.setVirtualHost(Config.getRabbitMqVHost());
connectionFactory.setHost(Config.getRabbitMqHost());
return connectionFactory;
}
@SuppressWarnings("rawtypes")
@Scheduled(fixedRate = 1)
public void readQueueAndSaveData() {
// take message process it and save to redis as hmset
}}
任何帮助都是值得的。有两种方法。 1) 从application.properties中删除所有属性,并编写一个配置bean来为您创建RedisTemplate和RabbitTemplatebean。这些设备所需的工厂属性可从VCAP_服务获得。在CF上,VCAP_SERVICES env变量将包含绑定到应用程序的服务信息。当你推送应用程序时,将redis、rabbit服务绑定到你的空间中,那么它们的属性在VCAP_服务中可用。因此,只需在代码中执行
System.getEnv(“VCAP_SERVICES”)
,然后解析json以获取服务细节以创建模板
2) 从application.properties中删除属性,并使用SpringCloudConnector。SpringCloud有一个名为SpringCloudConnectors的子项目,它提供连接到各种云服务的实用程序
http://cloud.spring.io/spring-cloud-connectors/spring-cloud-spring-service-connector.html#_rabbitmq
只需定义一个扩展AbstractCloudConfig的类,如下所示
class CloudConfig extends AbstractCloudConfig {
@Bean
public RabbitConnectionFactory rabbitFactory() {
return connectionFactory().rabbitConnectionFactory("rabbit-servicename");
}
@Bean
public RedisConnectionFactory redisFactory() {
return connectionFactory().redisConnectionFactory("redis-servicename");
}
}
如果您使用的是Spring,则首选第二种方法,因为它需要的编码非常少,并且可以轻松切换到不同的云提供商。我可以获取@Bean public RabbitConnectionFactory rabbitFactory(){return connectionFactory().RabbitConnectionFactory(“RabbitServiceName”);}的依赖项吗我尝试过的依赖项是:org.springframework.amqp spring rabbit 1.6.8.RELEASE,但我想用HMSET将redis中的数据保存为散列,但我认为redis模板不支持HMSET。要使用的依赖项是。org.springframework.cloud
rabbitFactory
方法的返回类型应为ConnectionFactory代码>(org.springframework.amqp.rabbit.connection.ConnectionFactory),而不是RabbitConnectionFactory。有关更多详细信息,请参阅。