zoukankan      html  css  js  c++  java
  • dockerfile动态修改服务配置文件

    主要是利用命令envsubst能实现变量的替换并生成新得配置文件以及docker命令行的变量输入等。

    本次实验主要是编写flume镜像,并在容器启动(docker run)时动态修改配置文件并启动,并向flume发数据,然后发给kafka。

    此实验的基础:

        会dockerfile的编写,熟悉flume服务,kafka服务。

    步骤:

    1、dockerfile文件如下:

    FROM centos
    WORKDIR /opt
    COPY jdk-8u241-linux-x64.rpm /root
    RUN rpm -i /root/jdk-8u241-linux-x64.rpm   # 安装jdk
    RUN yum install -y gettext   # 安装 envsubst命令
    COPY flume ./flume/
    EXPOSE 5140/udp
    VOLUME /tmp/logs/
    CMD envsubst < /opt/flume/conf/flume.conf.template > /opt/flume/conf/flume.conf && ./flume/bin/flume-ng agent -c ./flume/conf/ -f ./flume/conf/flume.conf  --name agent  -Dflume.root.logger=INFO,console
    # envsubst根据flume.conf.template这个配置文件替换变量并生成flume.conf。

     flume的配置文件如下:

    agent.sources = s1
    agent.sinks = k1
    agent.channels = c1
    
    agent.sources.s1.type = syslogudp
    agent.sources.s1.port = 5140
    agent.sources.s1.host = ${BIND_IP}
    
    agent.channels.c1.type = memory
    agent.channels.c1.capacity = 100000
    agent.channels.c1.transactionCapacity = 5000
    
    agent.sinks.k1.type = logger
    agent.sinks.k1.type = org.apache.flume.sink.kafka.KafkaSink
    agent.sinks.k1.kafka.topic = log
    agent.sinks.k1.kafka.bootstrap.servers = ${KAFKA_IP}:${KAFKA_PORT}
    agent.sinks.k1.flumeBatchSize = 200
    agent.sinks.k1.producer.acks = 1
    agent.sinks.k1.producer.linger.ms = 1
    agent.sinks.k1.producer.compression.type = snappy
    
    agent.sources.s1.channels = c1
    agent.sinks.k1.channel = c1

    2、构建镜像 

    docker build /root/flume/dockerfile/ -t flume_sink_file:v1
    

     注意:/root/flume/dockerfile/目录下要有flume、jdk-8u241-linux-x64.rpm、dockerfile文件。

    3、启动容器:

     docker run -d --rm -P -e  KAFKA_IP="192.168.174.128",KAFKA_PORT="9092",BIND_IP="0.0.0.0" --name=abcd flume_sink_file:v1 

    4、而后,向flume发送数据,测试是否能在kafka topic log上接收到数据。

  • 相关阅读:
    介绍自己
    第六周作业
    第五周作业
    第四周作业
    秋季学期学习总结
    币值转化
    justintime compiler
    PostgreSQL windows下安装出现问题的解决办法
    Java语言的异常处理,完全理解下面4点就可以了
    Ultraedit用途【来自网络】
  • 原文地址:https://www.cnblogs.com/hel7512/p/12895944.html
Copyright © 2011-2022 走看看