RedisPubSubController.java 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. package com.ruoyi.demo.controller;
  2. import com.ruoyi.common.core.domain.AjaxResult;
  3. import com.ruoyi.common.core.redis.RedisCache;
  4. import io.swagger.annotations.Api;
  5. import io.swagger.annotations.ApiOperation;
  6. import lombok.RequiredArgsConstructor;
  7. import org.springframework.beans.factory.annotation.Autowired;
  8. import org.springframework.web.bind.annotation.GetMapping;
  9. import org.springframework.web.bind.annotation.RequestMapping;
  10. import org.springframework.web.bind.annotation.RestController;
  11. /**
  12. * Redis 发布订阅 演示案例
  13. *
  14. * @author Lion Li
  15. */
  16. @Api(value = "Redis发布订阅 演示案例", tags = {"Redis发布订阅"})
  17. @RequiredArgsConstructor(onConstructor_ = @Autowired)
  18. @RestController
  19. @RequestMapping("/demo/redis/pubsub")
  20. public class RedisPubSubController {
  21. private final RedisCache redisCache;
  22. @ApiOperation("发布消息")
  23. @GetMapping("/pub")
  24. public AjaxResult<Void> pub(String key, String value){
  25. redisCache.publish(key, value, consumer -> {
  26. System.out.println("发布通道 => " + key + ", 发送值 => " + value);
  27. });
  28. return AjaxResult.success("操作成功");
  29. }
  30. @ApiOperation("订阅消息")
  31. @GetMapping("/sub")
  32. public AjaxResult<Void> sub(String key){
  33. redisCache.subscribe(key, String.class, msg -> {
  34. System.out.println("订阅通道 => " + key + ", 接收值 => " + msg.toString());
  35. });
  36. return AjaxResult.success("操作成功");
  37. }
  38. }