本地搭建K8S开发环境
admin
2024-02-07 20:39:39
0

有时候我们需要在本地搭建一个开发测试环境,这个环境可能会包括很多不同的软件组件,例如Kafka, PG, Redis之类的。利用Kubernetes我们可以很方便的搭建一个环境,并把这些需要的组件部署到环境上面去。这里我选择在本地安装minikube,然后快速地创建一个k8s集群。具体minikube的安装很简单,直接参考官网的介绍即可。

下面我们部署一些常用的组件到这个K8S环境中去。

Kafka

首先我们先部署一个Kafka。先定义一个名为kafka的namespace,新建一个名为00-namespace.yaml文件,内容如下:

apiVersion: v1
kind: Namespace
metadata:name: "kafka"labels:name: "kafka"

运行kubectl apply -f 00-namespace.yaml进行部署。

下一步就是部署一个zookeeper,创建一个名为01-zookeeper.yaml,内容如下:

apiVersion: v1
kind: Service
metadata:labels:app: zookeeper-servicename: zookeeper-servicenamespace: kafka
spec:type: NodePortports:- name: zookeeper-portport: 2181nodePort: 30181targetPort: 2181selector:app: zookeeper
---
apiVersion: apps/v1
kind: Deployment
metadata:labels:app: zookeepername: zookeepernamespace: kafka
spec:replicas: 1selector:matchLabels:app: zookeepertemplate:metadata:labels:app: zookeeperspec:containers:- image: wurstmeister/zookeeperimagePullPolicy: IfNotPresentname: zookeeperports:- containerPort: 2181

运行kubectl apply -f 01-zookeeper.yaml进行部署

运行kubectl get service -n kafka,可以查看刚才成功创建的zookeeper-service的状态,记录下cluster-IP

之后就可以部署kafka了,创建一个名为02-kafka.yaml,内容如下,里面的zookeeper-internal-ip用刚才记录的cluster-IP来替代:

apiVersion: v1
kind: Service
metadata:labels:app: kafka-brokername: kafka-servicenamespace: kafka
spec:ports:- port: 9092selector:app: kafka-broker
---
apiVersion: apps/v1
kind: Deployment
metadata:labels:app: kafka-brokername: kafka-brokernamespace: kafka
spec:replicas: 1selector:matchLabels:app: kafka-brokertemplate:metadata:labels:app: kafka-brokerspec:hostname: kafka-brokercontainers:- env:- name: KAFKA_BROKER_IDvalue: "1"- name: KAFKA_ZOOKEEPER_CONNECTvalue: :2181- name: KAFKA_LISTENERSvalue: PLAINTEXT://:9092- name: KAFKA_ADVERTISED_LISTENERSvalue: PLAINTEXT://kafka-broker:9092image: wurstmeister/kafkaimagePullPolicy: IfNotPresentname: kafka-brokerports:- containerPort: 9092

运行kubectl apply -f 02-kafka.yaml进行部署。

运行kubectl get pods -n kafka,可以看到kafka和zookeeper两个pod都能正常运行。在以上的kafka的yaml文件中,我们配置了一个kafka_advertised_listeners,里面指定了kafka-broker:9092,这个是用于kafka和zookeeper之间互相通信的。我们需要在本地的/etc/hosts里面加上一条记录127.0.0.1 kafka-broker

下面我们可以测试一下kafka是否能正常工作,运行以下命令把kafka pod的9092端口暴露出来,使得可以通过访问localhost:9092来访问kafka

kubectl port-forward kafka-broker-5c55f544d4-hrgnv 9092 -n kafka

在本地安装一个名为kafkacat的工具,然后运行以下命令,往test的topic发布一条消息:

echo "hello world!" | kafkacat -P -b localhost:9092 -t test

打开另一个终端,运行以下命令,可以成功接收test主题的消息:

kafkacat -C -b localhost:9092 -t test

由此可见我们已经成功把kafka部署到k8s了

Redis

修改一下刚才的00-namespace.yaml文件,增加一个redis的命名空间,内容如下:

apiVersion: v1
kind: Namespace
metadata:name: "kafka"labels:name: "kafka"
---
apiVersion: v1
kind: Namespace
metadata:name: "redis"labels:name: "redis"

和Kafka类似,创建一个名为03-redis.yaml的文件,内容如下:

apiVersion: v1
kind: Service
metadata:labels:app: redis-mastername: redis-servicenamespace: redis
spec:ports:- port: 6379selector:app: redis-master
---
apiVersion: apps/v1
kind: Deployment
metadata:labels:app: redis-mastername: redis-masternamespace: redis
spec:replicas: 1selector:matchLabels:app: redis-mastertemplate:metadata:labels:app: redis-masterspec:hostname: redis-mastercontainers:- env:- name: MASTERvalue: "true"image: redis:5.0.4imagePullPolicy: IfNotPresentname: redis-masterports:- containerPort: 6379resources:limits:cpu: "0.1"

运行kubectl apply -f 03-redis.yaml进行部署

部署之后,我们可以运行指令kubectl exec -it --namespace=redis redis-master-5989578dfd-gnnfh -- redis-cli进入redis pod,然后可以输入指令set "product" "test"设置一个key为product,value为test的键值对,然后再输入get "product",可以正确的获取到value test

Postgresql

接下来是部署PG数据库,考虑到数据库是一个有状态的应用,当数据库的Pod出现问题失败时,K8S会自动调度一个新的Pod,但是我们不能丢失原有的数据,因此需要把数据库的文件存储在一个host path类型的volume

因为minikube本身也是作为一个docker镜像运行的,因此需要把本地的文件目录mount到minikube里面,这样才能通过hostpath的方式来使用,例如以下的命令:

minikube start --mount --mount-string="/home/roy/data/k8s_pg:/minikubeContainer/pg_data"

建立一个名为04-postgresql.yaml文件,内容如下:

apiVersion: v1
kind: Service
metadata:name: postgresql-servicelabels:app: postgresqlnamespace: postgresql
spec:ports:- port: 5432targetPort: pgselector:app: postgresqltier: pg
---
apiVersion: apps/v1
kind: Deployment
metadata:name: postgresqllabels:app: postgresqlnamespace: postgresql
spec:selector:matchLabels:app: postgresqltier: pgstrategy:type: Recreatetemplate:metadata:labels:app: postgresqltier: pgspec:volumes:- name: pgvolumehostPath:path: /datatype: Directorycontainers:- image: postgres:12name: pg12env:- name: POSTGRES_DBvalueFrom:configMapKeyRef:name: cv-configmapkey: POSTGRES_DB- name: POSTGRES_USERvalueFrom:secretKeyRef:name: cv-secretkey: POSTGRES_USERoptional: false- name: POSTGRES_PASSWORDvalueFrom:secretKeyRef:name: cv-secretkey: POSTGRES_PASSWORDoptional: falseports:- containerPort: 5432name: pgvolumeMounts:- name: pgvolumemountPath: /var/lib/postgresql/data

在这里用到了configmap和secretmap来配置Postgres的环境变量。我们可以在一个kustomization.yaml文件里面来创建这些环境变量,并且把之前创建的这些deployments组合在一起,这样就不用每次都分别创建deployment了。内容如下:

configMapGenerator:
- name: cv-configmapenvs:- cv.envnamespace: postgresql
secretGenerator:
- name: cv-secretliterals:- POSTGRES_USER=postgres- POSTGRES_PASSWORD=postgresnamespace: postgresql
resources:
- 00-namespace.yaml
- 01-zookeeper.yaml
- 02-kafka.yaml
- 03-redis.yaml
- 04-postgresql.yaml

我们可以用kubectl delete deployment把之前创建的deployment删掉,然后执行kubectl apply -k kustomizationdirectory/的命令来进行部署。

相关内容

热门资讯

再现13.08%反对票!村镇银... 来源:每日经济新闻 13.08%的反对票比例,近日在苏州农商行2026年第一次临时股东会上,吸收合并...
币安考虑重启美股代币 全球加密... 来源:滚动播报 全球多家大型加密货币交易所正竞相推出可追踪美股走势的加密代币交易服务,打造出一个不受...
男子用SIM卡炼出近200克黄... 1月20日,广东一男子用170多公斤的手机SIM卡芯片废料,经过一系列复杂工序后,成功炼出191.7...
全国共有395家网约车平台公司... 据网约车监管信息交互系统监测,截至2025年12月31日,全国共有395家网约车平台公司取得网约车平...
原创 俄... 买岛惹争议,关税当杠杆 这事儿的起点,其实很“特朗普”:把地缘政治当成一笔能谈的交易。 特朗普在20...
原创 黄... 以前,苹果一直是台积电的最大客户,其贡献的营收占台积电的总营收,超过20%,妥妥的最大金主。 所以对...
盘活土地扶持项目! 海南这场会... 1月23日,海口,全省住房城乡建设工作会议召开。 “ 海南省房地产市场呈现出房价稳、需求总量稳、核心...
慈仁堂:打造专业居家养老服务中... 一、引言:居家养老需求激增 专业服务迫在眉睫 《2025中国智慧养老行业发展白皮书》数据显示,截至2...
LVMH将成中国中免股东 1月19日晚,中国中免发布公告称,其全资孙公司中免国际与DFS新加坡、DFS香港签署《框架协议》,约...
数十万网友涌入,李亚鹏带货登总... 每经编辑|何小桃 近日,李亚鹏及嫣然天使儿童医院相关动态引起热议。 1月23日晚间,李亚鹏时隔一周...
做四维一般要多久?可能是十几分... 怀孕到了一定的时间,医生都会建议孕妈妈 孕妈妈做一个四维彩超,这样能更好的观察胎宝宝的情况。但是,我...
强化政策引导 激发消费潜力 市政协委员芮咏梅。 南京日报/紫金山新闻记者 孙中元 戚珂嘉 摄 ...
原创 4... 一提到稀土,大家脑子里蹦出来的肯定都是这几个词:中国储量多,中国产量大,中国是出口大国。 没错,过去...
罕见9连跌,历史第二次!上证5... 最近,A股市场“冰火两重天”,有色金属、国防军工、电子等行业轮番走强,而大盘蓝筹却持续阴跌。 截至1...
见证历史!纽约白银期货、伦敦现... 1月23日晚,又见证历史了。1月23日晚间,纽约白银期货、伦敦现货白银双双突破100美元历史性关口!...
原创 淘... 当电商转向价值竞争,好服务成了好增长的密钥。 原创ⓒ新熵 新消费组 作者丨栀子 编辑丨九黎 进入20...
晚上9点后别做这几件事!一个好... 太原龙城中医医院科普:对于肺结节人群而言,除了饮食、运动等日常养护,优质睡眠的重要性往往被忽视。中医...
破“7”!人民币汇率中间价调升... 北京商报讯(记者 廖蒙)1月23日,中国人民银行授权中国外汇交易中心公布,当日银行间外汇市场人民币汇...
原创 异... 在探讨异性交往的微妙关系时,我们不得不提到一个至关重要的话题——男性回家后的行为模式。高情商的女性往...
和讯投顾王海洋:大盘震荡收星,... 1月23日,和讯投顾王海洋表示,大盘震荡收星,平均股价再创新高。昨日曾提到,今日大盘大概率会再次触摸...