SQMQOS是雲原生消息中間件,其設計初衷是為了將無服務器、容器和Kubernetes工作負載之間交換消息。本文將從多個方面深入講解sqmqos的實現細節和特性。
一、MQTT協議支持
func NewMQTTProtocol() protocol.Protocol {
return &mqttProtocol{
qos: QoSThree,
}
}
type mqttProtocol struct {
qos QoSLevel
}
func (mp *mqttProtocol) QoS() QoSLevel {
return mp.qos
}
func (mp *mqttProtocol) TriggerConfig() (*ampool.Config, error) {
return ampool.DefaultConfig, nil
}
SQMQOS支持MQTT協議。接口`protocol.Protocol`是SQMQOS提供的基礎協議接口。`mqttProtocol`實現了`protocol.Protocol`接口。在`NewMQTTProtocol`函數中,MQTT客戶端連接時,`mqttProtocol`被創建並返回。`QoS`方法返回MQTT的QoS(服務質量)級別。`TriggerConfig`方法返回一個內部組件的統一配置。MQTT協議有三個服務質量級別:0,1和2。QoS級別1和2可以保證消息的可靠投遞。在SQMQOS中,QoS3是最高的QoS級別,支持冪等和僅投遞一次的消息傳遞保證,以及可靠地保證傳遞到目標。
二、輕量級的雲原生架構
type Server struct {
Config Config
svc *service.Service
srv *http.Server
mm *am.MultiplexManager
}
func NewServer(config Config, tpo struct{} ) (*Server, error) {
srv := &http.Server{
Addr: config.Addr(),
Handler: newMux(config),
ReadTimeout: 70 * time.Second,
WriteTimeout: 70 * time.Second,
}
mm, err := am.NewMultiplexManager(ampool.Open(config.AMQP()), config.SQS())
if err != nil {
return nil, err
}
svc := service.New(mm, srv, config)
return &Server{
Config: config,
svc: svc,
srv: srv,
mm: mm,
}, nil
}
func (s *Server) Start() error {
err := s.svc.Start()
if err != nil {
return err
}
return s.srv.ListenAndServe()
}
SQMQOS實現了輕量級的雲原生架構。`Server`實現了SQMQOS的服務器端。使用Golang語言實現,`Server`是一個HTTP服務器,它監聽並處理到達服務地址的HTTP請求。在`NewServer`中,`http.Server`和`am.MultiplexManager`被初始化。`http.Server`提供HTTP層。`am.MultiplexManager`提供接口,以便處理來自不同傳輸方的消息。它考慮到多方傳輸-不限於HTTP,還可以是其他傳輸協議,如TCP和AMQP。其中,SQS是AWS的消息隊列服務,以Amazon SQS作為隊列後端。
三、可靠性
SQMQOS支持可靠的消息傳遞,這意味着郵件將在已發佈後被傳遞到一個或多個訂閱者。它採用三種級別的服務質量:QoS0,QoS1和QoS2。QoS0是最低的服務質量,它保證郵件僅會少量的進行編碼和傳輸。這就是所謂的「最多一次,非保證的傳輸庫存」保證。但這種級別的傳輸可以提供最小的可靠性。
高級別的服務質量將對協議進行更多方面的處理,以確保消息「冪等」(即消息被傳遞多次時,結果始終相同)並僅在一定程度上發送消息。
四、一些技術優化
SQMQOS通過復用TCP連接和HTTP/2協議提高性能。它非常適合雲原生應用程序,因為它是容器化的,規模化的,可靠的,跨雲和本地無服務器架構的。
五、主題訂閱功能
type Subscriber struct {
topic string
sm *am.SubscriptionManager
}
func NewSubscriber(aq ampool.Queue, topic string, handlers ...sm.SubscriptionHandler) (*Subscriber, error) {
sm, err := am.NewSubscriptionManager(aq, topic, handlers...)
if err != nil {
return nil, err
}
return &Subscriber{
topic: topic,
sm: sm,
}, nil
}
func (s *Subscriber) Subscribe() error {
return s.sm.Subscribe()
}
func (s *Subscriber) Unsubscribe() error {
return s.sm.Unsubscribe()
}
主題訂閱功能是MQTT協議的主要特性之一。它允許消息接收者訂閱主題、標籤或通配符規則。`Subscriber`是SQMQOS中實現主題訂閱功能的一個重要結構體。它封裝了`am.SubscriptionManager`結構體,實現主題訂閱行為,具有`Subscribe`和`Unsubscribe`API。
六、結論
至此,我們詳細地探討了SQMQOS的實現和特性。從MQTT協議支持、輕量級的雲原生架構、可靠性、一些技術優化和主題訂閱功能等多個方面逐一闡述了異步消息傳遞中間件SQMQOS。SQMQOS的設計目的是提供一種高質量、低延遲、高可伸縮性、經濟高效的消息基礎設施。
原創文章,作者:IYSZI,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/324920.html