1. 制作镜像
koa2应用已准备好
Dockerfile
FROM alpine:3.15.3
MAINTAINER l.hao.2012@qq.com
RUN apk add nodejs && apk add npm
RUN npm config set unsafe-perm true && npm install pm2 -g
ADD test/ /opt/test/
WORKDIR /opt/test
EXPOSE 3000
CMD ["pm2-runtime","start","bin/www"]
docker build -t 10.0.0.77/libary/test:1.5.1 -f Dockerfile .
2. 推送镜像到私有仓库
docker push 10.0.0.77/libary/test:1.5.1
3.编写YAML文件发布应用
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: koa-dp
namespace: kube-public
spec:
selector:
matchLabels:
app: koa-dp
template:
metadata:
labels:
app: koa-dp
spec:
containers:
- name: test
image: 10.0.0.77/libary/test:1.5.1
ports:
- containerPort: 3000
imagePullSecrets:
- name: harbor-secret
---
apiVersion: v1
kind: Service
metadata:
name: koa-svc
namespace: kube-public
spec:
ports:
- name: http
port: 3000
protocol: TCP
targetPort: 3000
selector:
app: koa-dp
type: ClusterIP
4.首次发布
kubectl create -f koa.yaml
4. 版本更新(滚动发布)每次代码更新执行滚动发布命令
kubectl set image deploy koa-dp test=10.0.0.77/libary/test:1.15.2 --record=true --namespace=kube-public
5. 服务访问
在master节点上nginx中加入test.conf
cat /etc/nginx/conf.d/test.conf
server{
listen 80;
server_name 10.0.0.51;
location /{
# add_header Access-Control-Allow-Origin *;
# http://koa-svc.kube-public.svc.cluster.local:3000
proxy_pass http://10.244.0.147:3000;
# proxy_set_header Host $host;
# proxy_set_header X-Real-IP $remote_addr;
# proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
6. 访问应用