gpt4 book ai didi

spring-boot - 在 spring boot 应用程序中使用关键的 cloud foundry redis 和 rabbitmq 服务作为 vcap 服务

转载 作者:IT王子 更新时间:2023-10-29 06:02:20 25 4
gpt4 key购买 nike

我能够使用关键的 REDIS 和 RABBITMQ 服务。在绑定(bind)服务时,我能够获取凭据并在我的 application.properties 中使用该凭据用于 spring boot 项目。

但是我正在使用的这个配置是在 application.Properties 中硬编码的为了动态地进行此配置,我开始知道我们可以使用 pivotal 提供的 vcap 服务。

所以想为 redis 和 rabbimq 使用运行时凭证。

我的代码在下面供引用。

应用程序属性

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 类,我在其中使用 Conguration 从 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 和 RabbitTemplate bean。这些所需的工厂属性将从 VCAP_SERVICES 中获取。在 CF 上,VCAP_SERVICES 环境变量将包含绑定(bind)到应用程序的服务信息。当你推送应用程序时,redis,rabbit 服务绑定(bind)到你的空间,然后它们的属性在 VCAP_SERVICES 中可用。因此,只需在您的代码中执行 System.getEnv("VCAP_SERVICES"),然后解析 json 以获取服务详细信息以创建模板。

2) 从 application.properties 中删除属性,并使用 spring cloud connector。 Spring cloud 有一个名为 Spring cloud connectors 的子项目,它提供实用程序来连接到各种云服务。

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,则首选第二种方法,因为这需要非常少的编码,并且可以毫不费力地切换到不同的云提供商。

关于spring-boot - 在 spring boot 应用程序中使用关键的 cloud foundry redis 和 rabbitmq 服务作为 vcap 服务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43936022/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com