kafka

/**
     * 异步发送
     * 
     * @param topic 主题
     * @param key key
     * @param value 消息内容
     * 
     * @throws WebsocketException 入参不合法
     */

public void doProducer(KafkaProducerTopics topic,
                           String key,
        String value) throws WebsocketException {

        if (null == topic) {
            throw new WebsocketException(WsErrorCode.ERROR_INVALID_PARAM);
        }

        ProducerRecord<String, String> record = new ProducerRecord<>(topic.getTopic(), key, value);
        producer.send(record);
    }

/**
     * 同步阻塞发送
     * 
     * @param topic 主题
     * @param key key
     * @param value 消息内容
     * @param unit 时间单位
     * @param timeout 超时时间
     * 
     * @throws WebsocketException 执行超时、执行被中断、执行失败等会抛出此异常
     */

public void doProducer(KafkaProducerTopics topic,
                           String key,
                           String value,
                           TimeUnit unit,
                           long timeout) throws WebsocketException {
    
        if (null == topic) {
            throw new WebsocketException(WsErrorCode.ERROR_INVALID_PARAM);
        }

        try {

            ProducerRecord<String, String> record = new ProducerRecord<>(topic.getTopic(),
                                                                         key,
                                                                         value);
            Future<RecordMetadata> resultFuture = producer.send(record);
            resultFuture.get(timeout, unit);

}  catch (TimeoutException e) {
            throw new WebsocketException(WsErrorCode.ERROR_TIME_OUT);
        } catch (InterruptedException e) {
            throw new WebsocketException(WsErrorCode.THREAD_INTERRUPTED);
        } catch (ExecutionException e) {

            throw new WebsocketException(WsErrorCode.ERROR_UNKNOW_EXCEPTION, e.getMessage());
        } 
       

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值