K8S-EFK-01

节点数
zookeeper 1或3
kafka 1+

k8s-zookeeper

docker pull zookeeper:3.6.2

mkdir /data/nfs-volume/zookeeper

# 这个是单机,打开注释replicas 3集群
cat >zookeeper-cluster.yaml<<\EOF
apiVersion: v1
kind: ConfigMap
metadata:
  name: zookeeper
  namespace: efk
data:
  zoo.cfg: |
    tickTime=2000
    initLimit=5
    syncLimit=2
    maxClientCnxns=120
    dataDir=/data
    log_Dir=/data
    server.1=zookeeper-0:2888:3888;2181
#    server.2=zookeeper-1:2888:3888;2181
#    server.3=zookeeper-2:2888:3888;2181
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  labels:
    name: zookeeper
  name: zookeeper
  namespace: efk
spec:
  replicas: 1
  serviceName: zookeeper
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      name: zookeeper
  template:
    metadata:
      labels:
        name: zookeeper
    spec:
      nodeSelector:
        efk: "true"   ## 指定部署在哪个节点。需根据环境来修改      
      initContainers:
      - name: fix-permissions
        image: alpine:3.6
        securityContext:
          privileged: true
        env:
        - name: NAMESPACE
          valueFrom:
            fieldRef:
              fieldPath: metadata.namespace
        - name: POD_NAME
          valueFrom:
            fieldRef:
              fieldPath: metadata.name
        command: [ "sh", "-c", "mkdir -p /mnt/${NAMESPACE}/${POD_NAME}/data && echo ${POD_NAME} |awk -F '-' '{print $2+1}' >/mnt/${NAMESPACE}/${POD_NAME}/myid &&  chown -R 1000:1000 /mnt"]
        imagePullPolicy: IfNotPresent
        volumeMounts:
        - name: zookeeper-data
          mountPath: /mnt
      containers:
      - name: zookeeper
        image: zookeeper:3.6.2
        securityContext:
          runAsUser: 1000
          runAsGroup: 1000
        env:
        - name: NAMESPACE
          valueFrom:
            fieldRef:
              fieldPath: metadata.namespace
        - name: POD_NAME
          valueFrom:
            fieldRef:
              fieldPath: metadata.name
        - name: JVMFLAGS
          value: "-Xms512m -Xmx512m"
        resources:
          limits:
            cpu: 1000m
            memory: 1Gi
          requests:
            cpu: 500m
            memory: 600Mi
        ports:
        - containerPort: 2181
          protocol: TCP
        - containerPort: 2888
          protocol: TCP
        - containerPort: 3888
          protocol: TCP
        volumeMounts:
        - name: zkp-config
          mountPath: /conf/zoo.cfg
          subPath: zoo.cfg
        - name: zookeeper-data
          mountPath: /data
          subPathExpr: $(NAMESPACE)/$(POD_NAME)
      volumes:
      - name: zkp-config
        configMap:
          name: zookeeper
      - name: zookeeper-data
        nfs:
          server: 10.0.0.2
          path: /data/nfs-volume/zookeeper/
---
apiVersion: v1
kind: Service
metadata:
  name: zookeeper
  namespace: efk
spec:
  ports:
  - name: client
    port: 2181
    protocol: TCP
    targetPort: 2181
  - name: server
    port: 2888
    protocol: TCP
    targetPort: 2888
  - name: leade
    port: 3888
    protocol: TCP
    targetPort: 3888
  selector:
    name: zookeeper
  clusterIP: None

EOF
# 登陆pod验证
zkServer.sh status
Mode: xxx

k8s-kafka

官网


cat >Dockerfile<<\EOF
FROM infra/jre8:8u271
ARG KAFKA_USER=kafka
ADD kafka_2.13-2.6.0.tgz /opt
RUN ln -ns /opt/kafka_2.13-2.6.0/  /opt/kafka \
    && useradd $KAFKA_USER \
    && [ `id -u $KAFKA_USER` -eq 1000 ] \
    && [ `id -g $KAFKA_USER` -eq 1000 ] \
    && chown -R $KAFKA_USER:$KAFKA_USER /opt/kafka*
USER kafka
WORKDIR /opt/kafka
EOF

docker build .  -t infra/kafka:2.6.0



mkdir /data/nfs-volume/kafka
# 参考 https://github.com/cuishuaigit/k8s-kafka/blob/master/kafka.yaml
# 更改  replicas: 进行集群
cat >kafka.yaml<<\EOF
apiVersion: v1
kind: Service
metadata:
  name: kafka
  namespace: efk
spec:
  ports:
  - name: kafka
    port: 9092
    targetPort: 9092
  clusterIP: None
  selector:
    name: kafka
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  labels:
    name: kafka
  name: kafka
  namespace: efk
spec:
  replicas: 1
  serviceName: kafka
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      name: kafka
  template:
    metadata:
      labels:
        name: kafka
    spec:
#      nodeSelector:
#        elasticsearch: "true"   ## 指定部署在哪个节点。需根据环境来修改
      securityContext:
        runAsUser: 1000
      containers:
      - name: kafka
        image: infra/kafka:2.6.0
        resources:
          requests:
            memory: 800Mi
            cpu: 500m
        ports:
        - containerPort: 9092
          protocol: TCP
        command:
        - sh
        - -c
        - "exec bin/kafka-server-start.sh /opt/kafka/config/server.properties --override broker.id=${HOSTNAME##*-} \
          --override listeners=PLAINTEXT://:9092 \
          --override zookeeper.connect=zookeeper.efk.svc.cluster.local \
          --override log.dir=/var/lib/kafka \
          --override auto.create.topics.enable=true \
          --override auto.leader.rebalance.enable=true \
          --override delete.topic.enable=true \
          --override log.retention.hours=72 \
          --override socket.request.max.bytes=104857600 \
          --override socket.send.buffer.bytes=102400 \
          --override unclean.leader.election.enable=true \
          --override zookeeper.session.timeout.ms=6000 \
          --override max.request.size=5242880 \
          --override message.max.bytes=6291456 \
          --override fetch.max.bytes=7340032"
        env:
        - name: KAFKA_HEAP_OPTS
          value : "-Xmx512M -Xms512M"
        - name: KAFKA_OPTS
          value: "-Dlogging.level=INFO"
        - name: NAMESPACE
          valueFrom:
            fieldRef:
              fieldPath: metadata.namespace
        - name: POD_NAME
          valueFrom:
            fieldRef:
              fieldPath: metadata.name
        readinessProbe:
          tcpSocket:
            port: 9092
          timeoutSeconds: 1
          initialDelaySeconds: 5
        volumeMounts:
        - name: kafka-data
          mountPath: /var/lib/kafka
          subPathExpr: $(NAMESPACE)/$(POD_NAME)
      volumes:
      - name: kafka-data
        nfs:
          server: 10.0.0.2
          path: /data/nfs-volume/kafka/

EOF

log.retention.hours


优化参考: https://zhuanlan.zhihu.com/p/137720038

num.partitions=3
# 更具节点数量来看
#指定创建topic的默认分区数量,该值默认为1,建议根据具体的情况进行设定,越多的分区对于海量数据来说可以提高吞吐,但是对于>少量数据来说,也可能增加网络消耗
#注意:分区数一旦指定,只能增加,不能减少


# 自动创建topics,例如,当收到消息时,topics未创建,配置elk,不然filebeat无法自动创建topice
auto.create.topics.enable

# 是否开启leader自动平衡
auto.leader.rebalance.enable
# 对应影响的其他两个参数
# leader.imbalance.per.broker.percentage : 每个broker允许leader不平衡比例(如果每个broker上超过了这个值,controller将会>执行分区再平衡),默认值10.
# leader.imbalance.check.interval.seconds: 主分区再平衡的频率,默认值为300s


# 是否允许删除topic,通过管理工具删除topic仅为标记删除,建议设由集群管理员定期统一的进行删除和管理
delete.topic.enable

# 默认副本因子,适用于自动创建的主题的默认复制因子,默认1,建议2
default.replication.factor

min.insync.replicas=2

# 为false,就只从ISR中获取leader保证了数据的可靠性,,true则从replica中获取,则可用性增强
unclean.leader.election.enable=false

登陆pod验证

# 创建主题
bin/kafka-topics.sh  \
--zookeeper zookeeper.efk.svc.cluster.local:2181 \
--create  \
--topic test1  \
--partitions 2 \
--replication-factor 1  

# 展示主题
bin/kafka-topics.sh  \
--zookeeper zookeeper.efk.svc.cluster.local:2181 \
--list  

# 查看主题详情
bin/kafka-topics.sh  \
--zookeeper zookeeper.efk.svc.cluster.local:2181 \
--describe  --topic  test1  

#--topic                 指定所创建主题名称  
#--partitions         指定分区个数
#--replication-factor   指定分区副本因子

k8s-kafkamanager

# docker pull kafkamanager/kafka-manager:3.0.0.4
cat >kafkamanager.yaml<<EOF
apiVersion: v1
kind: Service
metadata:
  namespace: efk
  name: kafka-manager
  labels:
    app: kafka-manager
spec:
  type: ClusterIP
  ports:
  - name: kafka-manager
    port: 9000
    targetPort: 9000
  selector:
    app: kafka-manager
---
apiVersion: apps/v1
kind: Deployment
metadata:
  namespace: efk
  name: kafka-manager
  labels:
    app: kafka-manager
spec:
  replicas: 1
  selector:
    matchLabels:
      app: kafka-manager
  template:
    metadata:
      labels:
        app: kafka-manager
    spec:
      containers:
      - name: kafka-manager
        image: kafkamanager/kafka-manager:3.0.0.4
        imagePullPolicy: IfNotPresent
        ports:
        - name: kafka-manager
          containerPort: 9000
          protocol: TCP
        env:
        - name: ZK_HOSTS
          value: "zookeeper.efk.svc.cluster.local:2181"
#        readinessProbe:
#          httpGet:
#            path: /api/health
#            port: kafka-manager
        resources:
          limits:
            cpu: 500m
            memory: 512Mi
          requests:
            cpu: 250m
            memory: 256Mi

EOF

验证

# 访问 主机:30900
# Add Cluster
Cluster Zookeeper Hosts:  zookeeper.efk.svc.cluster.local


# 也可以添加ingress
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: kafka
  namespace: efk
  annotations:
    nginx.ingress.kubernetes.io/backend-protocol: "HTTP"
spec:
  rules:
  - host: kafka.zs.com
    http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: kafka-manager
            port:
              number: 9000

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351

推荐阅读更多精彩内容