k8s部署 elfk 7.x + x-pack

k8s以StatefulSet方式部署elasticsearch集群,其中filebeat以sidecar方式部署。当前最新版本:7.10.1


namespace

mkdir -p /home/k8s/elfk/{
   elasticsearch-head,elasticsearch,logstash,kibana,filebeat}

cd /home/k8s/elfk

vim namespace.yaml
apiVersion: v1
kind: Namespace
metadata:
  name: log

pv

mount -t nfs -o vers=4,minorversion=0,rsize=1048576,wsize=1048576,hard,timeo=600,retrans=2,noresvport xxx.cn-hangzhou.nas.aliyuncs.com:/ /mnt

mkdir -p /mnt/elfk-data/{
   elasticsearch-0,elasticsearch-1,elasticsearch-2}

vim alicloud-nas-elfk-pv.yaml
apiVersion: v1
kind: PersistentVolume
metadata:
  name: alicloud-nas-elfk-pv0
  labels:
    alicloud-pvname: alicloud-nas-elfk-pv
spec:
  capacity:
    storage: 500Gi
  accessModes:
    - ReadWriteMany
  csi:
    driver: nasplugin.csi.alibabacloud.com
    volumeHandle: alicloud-nas-elfk-pv0
    volumeAttributes:
      server: "xxx.cn-hangzhou.nas.aliyuncs.com"
      path: "/elfk-data/elasticsearch-0"
  mountOptions:
  - nolock,tcp,noresvport
  - vers=4
  
---
apiVersion: v1
kind: PersistentVolume
metadata:
  name: alicloud-nas-elfk-pv1
  labels:
    alicloud-pvname: alicloud-nas-elfk-pv
spec:
  capacity:
    storage: 500Gi
  accessModes:
    - ReadWriteMany
  csi:
    driver: nasplugin.csi.alibabacloud.com
    volumeHandle: alicloud-nas-elfk-pv1
    volumeAttributes:
      server: "xxx.cn-hangzhou.nas.aliyuncs.com"
      path: "/elfk-data/elasticsearch-1"
  mountOptions:
  - nolock,tcp,noresvport
  - vers=4
  
---
apiVersion: v1
kind: PersistentVolume
metadata:
  name: alicloud-nas-elfk-pv2
  labels:
    alicloud-pvname: alicloud-nas-elfk-pv
spec:
  capacity:
    storage: 500Gi
  accessModes:
    - ReadWriteMany
  csi:
    driver: nasplugin.csi.alibabacloud.com
    volumeHandle: alicloud-nas-elfk-pv2
    volumeAttributes:
      server: "xxx.cn-hangzhou.nas.aliyuncs.com"
      path: "/elfk-data/elasticsearch-2"
  mountOptions:
  - nolock,tcp,noresvport
  - vers=4

elasticsearch-haed

vim elasticsearch-head/head.yaml
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: head
  namespace: log
spec:
  rules:
  - host: head.lzxlinux.cn
    http:
      paths:
      - path: /
        backend:
          serviceName: head
          servicePort: 9100

---
apiVersion: v1
kind: Service
metadata:
  name: head
  namespace: log
  labels:
    app: head
spec:
  selector:
    app: head
  ports:
  - port: 9100
    protocol: TCP
    targetPort: 9100
    
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: head
  namespace: log
  labels:
    app: head
spec:
  replicas: 1
  selector:
    matchLabels:
      app: head
  template:
    metadata:
      labels:
        app: head
    spec:
      containers:
      - name: head
        image: mobz/elasticsearch-head:5
        resources:
          limits:
            cpu: 200m
            memory: 200Mi
          requests:
            cpu: 100m
            memory: 100Mi
        ports:
        - containerPort: 9100

elasticsearch

vim elasticsearch/elasticsearch.yaml
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: elasticsearch
  namespace: log
spec:
  rules:
  - host: elasticsearch.lzxlinux.cn
    http:
      paths:
      - path: /
        backend:
          serviceName: elasticsearch
          servicePort: 9200

---
apiVersion: v1
kind: Service
metadata:
  name: elasticsearch
  namespace: log
  labels:
    app: elasticsearch
spec:
  selector:
    app: elasticsearch
  ports:
  - name: api
    port: 9200
  - name: discovery
    port: 9300
  clusterIP: None

---
apiVersion: apps/v1
kind: Stateful
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值