Redis
 sql >> Baza danych >  >> NoSQL >> Redis

Jak otrzymać wiadomość o publikacji Redis w Go

Uważam, że twój kod jest w porządku; problem polega na tym, że publikujesz wiadomość przed aktywacją subskrypcji. Na przykład wypróbuj to, co umieszcza wydawcę w gorutine, która publikuje wiadomość raz na sekundę:

package main

import (
    "fmt"
    "log"
    "time"

    "github.com/gomodule/redigo/redis"
)

func main() {
    fmt.Println("Start redis test.")

    c, err := redis.Dial("tcp", "localhost:6379")
    if err != nil {
        log.Println(err)
    } else {
        log.Println("No error during redis.Dial.")
    }
    // defer c.Close()

    /// Publisher.
    go func() {
        c, err := redis.Dial("tcp", "localhost:6379")
        if err != nil {
            panic(err)
        }

        count := 0
        for {
            c.Do("PUBLISH", "example",
                fmt.Sprintf("test message %d", count))
            count++
            time.Sleep(1 * time.Second)
        }
    }()
    /// End here

    /// Subscriber.
    psc := redis.PubSubConn{Conn: c}
    psc.Subscribe("example")

    for {
        switch v := psc.Receive().(type) {
        case redis.Message:
            fmt.Printf("%s: message: %s\n", v.Channel, v.Data)
        case redis.Subscription:
            fmt.Printf("%s: %s %d\n", v.Channel, v.Kind, v.Count)
        case error:
            fmt.Println(v)
        }

        time.Sleep(1)
    }
    /// End here

}

Uruchom to, a zobaczysz, że Twój subskrybent otrzymuje wiadomość raz na sekundę, generując dane wyjściowe takie jak:

Start redis test.
2021/08/18 19:01:29 No error during redis.Dial.
example: subscribe 1
example: message: test message 0
example: message: test message 1
example: message: test message 2
example: message: test message 3
example: message: test message 4
example: message: test message 5



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Podziel ciąg po znaku w Lua

  2. przechowywanie danych w redis przez zadanie cron

  3. Jak połączyć się z instancją klastra Docker Redis przy użyciu jedis for Java?

  4. Jak odizolować redis aplikacji wiosennego rozruchu i globalną redis sesji wiosennego rozruchu?

  5. Mechanizm blokady magazynu Redis (lub dowolnej bazy danych?) (NodeJS)