java+redis+添加_java+redis+spring mvc实现发布订阅(不同项目间)

项目1:利用redis做消息队列发布消息

项目2:利用redis订阅项目1发布的消息

项目1(发布):

properties配置文件中redis配置:

redis.hostName=192.168.1.1

redis.port=6379

redis.timeout=15000

redis.usePool=true

redis.maxIdle=6

redis.minEvictableIdleTimeMillis=300000

redis.numTestsPerEvictionRun=3

redis.timeBetweenEvictionRunsMillis=60000

spring配置文件添加redis配置(只列出了redis相关配置):

xmlns:redis=”http://www.springframework.org/schema/redis”

http://www.springframework.org/schema/redis

http://www.springframework.org/schema/redis/spring-redis-1.0.xsd

class=’org.springframework.data.redis.connection.jedis.JedisConnectionFactory’ >

class=”org.springframework.data.redis.serializer.StringRedisSerializer” />

RedisDao接口:

import java.util.Map;

import org.springframework.data.redis.core.ValueOperations;

public interface RedisDao {

/*

* 设置频道

*/

public static final String TQCHANNEL = “channel_message”;

public void sendMessage(String channel, String message);

}

RedisDaoImpl实现类:

public class RedisDaoImpl implements RedisDao {

@Autowired

public RedisTemplate redisTemplate;

@Override

public void sendMessage(String channel, String message) {

System.out.println(“开始发布消息。。。”);

redisTemplate.convertAndSend(channel, message);

System.out.println(“发布成功!”);

}

}

程序中调用RedisDaoImpl发布消息:

redisDao.sendMessage(“channel_message”, “要发布的字符串”);

项目2(订阅):

properties配置文件中redis配置:

redis.hostName=192.168.1.1

redis.port=6379

redis.timeout=15000

redis.usePool=true

redis.maxIdle=6

redis.minEvictableIdleTimeMillis=300000

redis.numTestsPerEvictionRun=3

redis.timeBetweenEvictionRunsMillis=60000

spring配置文件添加redis配置(只列出了redis相关配置):

xmlns:redis=”http://www.springframework.org/schema/redis”

http://www.springframework.org/schema/redis

http://www.springframework.org/schema/redis/spring-redis-1.0.xsd

id=’jedisConnectionFactory’

class=’org.springframework.data.redis.connection.jedis.JedisConnectionFactory’ >

class=”org.springframework.data.redis.listener.adapter.MessageListenerAdapter”>

  –>

topic=”tq_message” />

监听器TQMessageDelegateListener代码:

public class TQMessageDelegateListener  {

@Autowired

protected JdbcTemplate jdbcTemplate ;

@Autowired

private JdbcTemplate jdbc;

//private UserController user = new UserController();

public void  handleMessage(String message){

System.out.println(“监听到的消息为:”+message);

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值