2020-12-27 01:05:24 +00:00
## 8. Message Stream Service
#### 8.1 Overview
2021-01-12 02:52:57 +00:00
#### 8.2 API
2020-12-27 01:05:24 +00:00
2020-12-29 10:02:44 +00:00
```go
type Client interface {
2021-01-12 02:52:57 +00:00
CreateChannels(req CreateChannelRequest) (ChannelID []string, error)
DestoryChannels(channelID []string) error
DescribeChannels(channelID []string) (ChannelDescriptions, error)
2020-12-29 10:02:44 +00:00
}
```
* *CreateChannels*
2020-12-27 01:05:24 +00:00
```go
type OwnerDescription struct {
Role string
Address string
//Token string
DescriptionText string
}
2020-12-29 10:02:44 +00:00
type CreateChannelRequest struct {
OwnerDescription OwnerDescription
2021-01-12 02:52:57 +00:00
numChannels int
2020-12-29 10:02:44 +00:00
}
```
* *DescribeChannels*
```go
2020-12-27 01:05:24 +00:00
type ChannelDescription struct {
Owner OwnerDescription
}
2021-01-12 02:52:57 +00:00
type ChannelDescriptions struct {
2020-12-29 10:02:44 +00:00
Descriptions []ChannelDescription
2020-12-27 01:05:24 +00:00
}
```
2021-01-04 06:16:43 +00:00
#### A.3 Message Stream
``` go
type MsgType uint32
const {
kInsert MsgType = 400
kDelete MsgType = 401
kSearch MsgType = 500
2021-01-12 02:52:57 +00:00
KSearchResult MsgType = 1000
2021-01-04 06:16:43 +00:00
kSegStatistics MsgType = 1100
kTimeTick MsgType = 1200
kTimeSync MsgType = 1201
}
type TsMsg interface {
SetTs(ts Timestamp)
BeginTs() Timestamp
EndTs() Timestamp
Type() MsgType
Marshal(*TsMsg) []byte
Unmarshal([]byte) *TsMsg
}
type MsgPack struct {
BeginTs Timestamp
EndTs Timestamp
Msgs []TsMsg
}
type MsgStream interface {
Produce(*MsgPack) error
Broadcast(*MsgPack) error
Consume() *MsgPack // message can be consumed exactly once
}
type RepackFunc(msgs []* TsMsg, hashKeys [][]int32) map[int32] *MsgPack
type PulsarMsgStream struct {
client *pulsar.Client
repackFunc RepackFunc
producers []*pulsar.Producer
consumers []*pulsar.Consumer
unmarshal *UnmarshalDispatcher
}
func (ms *PulsarMsgStream) CreatePulsarProducers(topics []string)
func (ms *PulsarMsgStream) CreatePulsarConsumers(subname string, topics []string, unmarshal *UnmarshalDispatcher)
func (ms *PulsarMsgStream) SetRepackFunc(repackFunc RepackFunc)
func (ms *PulsarMsgStream) Produce(msgs *MsgPack) error
func (ms *PulsarMsgStream) Broadcast(msgs *MsgPack) error
func (ms *PulsarMsgStream) Consume() (*MsgPack, error)
func (ms *PulsarMsgStream) Start() error
func (ms *PulsarMsgStream) Close() error
func NewPulsarMsgStream(ctx context.Context, pulsarAddr string) *PulsarMsgStream
type PulsarTtMsgStream struct {
client *pulsar.Client
repackFunc RepackFunc
producers []*pulsar.Producer
consumers []*pulsar.Consumer
unmarshal *UnmarshalDispatcher
inputBuf []*TsMsg
unsolvedBuf []*TsMsg
msgPacks []*MsgPack
}
func (ms *PulsarTtMsgStream) CreatePulsarProducers(topics []string)
func (ms *PulsarTtMsgStream) CreatePulsarConsumers(subname string, topics []string, unmarshal *UnmarshalDispatcher)
func (ms *PulsarTtMsgStream) SetRepackFunc(repackFunc RepackFunc)
func (ms *PulsarTtMsgStream) Produce(msgs *MsgPack) error
func (ms *PulsarTtMsgStream) Broadcast(msgs *MsgPack) error
func (ms *PulsarTtMsgStream) Consume() *MsgPack //return messages in one time tick
func (ms *PulsarTtMsgStream) Start() error
func (ms *PulsarTtMsgStream) Close() error
func NewPulsarTtMsgStream(ctx context.Context, pulsarAddr string) *PulsarTtMsgStream
```
```go
type MarshalFunc func(*TsMsg) []byte
type UnmarshalFunc func([]byte) *TsMsg
type UnmarshalDispatcher struct {
tempMap map[ReqType]UnmarshalFunc
}
func (dispatcher *MarshalDispatcher) Unmarshal([]byte) *TsMsg
func (dispatcher *MarshalDispatcher) AddMsgTemplate(msgType MsgType, marshal MarshalFunc)
func (dispatcher *MarshalDispatcher) addDefaultMsgTemplates()
func NewUnmarshalDispatcher() *UnmarshalDispatcher
```
2021-01-11 10:35:54 +00:00
#### A.4 RocksMQ
RocksMQ is a RocksDB-based messaging/streaming library.
```go
type ProducerMessage struct {
2021-01-12 02:52:57 +00:00
payload []byte
2021-01-11 10:35:54 +00:00
}
```
2021-01-12 02:52:57 +00:00
2021-01-11 10:35:54 +00:00
```go
type ConsumerMessage struct {
2021-01-12 02:52:57 +00:00
msgID MessageID
payload []byte
2021-01-11 10:35:54 +00:00
}
```
```GO
2021-01-12 02:52:57 +00:00
type Channel struct {
beginOffset MessageID
endOffset MessageID
}
type ComsumerGroupContext struct {
currentOffset MessageID
2021-01-11 10:35:54 +00:00
}
2021-01-12 02:52:57 +00:00
// Every collection has its RocksMQ
type RocksMQ struct {
channels map[string]Channel
cgCtxs map[string]ComsumerGroupContext
mu sync.Mutex
}
func (rmq *RocksMQ) CreateChannel(channelName string) error // create channel, add record in meta-store
func (rmq *RocksMQ) DestroyChannel(channelName string) error // drop channel, delete record in meta-store
func (rmq *RocksMQ) CreateConsumerGroup(groupName string) error // create consumer group, add record in meta-store
func (rmq *RocksMQ) DestroyConsumerGroup(groupName string) error // drop consumer group, delete record in meta-store
func (rmq *RocksMQ) Produce(channelName string, messages []ProducerMessage) error // produce a batch of message, insert into rocksdb
func (rmq *RocksMQ) Consume(groupName string, channelName string, n int) ([]ConsumerMessage, error) // comsume up to n messages, modify current_id in Etcd
func (rmq *RocksMQ) Seek(groupName string, channelName string, msgID MessageID) error // modify current_id in Etcd
2021-01-11 10:35:54 +00:00
```
2021-01-12 02:52:57 +00:00
##### A.4.1 Meta (stored in Etcd)
2021-01-11 10:35:54 +00:00
* channel meta
```go
2021-01-12 02:52:57 +00:00
"$(channel_name)/begin_id", MessageID
2021-01-11 10:35:54 +00:00
"$(channel_name)/end_id", MessageID
```
* consumer group meta
```go
"$(group_name)/$(channel_name)/current_id", MessageID
```
2021-01-12 02:52:57 +00:00
##### A.4.2 Data (stored in RocksDB)
- data
```go
"$(channel_name)/$(unique_id)", []byte
```