docker部署elk

es1镜像

两个容器 171.111.0.11


172.111.0.12


npm可以不装


l logstash


k 也有


docker安装es1

[root@docker2 es1]# ls

Dockerfile  elasticsearch-6.7.2.rpm  elasticsearch.yml  node-v8.2.1.tar.gz  phantomjs-2.1.1-linux-x86_64.tar.bz2

[root@docker2 es1]# vim Dockerfile

FROM centos:7

RUN rm -rf /etc/yum.repos.d/*

ADD http://mirrors.aliyun.com/repo/Centos-7.repo /etc/yum.repos.d/Centos-7.repo

RUN yum clean all && yum makecache

RUN yum -y install epel-release

RUN yum -y install gcc gcc-c++ make

RUN yum -y install java

RUN yum clean all

COPY elasticsearch-6.7.2.rpm /opt

RUN rpm -ivh /opt/elasticsearch-6.7.2.rpm

COPY elasticsearch.yml /etc/elasticsearch/elasticsearch.yml

EXPOSE 9200

CMD ["/usr/share/elasticsearch/bin/elasticsearch"]

WORKDIR /opt/

ADD node-v8.2.1.tar.gz /opt/

RUN cd node-v8.2.1 \

   && ./configure \

   && make -j 2 \

   && make install

ADD phantomjs-2.1.1-linux-x86_64.tar.bz2 /opt/es1

RUN ln -s /opt/es1/phantomjs-2.1.1-linux-x86_64/bin/phantomjs /usr/local/bin/phantomjs

RUN chown -R elasticsearch:elasticsearch /usr/share/elasticsearch \

   && chown -R elasticsearch:elasticsearch /etc/elasticsearch

USER elasticsearch

[root@docker2 es1]# vim elasticsearch.yml

cluster.name: elk-cluster

node.name: node1

node.master: true

node.data: true

path.data: /var/lib/elasticsearch

path.logs: /var/log/elasticsearch

network.host: 0.0.0.0

http.port: 9200

transport.tcp.port: 9300

discovery.zen.ping.unicast.hosts: ["172.111.0.11","172.111.0.12"]

[root@docker2 es1]# docker build -t es1:elk .

[root@docker2 es1]# docker run -itd --name es1 -p 9200:9200 --net mynetwork --ip 172.111.0.11 es1:elk

58ed4d572bece8ae75ec9be63d5f1335ee9b3e7c0ccfd40ba23909faf4223402

[root@docker2 es1]# docker ps

CONTAINER ID   IMAGE     COMMAND                   CREATED         STATUS         PORTS                                       NAMES

58ed4d572bec   es1:elk   "/usr/share/elastics…"   3 seconds ago   Up 3 seconds   0.0.0.0:9200->9200/tcp, :::9200->9200/tcp   es1

es2镜像

docker创建es2

[root@docker2 es2]# vim elasticsearch.yml

cluster.name: elk-cluster

node.name: node2

node.master: false

node.data: true

path.data: /var/lib/elasticsearch

path.logs: /var/log/elasticsearch

network.host: 0.0.0.0

http.port: 9200

transport.tcp.port: 9300

discovery.zen.ping.unicast.hosts: ["172.111.0.11","172.111.0.12"]

[root@docker2 es2]# vim Dockerfile

FROM centos:7

RUN rm -rf /etc/yum.repos.d/*

ADD http://mirrors.aliyun.com/repo/Centos-7.repo /etc/yum.repos.d/Centos-7.repo

RUN yum clean all && yum makecache

RUN yum -y install epel-release

RUN yum -y install gcc gcc-c++ make

RUN yum -y install java

RUN yum clean all

COPY elasticsearch-6.7.2.rpm /opt

RUN rpm -ivh /opt/elasticsearch-6.7.2.rpm

COPY elasticsearch.yml /etc/elasticsearch/elasticsearch.yml

EXPOSE 9200

CMD ["/usr/share/elasticsearch/bin/elasticsearch"]

WORKDIR /opt/

ADD node-v8.2.1.tar.gz /opt/

RUN cd node-v8.2.1 \

   && ./configure \

   && make -j 2 \

   && make install

ADD phantomjs-2.1.1-linux-x86_64.tar.bz2 /opt/es1

RUN ln -s /opt/es1/phantomjs-2.1.1-linux-x86_64/bin/phantomjs /usr/local/bin/phantomjs

RUN chown -R elasticsearch:elasticsearch /usr/share/elasticsearch \

   && chown -R elasticsearch:elasticsearch /etc/elasticsearch

USER elasticsearch

[root@docker2 es2]# docker build -t es2:elk .

[root@docker2 es1]# docker run -itd --name es2 -p 9201:9200 --net mynetwork --ip 172.111.0.12 es2:elk

logstash镜像

拉取logstash和kibana的v6.7.2版本镜像


docker pull logstash:6.7.2

docker pull kibana:6.7.2

logstash镜像编排


cd /opt/logstash

vim logstash.yml

# 编写yml文件

http.host: "0.0.0.0"

xpack.monitoring.elasticsearch.url: [ "http://es1:9200","http://es2:9201" ]

vim logstash.conf

# 编写 conf 文件,定义输入输出,指定输入之一为宿主机Apache的日志文件

input {

 tcp {

   mode => "server"

   host => "0.0.0.0"

   port => 5044

   codec => "json"

 }

 file {

   path => "/opt/logs/*_log"

   start_position => "beginning"

 }

}

output {

 elasticsearch {

   hosts => [ "http://es1:9200","http://es2:9201" ]

   index => "elk-%{+YYYY.MM.dd}"

 }

}

为了方便,把logstash镜像的权限设置为root,否则宿主机共享过去的Apache日志文件logstash都无权限访问


vim Dockerfile

FROM logstash:6.7.2

USER root

COPY logstash.yml ./config/logstash.yml

COPY logstash.conf ./pipeline/logstash.conf

docker build -t logstash:elk .

docker run -itd --name logstash -v /etc/httpd/logs/:/opt/logs/ --net mynetwork1 --ip 172.111.0.30 -p 5044:5044 -p 9600:9600 logstash:elk

docker exec -it logstash bash

cd /opt/logs/

doc  

访问几次宿主机的Apache服务,并查看Apache的日志文件是否共享到容器内


kibana镜像编排

cd /opt/kibana

vim kibana.yml

server.name: kibana

server.host: "0"

elasticsearch.hosts: [ "http://172.111.0.11:9200","http://172.111.0.12:9201" ]

vim Dockerfile

FROM kibana:6.7.2

COPY kibana.yml ./config/kibana.yml

USER root

RUN chown kibana.kibana ./config/kibana.yml

USER kibana

docker build -t kibana:elk .

docker run -itd --name kibana --net mynetwork --ip 172.111.0.40 -p 5601:5601 kibana:elk

docker exec -it kibana bash

访问kibana的web页面,查看日志数据并建立对应索引