-
Notifications
You must be signed in to change notification settings - Fork 154
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
2f0104a
commit e697d03
Showing
4 changed files
with
211 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
62 changes: 62 additions & 0 deletions
62
...ozhera-log/log-agent/src/main/java/com/xiaomi/mone/log/agent/extension/KafkaExporter.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
package com.xiaomi.mone.log.agent.extension; | ||
|
||
import com.google.common.collect.Lists; | ||
import com.xiaomi.mone.log.agent.export.MsgExporter; | ||
import com.xiaomi.mone.log.api.model.msg.LineMessage; | ||
import org.apache.kafka.clients.producer.Producer; | ||
import org.apache.kafka.clients.producer.ProducerRecord; | ||
|
||
import java.util.List; | ||
|
||
|
||
public class KafkaExporter implements MsgExporter { | ||
|
||
private Producer mqProducer; | ||
|
||
private String rmqTopic; | ||
|
||
private Integer batchSize; | ||
|
||
public KafkaExporter(Producer mqProducer) { | ||
this.mqProducer = mqProducer; | ||
} | ||
|
||
@Override | ||
public void close() { | ||
|
||
} | ||
|
||
@Override | ||
public void export(LineMessage message) { | ||
this.export(Lists.newArrayList(message)); | ||
} | ||
|
||
@Override | ||
public void export(List<LineMessage> messageList) { | ||
if (messageList.isEmpty()) { | ||
return; | ||
} | ||
|
||
for (LineMessage lineMessage : messageList) { | ||
ProducerRecord<String, String> record = new ProducerRecord<>(rmqTopic, "message", gson.toJson(lineMessage)); | ||
mqProducer.send(record); | ||
} | ||
|
||
} | ||
|
||
public String getRmqTopic() { | ||
return rmqTopic; | ||
} | ||
|
||
public void setRmqTopic(String rmqTopic) { | ||
this.rmqTopic = rmqTopic; | ||
} | ||
|
||
public Integer getBatchSize() { | ||
return batchSize; | ||
} | ||
|
||
public void setBatchSize(Integer batchSize) { | ||
this.batchSize = batchSize; | ||
} | ||
} |
99 changes: 99 additions & 0 deletions
99
...zhera-log/log-agent/src/main/java/com/xiaomi/mone/log/agent/extension/KafkaMQService.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,99 @@ | ||
package com.xiaomi.mone.log.agent.extension; | ||
|
||
import com.google.common.base.Preconditions; | ||
import com.xiaomi.mone.log.agent.export.MsgExporter; | ||
import com.xiaomi.mone.log.agent.output.Output; | ||
import com.xiaomi.mone.log.agent.service.OutPutService; | ||
import com.xiaomi.mone.log.api.model.meta.LogPattern; | ||
import com.xiaomi.mone.log.api.model.meta.MQConfig; | ||
import com.xiaomi.youpin.docean.anno.Service; | ||
import lombok.extern.slf4j.Slf4j; | ||
import org.apache.commons.lang3.StringUtils; | ||
import org.apache.kafka.clients.producer.KafkaProducer; | ||
import org.apache.kafka.clients.producer.Producer; | ||
import org.apache.kafka.clients.producer.ProducerConfig; | ||
|
||
import java.util.Properties; | ||
import java.util.concurrent.ConcurrentHashMap; | ||
|
||
import static com.xiaomi.mone.log.common.Constant.DEFAULT_CONSUMER_GROUP; | ||
|
||
@Service(name = "KafkaMQService") | ||
@Slf4j | ||
public class KafkaMQService implements OutPutService { | ||
|
||
private ConcurrentHashMap<String, Producer> producerMap; | ||
|
||
public void init() { | ||
producerMap = new ConcurrentHashMap<>(128); | ||
} | ||
|
||
@Override | ||
public boolean compare(Output oldOutPut, Output newOutPut) { | ||
|
||
return false; | ||
} | ||
|
||
@Override | ||
public void preCheckOutput(Output output) { | ||
KafkaOutput rmqOutput = (KafkaOutput) output; | ||
Preconditions.checkArgument(null != rmqOutput.getClusterInfo(), "rmqOutput.getClusterInfo can not be null"); | ||
Preconditions.checkArgument(null != rmqOutput.getTopic(), "rmqOutput.getTopic can not be null"); | ||
} | ||
|
||
@Override | ||
public MsgExporter exporterTrans(Output output) throws Exception { | ||
KafkaOutput kafkaOutput = (KafkaOutput) output; | ||
String nameSrvAddr = kafkaOutput.getClusterInfo(); | ||
Producer mqProducer = producerMap.get(nameSrvAddr); | ||
if (null == mqProducer) { | ||
mqProducer = initMqProducer(kafkaOutput); | ||
producerMap.put(String.valueOf(nameSrvAddr), mqProducer); | ||
} | ||
|
||
KafkaExporter rmqExporter = new KafkaExporter(mqProducer); | ||
rmqExporter.setRmqTopic(kafkaOutput.getTopic()); | ||
rmqExporter.setBatchSize(kafkaOutput.getBatchExportSize()); | ||
|
||
return rmqExporter; | ||
} | ||
|
||
private Producer initMqProducer(KafkaOutput output) { | ||
Properties properties = new Properties(); | ||
properties.setProperty(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, output.getClusterInfo()); | ||
properties.setProperty(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, "org.apache.kafka.common.serialization.StringSerializer"); | ||
properties.setProperty(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, "org.apache.kafka.common.serialization.StringSerializer"); | ||
if (StringUtils.isNotEmpty(output.getAk()) && StringUtils.isNotEmpty(output.getSk())) { | ||
properties.setProperty("security.protocol", "SASL_SSL"); | ||
properties.setProperty("sasl.mechanism", "PLAIN"); | ||
properties.setProperty("sasl.jaas.config", "org.apache.kafka.common.security.plain.PlainLoginModule required username=\"" + output.getAk() + "\" password=\"" + output.getSk() + "\";"); | ||
} | ||
Producer<String, String> producer = new KafkaProducer<>(properties); | ||
return producer; | ||
} | ||
|
||
@Override | ||
public void removeMQ(Output output) { | ||
KafkaOutput kafkaOutput = (KafkaOutput) output; | ||
if (null != producerMap.get(kafkaOutput.getClusterInfo())) { | ||
producerMap.get(kafkaOutput.getClusterInfo()).close(); | ||
} | ||
} | ||
|
||
@Override | ||
public Output configOutPut(LogPattern logPattern) { | ||
|
||
MQConfig mqConfig = logPattern.getMQConfig(); | ||
KafkaOutput output = new KafkaOutput(); | ||
output.setOutputType(KafkaOutput.OUTPUT_KAFKAMQ); | ||
output.setClusterInfo(mqConfig.getClusterInfo()); | ||
output.setProducerGroup(mqConfig.getProducerGroup()); | ||
output.setAk(mqConfig.getAk()); | ||
output.setSk(mqConfig.getSk()); | ||
output.setTopic(mqConfig.getTopic()); | ||
output.setPartitionCnt(mqConfig.getPartitionCnt()); | ||
output.setTag(mqConfig.getTag()); | ||
output.setProducerGroup(DEFAULT_CONSUMER_GROUP + (null == logPattern.getPatternCode() ? "" : logPattern.getPatternCode())); | ||
return output; | ||
} | ||
} |
45 changes: 45 additions & 0 deletions
45
...l/ozhera-log/log-agent/src/main/java/com/xiaomi/mone/log/agent/extension/KafkaOutput.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
package com.xiaomi.mone.log.agent.extension; | ||
|
||
import com.xiaomi.mone.log.agent.output.Output; | ||
import lombok.Data; | ||
import lombok.EqualsAndHashCode; | ||
|
||
import java.io.Serializable; | ||
|
||
@Data | ||
@EqualsAndHashCode | ||
public class KafkaOutput extends Output implements Serializable { | ||
|
||
public static final String OUTPUT_KAFKAMQ = "kafkamq"; | ||
|
||
private String serviceName = "KafkaMQService"; | ||
|
||
/** | ||
* mq fill:namesrv_addr | ||
*/ | ||
private String clusterInfo; | ||
|
||
private String producerGroup; | ||
|
||
private String orgId; | ||
|
||
private String ak; | ||
|
||
private String sk; | ||
|
||
private String topic; | ||
|
||
private Integer partitionCnt; | ||
|
||
private Integer batchExportSize; | ||
|
||
@Override | ||
public String getEndpoint() { | ||
return clusterInfo; | ||
} | ||
|
||
@Override | ||
public String getServiceName() { | ||
return serviceName; | ||
} | ||
} |