All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.plumelog.core.kafka.KafkaProducerClient Maven / Gradle / Ivy

package com.plumelog.core.kafka;

import com.plumelog.core.AbstractClient;
import com.plumelog.core.exception.LogQueueConnectException;
import org.apache.kafka.clients.producer.KafkaProducer;
import org.apache.kafka.clients.producer.ProducerRecord;

import java.util.List;
/**
 * className:KafkaProducerClient
 * description:kafka Producer instance
 * time:2020-05-11.16:17
 *
 * @author Frank.chen
 * @version 1.0.0
 */
public class KafkaProducerClient extends AbstractClient {
    private static KafkaProducerClient instance;
    private KafkaProducerPool kafkaProducerPool;
    public static KafkaProducerClient getInstance(String hosts) {
        if (instance == null) {
            synchronized (KafkaProducerClient.class) {
                if (instance == null) {
                    instance = new KafkaProducerClient(hosts);
                }
            }
        }
        return instance;
    }
    private KafkaProducerClient(String hosts){
        this.kafkaProducerPool=new KafkaProducerPool(hosts);
    }
    @Override
    public void pushMessage(String topic, String message) throws LogQueueConnectException {
        KafkaProducer kafkaProducer=null;
        try {
            kafkaProducer=kafkaProducerPool.getResource();
            kafkaProducer.send(new ProducerRecord(topic, message));
        }catch (Exception e){
            throw new LogQueueConnectException("kafka 写入失败!",e);
        }finally {
            if(kafkaProducer!=null){
                kafkaProducerPool.returnResource(kafkaProducer);
            }
        }

    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy