本文共 2701 字,大约阅读时间需要 9 分钟。
K8S部署一个应用的流程如下
编写 yaml :deployment service ingress
1.0创建 deployment模板
kubectl create deployment nginx --image=nginx --dry-run -o yaml > deployment.yaml
1.1启动nginx pod
kubectl apply -f deployment.yaml
1.2检查pod服务
kubectl get pods
kubectl expose deployment nginx --port=80 --target-port=80 --type=NodePort --dry-run -o yaml > service.yaml
2.1.启动service服务
kubectl apply -f service.yaml
2.2检查service端口
kubectl get svcweb-dc77dd8db-7r8k5
有问题查看构建镜像的构建 helm 解决了如下管理应用的问题1. 如何将这些yaml作为一个整体管理?2. 这些yanl文件如何高效复用?3. 不支持应用级别的版本管理
wget http://120.78.77.38/file/helm-v3.0.0-linux-amd64.tar.gz#也可以去官网下载 tar -xf helm-v3.0.0-linux-amd64.tar.gz && cd linux-amd64 mv helm /usr/bin/ #将helm二进制文件拷贝到宿主机/bin下
helm search repo weave #去仓库中查找weave的程序包
helm install ui stable/weave-scope #安装
kubectl get pods 检查
ClusterIP改成 NodePort
kubectl edit svc ui-weave-scope
kubectl get svc #可以看到暴露的端口
helm upgrade web mychart
helm list 检测服务
deployment/service
关键信息创建应用vim values.yaml
replicaCount: 1image: zhangfan5391621/java-demotag: latestlabel: java-demoport: 8080
修改deployment.yaml(关键信息为变量定义信息)
vim deployment.yamlapiVersion: apps/v1kind: Deploymentmetadata: name: { { .Release.Name }}-dpspec: replicas: { { .Values.replicas }} selector: matchLabels: app: { { .Values.label }} template: metadata: labels: app: { { .Values.label }} spec: containers: - image: { { .Values.image }}:{ { .Values.tag }} name: nginx
修改service.yaml(关键信息为变量定义信息)
vim service.yamlapiVersion: v1kind: Servicemetadata: name: { { .Release.Name }}-svcspec: ports: - port: 80 protocol: TCP targetPort: { { .Values.port }} selector: app: { { .Values.label }} type: NodePort
helm install --dry-run web1 mychart/ #检测配置变量是否正确生效
#helm 扩容
helm upgraded web1 --set replicas=3 mychart/ #扩容副本3个
#回滚
helm rollback web1 1 #将web1回滚到第一个版本
转载地址:http://mqah.baihongyu.com/