Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ryskiwt/pubsub-go
Simple pub/sub written in Golang
https://github.com/ryskiwt/pubsub-go
go golang pubsub
Last synced: 15 days ago
JSON representation
Simple pub/sub written in Golang
- Host: GitHub
- URL: https://github.com/ryskiwt/pubsub-go
- Owner: ryskiwt
- License: bsd-2-clause
- Created: 2018-03-08T11:50:25.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2018-03-09T13:29:46.000Z (almost 7 years ago)
- Last Synced: 2024-11-13T02:52:19.594Z (3 months ago)
- Topics: go, golang, pubsub
- Language: Go
- Homepage:
- Size: 5.86 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# pubsub-go
Simple pub/sub library written in Golang.
[![GoDoc](https://godoc.org/github.com/ryskiwt/pubsub-go?status.svg)](https://godoc.org/github.com/ryskiwt/pubsub-go)
[![License](https://img.shields.io/badge/License-BSD%202--Clause-orange.svg)](https://github.com/ryskiwt/pubsub-go/blob/master/LICENSE)### features
- quite simple interface (Pub/Sub/PSub)
- type of topic is string
- type of message is interface{}
- support pattern subscribe (PSub/PUnsub)### interface
```go
type Hub interface {
Pub(topic string, msg interface{})
Sub(topic string) <-chan interface{}
Unsub(topic string, ch <-chan interface{})
PSub(pattern string) <-chan interface{}
PUnsub(pattern string, ch <-chan interface{})
Close()
Context() context.Context
}
```### example
```go
package mainimport (
"fmt"
"time"pubsub "github.com/ryskiwt/pubsub-go"
)func main() {
h := pubsub.NewHub(32)
subChan11 := h.Sub("/some/topic/1")
go func() {
for msg := range subChan11 {
fmt.Printf("subChan11, TOPIC: /some/topic/1, MSG: %s\n", msg)
}
}()
subChan12 := h.Sub("/some/topic/1")
go func() {
for msg := range subChan12 {
fmt.Printf("subChan12, TOPIC: /some/topic/1, MSG: %s\n", msg)
}
}()subChan2 := h.Sub("/some/topic/2")
go func() {
for msg := range subChan2 {
fmt.Printf("subChan2, TOPIC: /some/topic/2, MSG: %s\n", msg)
}
}()subChan3 := h.PSub("/some/topic/*")
go func() {
for msg := range subChan3 {
fmt.Printf("subChan3, TOPIC: /some/topic/*, MSG: %s\n", msg)
}
}()h.Pub("/some/topic/1", "message 1 !")
h.Pub("/some/topic/2", "message 2 !")
h.Pub("/some/topic/3", "message 3 !")
h.Pub("/some/topic/1", "message 4 !")
h.Pub("/some/topic/2", "message 5 !")
h.Pub("/some/topic/3", "message 6 !")<-time.After(time.Second)
h.Unsub("/some_topic/1", subChan11)
h.Unsub("/some_topic/1", subChan12)
h.Unsub("/some_topic/2", subChan2)
h.PUnsub("/some_topic/*", subChan3)
}
``````sh
$ cd example
$ go run main.go
subChan11, TOPIC: /some/topic/1, MSG: message 1 !
subChan12, TOPIC: /some/topic/1, MSG: message 1 !
subChan12, TOPIC: /some/topic/1, MSG: message 4 !
subChan3, TOPIC: /some/topic/*, MSG: message 1 !
subChan3, TOPIC: /some/topic/*, MSG: message 2 !
subChan3, TOPIC: /some/topic/*, MSG: message 4 !
subChan3, TOPIC: /some/topic/*, MSG: message 5 !
subChan11, TOPIC: /some/topic/1, MSG: message 4 !
subChan2, TOPIC: /some/topic/2, MSG: message 2 !
subChan2, TOPIC: /some/topic/2, MSG: message 5 !
```