Redis (一)消息订阅和发送测试

〇、redis 配置

1、概况

本文基于 Ubuntu20.04 云服务器配置Redis,且在本地进行 Redis 测试。

2、目录概况

一、配置文件

位于 /config/app.yml 中,目的用于 Redis 初始化:

bash 复制代码
redis:
  addr: "39.104.**.28:6379"
  password: "password"
  DB: 0
  poolSize: 30
  minIdleConn: 30

二、main 文件

go 复制代码
package main

import (
	"ChatTest/router"
	"ChatTest/utils"
	"github.com/gin-gonic/gin"
)

func main() {
	utils.InitConfig()
	utils.InitRedis()
	r := gin.Default()
	r = router.Router()
	r.Run(":8000")
}

二、初始化文件

位于 /utils/system_init.go 文件中,目的用于初始化相关:

bash 复制代码
package utils

import (
	"fmt"
	"github.com/go-redis/redis/v8"
	"github.com/spf13/viper"
)

var (
	Red *redis.Client
)

// 初始化初始化文件

func InitConfig() {
	viper.SetConfigName("app")
	viper.AddConfigPath("/Users/luliang/GoLand/ChatTest/config") //带绝对路径
	err := viper.ReadInConfig()
	if err != nil {
		fmt.Println(err)
	}
}

// 初始化 Redis

func InitRedis() {
	Red = redis.NewClient(&redis.Options{
		Addr:         viper.GetString("redis.addr"),
		Password:     viper.GetString("redis.password"),
		DB:           viper.GetInt("redis.DB"),
		PoolSize:     viper.GetInt("redis.minIdleConn"),
		MinIdleConns: viper.GetInt("redis.minIdleConn"),
	})
	fmt.Println("config Redis:", viper.Get("redis"))
}

三、路由文件

路由文件位于 /router/app.go 中,目的是建立路由:

go 复制代码
package router

import (
	"ChatTest/service"
	"github.com/gin-gonic/gin"
)

func Router() *gin.Engine {
	r := gin.Default()
	r.GET("/send", service.SendMsg)
	r.GET("/recv", service.RecvMsg)
	return r
}

四、实现服务

位于/service/message.go中,是 HandlerFunc,且实现服务:

go 复制代码
package service

import (
	"ChatTest/utils"
	"context"
	"github.com/gin-gonic/gin"
)

func SendMsg(c *gin.Context) {
	cmd := utils.Red.Publish(context.Background(), "myRedis", "Hello, MyRedis0001!")
	if cmd != nil {
		c.JSON(200, gin.H{
			"code":    0,
			"message": "发送成功!",
		})
		return
	}
	c.JSON(200, gin.H{
		"code":    -1,
		"message": "发送失败!",
	})

}

func RecvMsg(c *gin.Context) {
	pubSub := utils.Red.Subscribe(context.Background(), "myRedis")
	defer pubSub.Close()

	ch := pubSub.Channel()

	for msg := range ch {
		c.JSON(200, gin.H{
			"code":    0,
			"message": msg.Payload,
		})
		// 根据业务逻辑决定是否终止循环并返回响应
		return
	}

	// 如果没有接收到消息,可以根据需要返回响应
	c.JSON(200, gin.H{
		"code":    -1,
		"message": "接受失败!",
	})
}

五、运行流程

这里面的核心就是Redis 的连接,以及在 Redis 中发布消息和订阅消息了。

1、消息的发布

go 复制代码
cmd := utils.Red.Publish(context.Background(), "myRedis", "Hello, MyRedis0001!")

调用Publish() 函数发布一条消息,这个 Publish() 是 go-redis中封装好的方法。

2、消息的订阅

go 复制代码
pubSub := utils.Red.Subscribe(context.Background(), "myRedis")

可以看到,go-redis 中使用消息的订阅和发布功能,可以使得消息发送和接受的过程异常简单!

全文完,感谢阅读!

相关推荐
zxrhhm5 小时前
MySQL 8.4 LTS 数据库巡检脚本
数据库·mysql
AI木马人5 小时前
9.【AI任务队列实战】如何在高并发下保证系统不崩?(Redis + Celery完整方案)
数据库·人工智能·redis·神经网络·缓存
2401_883600255 小时前
golang如何理解weak pointer弱引用_golang weak pointer弱引用总结
jvm·数据库·python
aLTttY5 小时前
【Redis实战】分布式锁的N种实现方案对比与避坑指南
数据库·redis·分布式
2301_773553625 小时前
mysql如何评估SQL语句的索引开销_mysql性能追踪与分析
jvm·数据库·python
pele6 小时前
PHP源码运行受主板供电影响吗_供电相数重要性说明【技巧】
jvm·数据库·python
sinat_383437366 小时前
CSS如何实现元素悬浮在页面底部_利用fixed定位与底部间距
jvm·数据库·python
gmaajt7 小时前
mysql如何备份与恢复函数定义_mysql mysqldump导出存储对象
jvm·数据库·python
阿丰资源7 小时前
基于SpringBoot的在线视频教育平台的设计与实现(附源码+数据库+文档,一键运行)
数据库·spring boot·后端
qq_460978407 小时前
Python爬虫怎么模拟手机端抓取_设置手机型号User-Agent字符串
jvm·数据库·python