我在docker zookeeper,kafka,telegraf,influxdb,postgres等
version: '2.1'
services:
zookeeper:
image: wurstmeister/zookeeper
ports:
- "2181:2181"
environment:
ZOOKEEPER_CLIENT_PORT: 2181
ZOOKEEPER_TICK_TIME: 2000
healthcheck:
test: echo stat | nc localhost 2181
interval: 10s
timeout: 10s
retries: 3
kafka:
image: wurstmeister/kafka:0.11.0.0
ports:
- "9092:9092"
environment:
OFFSETS_TOPIC_REPLICATION_FACTOR: 1
KAFKA_BROKER_ID: 3
KAFKA_ADVERTISED_PORT: 9092
KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://kafka:9092
LOG4J_LOGGER_KAFKA_AUTHORIZER_LOGGER: TRACE
KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
KAFKA_CREATE_TOPICS: "testservise:1:1,testServiceInQueue:1:1,anotherTestServiceInQueue:1:1,storageServiceInQueue:1:1"
volumes:
- /var/run/docker.sock:/var/run/docker.sock
depends_on:
zookeeper:
condition: service_healthy
influxdb:
image: influxdb:latest
container_name: influxdb
ports:
- "8083:8083"
- "8086:8086"
- "8090:8090"
telegraf:
image: telegraf:latest
restart: always
container_name: telegraf
hostname: localhost
links:
- influxdb
volumes:
- ${PWD}/.telegraf/telegraf.conf
首先,我这样做
telegraf -sample-config -input-filter kafka_consumer -output-filter influxdb > telegraf.conf
因为需要使用telegraf / plugins / inputs / kafka_consumer docker-compose文件正确吗?
此后,我需要从kafka中获取信息,当我的测试服务发送某些内容时,我该怎么做或如何对它进行谷歌搜索?
答案 0 :(得分:0)
您的撰写文件看起来不错
默认情况下,我相信telegraf配置看起来像这样
[[inputs.kafka_consumer]]
## kafka servers
brokers = ["localhost:9092"]
## topic(s) to consume
topics = ["telegraf"]
您需要使用kafka:9092
并相应地更新主题。而且您还需要更新流入的输出(可能也远离本地主机)
您还可以使用Kafka Connect将kafka消息写入InfluxDB