milvus/internal/mq/mqimpl/rocksmq/client/producer_impl.go

73 lines
1.9 KiB
Go

// Copyright (C) 2019-2020 Zilliz. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software distributed under the License
// is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
// or implied. See the License for the specific language governing permissions and limitations under the License.
package client
import (
"go.uber.org/zap"
"github.com/milvus-io/milvus/internal/mq/mqimpl/rocksmq/server"
"github.com/milvus-io/milvus/pkg/log"
)
// assertion make sure implementation
var _ Producer = (*producer)(nil)
// producer contains a client instance and topic name
type producer struct {
// client which the producer belong to
c *client
topic string
}
// newProducer creates a rocksmq producer from options
func newProducer(c *client, options ProducerOptions) (*producer, error) {
if c == nil {
return nil, newError(InvalidConfiguration, "client is nil")
}
if options.Topic == "" {
return nil, newError(InvalidConfiguration, "Topic is empty")
}
return &producer{
c: c,
topic: options.Topic,
}, nil
}
// Topic returns the topic name of producer
func (p *producer) Topic() string {
return p.topic
}
// Send produce message in rocksmq
func (p *producer) Send(message *ProducerMessage) (UniqueID, error) {
ids, err := p.c.server.Produce(p.topic, []server.ProducerMessage{
{
Payload: message.Payload,
Properties: message.Properties,
},
})
if err != nil {
return 0, err
}
return ids[0], nil
}
// Close destroy the topic of this producer in rocksmq
func (p *producer) Close() {
err := p.c.server.DestroyTopic(p.topic)
if err != nil {
log.Warn("Producer close failed", zap.Any("topicName", p.topic), zap.Any("error", err))
}
}