一、影响Kafka生产者吞吐量因素
- batch.size: 批次大小,默认16K
- linger.ms: 等待时间,默认为0,修改为5-100ms
- compression.type: 压缩,默认none,修改为snappy
- RecordAccumulator: 缓冲区大小,默认32m,修改为64m
二、Kafka生产者Java实现
import com.sun.org.apache.bcel.internal.generic.NEW;
import org.apache.kafka.clients.producer.KafkaProducer;
import org.apache.kafka.clients.producer.ProducerConfig;
import org.apache.kafka.clients.producer.ProducerRecord;
import org.apache.kafka.common.protocol.types.Field;
import org.apache.kafka.common.serialization.StringSerializer;
import java.util.Properties;
public class CustomProducerParameters {
public static void main(String[] args) {
Properties properties = new Properties();
properties.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG,"node1:9092");
properties.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class.getName());
properties.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class.getName());
properties.put(ProducerConfig.BATCH_SIZE_CONFIG,16384);
properties.put(ProducerConfig.LINGER_MS_CONFIG,20);
properties.put(ProducerConfig.BUFFER_MEMORY_CONFIG,67108864);
properties.put(ProducerConfig.COMPRESSION_TYPE_CONFIG,"snappy");
KafkaProducer<String, String> kafkaProducer = new KafkaProducer<>(properties);
for (int i=0;i<5;i++){
kafkaProducer.send(new ProducerRecord<>("first","testMessage"+i));
}
kafkaProducer.close();
}
}