使用kuernetes提供高可用的kibana服务
在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服务的更多相关文章
- 使用kuernetes提供高可用的logstash服务
在kubernetes集群中部署logstash步骤如下: 1:logstash安装文件(目前最新版本2.3.4): 2:编写Dockerfile及执行点脚本文件run.sh,并且修改logstash ...
- heartbeat单独提供高可用服务
本文目录:1.简介2.安装heartbeat 2.1 编译安装Heartbeat3.heartbeat相关配置文件 3.1 配置文件ha.cf 3.2 配置文件authkeys 3.3 配置文件har ...
- 每天响应数亿次请求,腾讯云如何提供高可用API服务?
每天响应数亿次请求,腾讯云如何提供高可用API服务? https://mp.weixin.qq.com/s/OPwlHcqkaTT_gcwHfr5Shw 李阳 云加社区 2020-09-16 导语 | ...
- 搭建高可用的Redis服务,需要注意这些方面!
搭建高可用的Redis服务,需要注意这些方面! HorstXu 占小狼的博客 今天 ◎作者 | HorstXu www.cnblogs.com/xuning/p/8464625.html 基于内存的R ...
- [ Openstack ] Openstack-Mitaka 高可用之 网络服务(Neutron)
目录 Openstack-Mitaka 高可用之 概述 Openstack-Mitaka 高可用之 环境初始化 Openstack-Mitaka 高可用之 Mariadb-Galera集群 ...
- [ Openstack ] Openstack-Mitaka 高可用之 计算服务(Nova)
目录 Openstack-Mitaka 高可用之 概述 Openstack-Mitaka 高可用之 环境初始化 Openstack-Mitaka 高可用之 Mariadb-Galera集群 ...
- [ Openstack ] OpenStack-Mitaka 高可用之 镜像服务(glance)
目录 Openstack-Mitaka 高可用之 概述 Openstack-Mitaka 高可用之 环境初始化 Openstack-Mitaka 高可用之 Mariadb-Galera集群 ...
- MaxCompute,基于Serverless的高可用大数据服务
摘要:2019年1月18日,由阿里巴巴MaxCompute开发者社区和阿里云栖社区联合主办的“阿里云栖开发者沙龙大数据技术专场”走近北京联合大学,本次技术沙龙上,阿里巴巴高级技术专家吴永明为大家分享了 ...
- suse 12 编译部署Keepalived + nginx 为 kube-apiserver 提供高可用
文章目录 编译部署nginx 下载nginx源码包 编译nginx 配置nginx.conf 配置nginx为systemctl管理 分发nginx二进制文件和配置文件 启动kube-nginx服务 ...
随机推荐
- 平滑过渡的战争迷雾(一) 原理:Warcraft3地形拼接算法
本系列文章由七十一雾央编写,转载请注明出处. http://blog.csdn.net/u011371356/article/details/9611887 作者:七十一雾央 新浪微博:http:/ ...
- [No00000F]Excel快捷键大全 Excel2013/2010/2007/2003常用快捷键大全
一个软件最大的用处是提高工作效率,衡量一个软件的好坏,除了是否出名之外,最主就是能否让一个新手更快的学会这个软件和提高工作速度.就拿Excel表格来说吧,平常办公中我们经常会用它来制作表格,统计数据或 ...
- [No000008]发工资不仅仅是让你写代码的
这是我对团队每个新进员工说的第一件事情.这句话的意思是,我并不关心你是如何快速完成任务的,哪怕代码很差,只要它像救生艇通气门一样管用就行.这句话也是我最喜欢的座右铭之一. 这个说法其实很合理:我们的工 ...
- 技术专题—Python黑客【优质内容聚合贴】
作者:坏蛋链接:https://zhuanlan.zhihu.com/p/24645819来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 一.前言 本着知识分享,聚合优 ...
- AndroidStudio 混淆打包
AndroidStudio中的项目可以用compile的形式引入github上的开 源项目,可以引用module,而不一定都要用libs文件夹中添加jar包的形式.在最终realease打包时,混淆的 ...
- oracle 事务总结
用了这么长时间的oracle,该总结一下所得了 1,事务 事务用于保证数据的一致性, 它由一组相关的 dml语句组成, 该组的dml(数据操作语言,增删改,没有查询)语句要么全部成功,要么全部失败,比 ...
- 4817 江哥的dp题d
4817 江哥的dp题d 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description 已知1-N的排列P的LIS(最长上 ...
- BZOJ 1082 【SCOI2005】 栅栏
Description 农夫约翰打算建立一个栅栏将他的牧场给围起来,因此他需要一些特定规格的木材.于是农夫约翰到木材店购买木材.可是木材店老板说他这里只剩下少部分大规格的木板了.不过约翰可以购买这些木 ...
- [转]ReactPHP── PHP版的Node.js
FROM : http://www.csdn.net/article/2015-10-12/2825887 摘要:ReactPHP作为Node.js的PHP版本.在实现思路,使用方法,应用场景上的确有 ...
- Cordova - 使用Cordova开发iOS应用实战4(调用摄像头拍照,并编辑)
使用Cordova可以很方便的通过js代码来使用设备摄像头拍照,只需把camera插件添加进来即可. 一,添加camera插件 首先我们要在“终端”中进入工程所在的目录,然后运行如下命令: 1 cor ...