在kubernetes集群中部署kibana步骤如下:

1:kibana安装文件(目前最新版本4.5.1);

2:编写Dockerfile及执行点脚本文件run.sh,制作Kibana镜像;

3:推送镜像至某个Docker源,可以是公网的源,也可以是公司内部源;

4:在kubernetes主节点编写kibana镜像对应的RC文件,service文件;

5:在kubernetes集群中创建kibana service,kibana pods;

6:测试验证。

===============================================================================

1:kibana安装文件(以4.5.1版本为例)

安装包名为:kibana-4.5.1-linux-x64.tar.gz

如无安装包,可以从官网下载安装包,或者直接在Dockerfile中使用wget的方式下载。

===============================================================================

2:编写Dockerfile及执行点脚本文件run.sh,制作Kibana镜像;

由于需要保持与开发测试环境一致,因此这里采用了centos作为基础镜像,镜像较大,可使用ubuntu或alpine作为基础镜像,能显著缩小镜像尺寸。

以下是Dockerfile内容:

 FROM jiakai/centos.base:7.2.1511
 MAINTAINER JiaKai "jiakai@gridsum.com"
 ENV KIBANA_VERSION 4.5.1-linux-x64
 COPY ./kibana-${KIBANA_VERSION}.tar.gz /opt/kibana-${KIBANA_VERSION}.tar.gz
 RUN tar -xzf /opt/kibana-${KIBANA_VERSION}.tar.gz && \
     mv -f /kibana-${KIBANA_VERSION} /opt/kibana-${KIBANA_VERSION} && \
     rm -f /opt/kibana-${KIBANA_VERSION}.tar.gz
 ADD ./run.sh /run.sh
 EXPOSE 5601
 CMD /bin/bash /run.sh

入口点的shell脚本文件如下:

 #!/bin/sh
 set -e
 KIBANA_CONF_FILE="/opt/kibana-${KIBANA_VERSION}/config/kibana.yml"
 KIBANA_ES_URL=${KIBANA_ES_URL:-http://localhost:9200}
 sed -i "s;^.*elasticsearch.url:.*;elasticsearch.url: ${KIBANA_ES_URL};" "${KIBANA_CONF_FILE}"
 exec /opt/kibana-${KIBANA_VERSION}/bin/kibana

此时可以制作kibana的 Docker镜像:

sudo docker build -t="jiakai/kibana:4.5" .

无误的话将得到名为jiakai/kibana,Tag为4.5的kibana镜像,可以通过

sudo docker run -it ${Image Id} /bin/bash

来启动镜像检查(自行替换${Image ID}为实际获得的镜像ID);

================================================================================================

3:推送镜像至某个Docker源,可以是公网的源,也可以是公司内部源

推送镜像之前需要为镜像重新标记(TAG),这里以公司的内部源为例,将制作好的镜像推送至目标源:

sudo docker Tag jiakai/kibana:4.5 10.200.XXX.XXX:5000/gridsum/logstash:4.5

================================================================================================

4:在kubernetes主节点编写kibana镜像对应的RC文件,service文件

由于kibana需要向外界提供web服务,因此需要在kubernetes中对kibana建立RC及service;

下面是RC文件,只起了一个副本,可根据需求调整

 apiVersion: v1
 kind: ReplicationController
 metadata:
   name: kibana
   namespace: default
   labels:
     component: elk
     name: kibana
 spec:
   replicas: 1
   selector:
     component: elk
     name: kibana
   template:
     metadata:
       labels:
         component: elk
         name: kibana
     spec:
       containers:
       - name: kibana
         image: 10.XXX.XXXX.XXX:5000/gridsum/ld/kibana:4.5
         env:
         - name: KIBANA_ES_URL
           value: "http://10.XXX.XXX.XXX:9200"
         ports:
           - containerPort: 5601
             name: http
             protocol: TCP

下面是service文件,将自行LB所有的kibana pod:

 apiVersion: v1
 kind: Service
 metadata:
   name: kibana
   namespace: default
   labels:
     component: elk
     name: kibana
 spec:
   type: NodePort
   ports:
   - port: 5601
     targetPort: 5601
     nodePort: 30601
   selector:
     component: elk
     name: kibana

=================================================================================================

5:在kubernetes集群中创建kibana service,kibana pods

正确建立了kibana的RC及service文件后,即可在kubernetes集群中部署kibana服务对外提供服务;

这里我们在第4步建立的RC文件名为kibana-controller.yaml,建立的service文件名为kibana-service.yaml:

启动kibana service:

kubectl create -f kibana-service.yaml

启动kibana pods:

kubectl create -f kibana-controller.yaml

=================================================================================================

6:测试验证
在kubernetes集群中可以通过

kubectl get pods

查看当前所有pods状态;

通过

kubectl get service

查看当前所有service状态。

确定服务状态及pod状态正常后,即可通过浏览器来访问kibana服务,不过这里要注意一点就是kubernetes集群提供的kibana服务不再是通过5601端口,而是在service文件中定义的30601端口,可访问这个URL测试kubernetes集群提供的kibana服务。


Kibana默认安装路径 /opt/kibana

默认配置文件路径 /opt/kibana/config/kibana.yml

使用kuernetes提供高可用的kibana服务的更多相关文章

  1. 使用kuernetes提供高可用的logstash服务

    在kubernetes集群中部署logstash步骤如下: 1:logstash安装文件(目前最新版本2.3.4): 2:编写Dockerfile及执行点脚本文件run.sh,并且修改logstash ...

  2. heartbeat单独提供高可用服务

    本文目录:1.简介2.安装heartbeat 2.1 编译安装Heartbeat3.heartbeat相关配置文件 3.1 配置文件ha.cf 3.2 配置文件authkeys 3.3 配置文件har ...

  3. 每天响应数亿次请求,腾讯云如何提供高可用API服务?

    每天响应数亿次请求,腾讯云如何提供高可用API服务? https://mp.weixin.qq.com/s/OPwlHcqkaTT_gcwHfr5Shw 李阳 云加社区 2020-09-16 导语 | ...

  4. 搭建高可用的Redis服务,需要注意这些方面!

    搭建高可用的Redis服务,需要注意这些方面! HorstXu 占小狼的博客 今天 ◎作者 | HorstXu www.cnblogs.com/xuning/p/8464625.html 基于内存的R ...

  5. [ Openstack ] Openstack-Mitaka 高可用之 网络服务(Neutron)

    目录 Openstack-Mitaka 高可用之 概述    Openstack-Mitaka 高可用之 环境初始化    Openstack-Mitaka 高可用之 Mariadb-Galera集群 ...

  6. [ Openstack ] Openstack-Mitaka 高可用之 计算服务(Nova)

    目录 Openstack-Mitaka 高可用之 概述    Openstack-Mitaka 高可用之 环境初始化    Openstack-Mitaka 高可用之 Mariadb-Galera集群 ...

  7. [ Openstack ] OpenStack-Mitaka 高可用之 镜像服务(glance)

    目录 Openstack-Mitaka 高可用之 概述    Openstack-Mitaka 高可用之 环境初始化    Openstack-Mitaka 高可用之 Mariadb-Galera集群 ...

  8. MaxCompute,基于Serverless的高可用大数据服务

    摘要:2019年1月18日,由阿里巴巴MaxCompute开发者社区和阿里云栖社区联合主办的“阿里云栖开发者沙龙大数据技术专场”走近北京联合大学,本次技术沙龙上,阿里巴巴高级技术专家吴永明为大家分享了 ...

  9. suse 12 编译部署Keepalived + nginx 为 kube-apiserver 提供高可用

    文章目录 编译部署nginx 下载nginx源码包 编译nginx 配置nginx.conf 配置nginx为systemctl管理 分发nginx二进制文件和配置文件 启动kube-nginx服务 ...

随机推荐

  1. 面试题:return和finally执行

    Demo类: public class Demo { public int get() { int x=1; try { x++; return x; }finally{ ++x; } } } Tes ...

  2. java-vector hashtable过时?

    vector hashtable过时? 在用JAVA集合时,IDE提示 vector 以及hashtable被arraylist ,hashmap替代,而前者又是线程同步的,不知道为什么?是效率差了的 ...

  3. HTML 学习笔记 CSS(选择器2)

    CSS 类选择器 类选择器允许以一种独立于文档元素的方式来指定样式 CSS 类选择器 类选择器允许以一种独立于文档元素的方式来指定样式 该选择器可以单独使用 也可以和其他元素结合使用 提示 只要适当的 ...

  4. MakeCode 递归生成资源文件

    static void yieldDir(DirectoryInfo dir, int depth, StringBuilder sb1, StringBuilder sb2) { var first ...

  5. Html网页使用jQuery传递参数并获取Web API的数据

    昨天Insus.NET有开始学习Web API,<ASP.NET MVC的Web Api的实练>http://www.cnblogs.com/insus/p/4334316.html .其 ...

  6. NET Core中怎么使用HttpContext.Current

    NET Core中怎么使用HttpContext.Current 阅读目录 一.前言 二.IHttpContextAccessor 三.HttpContextAccessor 回到目录 一.前言 我们 ...

  7. struts2和spring3.2的整合 详细演示

    1.首先我们新建一个Web工程,如下: 2.导入Spring和Struts2的jar包. 其中,struts2-spring-plugin-2.1.8.jar是struts2.spring整合的关键. ...

  8. 利用Spring MVC搭建REST Service

    之前写过一篇 利用JAX-RS快速开发RESTful 服务 今天来看下spring-mvc框架如何实现类似的功能: 一.pom.xml <?xml version="1.0" ...

  9. leetcode - 位运算题目汇总(上)

    最近在看位运算的知识,十分感叹于位运算的博大精深,正好leetcode有 Bit Manipulation 的专题,正好拿来练练手. Subsets 给出一个由不同的数字组成的数组,枚举它的子数组(子 ...

  10. AndFix热修复 —— 实战与源码解析

    当你的应用发布后第二天却发现一个重要的bug要修复,头疼的同时你可能想着赶紧修复重新打个包发布出去,让用户收到自动更新重新下载.但是万事皆有可能,万一隔一天又发现一个急需修复的bug呢?难道再次发布打 ...