123
This commit is contained in:
parent
9a5da6bcad
commit
83f66f4924
261
pkg/controller/front/link.go
Normal file
261
pkg/controller/front/link.go
Normal file
@ -0,0 +1,261 @@
|
|||||||
|
package front
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"github.com/gin-gonic/gin"
|
||||||
|
"github.com/go-redis/redis"
|
||||||
|
"github.com/gorilla/websocket"
|
||||||
|
"log"
|
||||||
|
"net/http"
|
||||||
|
"sync"
|
||||||
|
"time"
|
||||||
|
"worktest/pkg/controller"
|
||||||
|
"worktest/pkg/redistab"
|
||||||
|
_ "worktest/pkg/redistab"
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
func RedisRecWebsocket(c *gin.Context) {
|
||||||
|
var wg sync.WaitGroup
|
||||||
|
var upgrader = websocket.Upgrader{
|
||||||
|
ReadBufferSize: 1024,
|
||||||
|
WriteBufferSize: 1024,
|
||||||
|
}
|
||||||
|
cn, err := upgrader.Upgrade(c.Writer, c.Request, http.Header{"Set-Cookie": {"sessionID=1234"}})
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
controller.Error(c, err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
defer cn.Close()
|
||||||
|
wg.Add(1)
|
||||||
|
|
||||||
|
go ListenRedisRec(cn,&wg)
|
||||||
|
|
||||||
|
fmt.Println("等待ing")
|
||||||
|
wg.Wait()
|
||||||
|
fmt.Println("等待结束")
|
||||||
|
}
|
||||||
|
|
||||||
|
func RedisWebsocket(c *gin.Context) {
|
||||||
|
var wg sync.WaitGroup
|
||||||
|
var upgrader = websocket.Upgrader{
|
||||||
|
ReadBufferSize: 1024,
|
||||||
|
WriteBufferSize: 1024,
|
||||||
|
}
|
||||||
|
cn, err := upgrader.Upgrade(c.Writer, c.Request, http.Header{"Set-Cookie": {"sessionID=1234"}})
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
controller.Error(c, err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
defer cn.Close()
|
||||||
|
wg.Add(1)
|
||||||
|
|
||||||
|
go ListenRedis(cn,&wg)
|
||||||
|
|
||||||
|
fmt.Println("等待ing")
|
||||||
|
wg.Wait()
|
||||||
|
fmt.Println("等待结束")
|
||||||
|
}
|
||||||
|
|
||||||
|
func ping(ws *websocket.Conn, done chan struct{}) {
|
||||||
|
ticker := time.NewTicker(10*time.Second)
|
||||||
|
defer ticker.Stop()
|
||||||
|
for {
|
||||||
|
if err := ws.WriteControl(websocket.PingMessage, []byte{}, time.Now().Add(10*time.Second)); err != nil {
|
||||||
|
done<- struct{}{}
|
||||||
|
log.Println("ping:", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func ListenRedis(cn *websocket.Conn, wg *sync.WaitGroup) {
|
||||||
|
|
||||||
|
defer wg.Done()
|
||||||
|
|
||||||
|
|
||||||
|
//redis 订阅数据
|
||||||
|
pubsub := redistab.RedisClient.Subscribe( redistab.GetChannelKey()) // 订阅 mychannel
|
||||||
|
ch := pubsub.Channel()
|
||||||
|
defer pubsub.Close()
|
||||||
|
|
||||||
|
|
||||||
|
stdoutDone := make(chan struct{})
|
||||||
|
go ping(cn, stdoutDone) //存活检测
|
||||||
|
|
||||||
|
|
||||||
|
for {
|
||||||
|
|
||||||
|
/*
|
||||||
|
fmt.Println("7-----")
|
||||||
|
var msg *redis.Message
|
||||||
|
msg, ok := <-ch
|
||||||
|
fmt.Println("1--------------",msg,ok)
|
||||||
|
if !ok {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
//1 pubsub.Receive()//receive 监听数据
|
||||||
|
|
||||||
|
var msg *redis.Message
|
||||||
|
select {
|
||||||
|
case <-stdoutDone:
|
||||||
|
fmt.Println("前端终止连接")
|
||||||
|
return
|
||||||
|
case msg = <-ch:
|
||||||
|
fmt.Println("接受数据",msg)
|
||||||
|
}
|
||||||
|
|
||||||
|
err := cn.WriteMessage(websocket.TextMessage, []byte(msg.String()))
|
||||||
|
if err != nil{
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func ListenRedis3(cn *websocket.Conn, wg *sync.WaitGroup) {
|
||||||
|
|
||||||
|
defer wg.Done()
|
||||||
|
|
||||||
|
|
||||||
|
go func(cn *websocket.Conn) {
|
||||||
|
for {
|
||||||
|
fmt.Println("123123")
|
||||||
|
/*
|
||||||
|
ticker := time.NewTicker(30 * time.Second)
|
||||||
|
defer ticker.Stop()
|
||||||
|
for {
|
||||||
|
|
||||||
|
fmt.Println("ping")
|
||||||
|
// 发送 Ping 消息
|
||||||
|
err := cn.WriteMessage(websocket.PingMessage, []byte{})
|
||||||
|
if err != nil {
|
||||||
|
// 处理错误
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
<-ticker.C
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
ticker := time.NewTicker(30 * time.Second)
|
||||||
|
defer ticker.Stop()
|
||||||
|
for {
|
||||||
|
select {
|
||||||
|
case <-ticker.C:
|
||||||
|
if err := cn.WriteControl(websocket.PingMessage, []byte{}, time.Now().Add(10 * time.Second)); err != nil {
|
||||||
|
log.Println("ping:", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}(cn)
|
||||||
|
|
||||||
|
go func(cn *websocket.Conn) {
|
||||||
|
for {
|
||||||
|
fmt.Println("123123")
|
||||||
|
for {
|
||||||
|
|
||||||
|
fmt.Println("ping")
|
||||||
|
// 发送 Ping 消息
|
||||||
|
err := cn.WriteMessage(websocket.TextMessage, []byte("222222"))
|
||||||
|
//err := cn.WriteMessage(websocket.PingMessage, []byte{})
|
||||||
|
if err != nil {
|
||||||
|
// 处理错误
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}(cn)
|
||||||
|
|
||||||
|
|
||||||
|
for {
|
||||||
|
fmt.Println("123123")
|
||||||
|
err := cn.WriteMessage(websocket.TextMessage, []byte("1111111"))
|
||||||
|
if err != nil {
|
||||||
|
log.Println(" server write err:", err)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func ListenRedis2(cn *websocket.Conn, wg *sync.WaitGroup) {
|
||||||
|
|
||||||
|
defer wg.Done()
|
||||||
|
|
||||||
|
for {
|
||||||
|
|
||||||
|
mt, message, err := cn.ReadMessage()
|
||||||
|
if err != nil {
|
||||||
|
log.Println("server read:", err)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
log.Printf("server recv msg: %s", message)
|
||||||
|
msg := string(message)
|
||||||
|
if msg == "woshi client1" {
|
||||||
|
message = []byte("client1 去服务端了一趟")
|
||||||
|
|
||||||
|
} else if msg == "woshi client2" {
|
||||||
|
message = []byte("client2 去服务端了一趟")
|
||||||
|
}
|
||||||
|
|
||||||
|
err = cn.WriteMessage(mt, message)
|
||||||
|
if err != nil {
|
||||||
|
log.Println(" server write err:", err)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
func ListenRedisRec(cn *websocket.Conn, wg *sync.WaitGroup) {
|
||||||
|
|
||||||
|
defer wg.Done()
|
||||||
|
|
||||||
|
//redis 订阅数据
|
||||||
|
pubsub := redistab.RedisClient.Subscribe( redistab.GetChannelKey()) // 订阅 mychannel
|
||||||
|
defer pubsub.Close()
|
||||||
|
|
||||||
|
//stdoutDone := make(chan struct{})
|
||||||
|
//go ping(cn, stdoutDone) //存活检测
|
||||||
|
|
||||||
|
for {
|
||||||
|
|
||||||
|
var message *redis.Message
|
||||||
|
msg,err := pubsub.Receive()//receive 监听数据
|
||||||
|
if err != nil{
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
switch info := msg.(type) {
|
||||||
|
case *redis.Subscription:
|
||||||
|
continue
|
||||||
|
case *redis.Pong:
|
||||||
|
continue
|
||||||
|
case *redis.Message:
|
||||||
|
message = info
|
||||||
|
default:
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
err = cn.WriteMessage(websocket.TextMessage, []byte(message.String()))
|
||||||
|
|
||||||
|
if err != nil{
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
28
pkg/redistab/redis_key_test.go
Normal file
28
pkg/redistab/redis_key_test.go
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
package redistab
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestGetProductBitMap(t *testing.T) {
|
||||||
|
// 创建一个带有缓冲区的channel
|
||||||
|
ch := make(chan int, 3)
|
||||||
|
|
||||||
|
// 启动多个监听者
|
||||||
|
for i := 1; i <= 3; i++ {
|
||||||
|
go func(i int) {
|
||||||
|
// 从channel中读取数据,并将其打印到控制台
|
||||||
|
fmt.Printf("监听器%d收到消息:%d\n", i, <-ch)
|
||||||
|
}(i)
|
||||||
|
}
|
||||||
|
|
||||||
|
// 向channel发送消息
|
||||||
|
for i := 1; i <= 5; i++ {
|
||||||
|
ch <- i
|
||||||
|
}
|
||||||
|
|
||||||
|
// 等待所有监听者处理完所有消息
|
||||||
|
time.Sleep(3*time.Second)
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user