1、概述
通过现代的 Web 服务,用户希望应用程序能够 24/7 全天候使用,开发人员希望每天可以多次发布部署新版本的应用程序。 容器化可以帮助软件包达成这些目标,使应用程序能够以简单快速的方式发布和更新,而无需停机。这段话是Kubernetes官网描述的,也是Kubernetes可以实现的功能。
本次实例,我们用的是kubernetes1.25+docker实现nginx 部署部署、发布、升级、回滚、扩缩容。
2、部署Nginx1.14版本
2.1、命令部署
涉及命令:
-
# 获取当前pod
-
kubectl get pod
-
-
# 创建deployment 名称为mynginx 使用 镜像 nginx:1.14 副本只有一个(默认1个)
-
kubectl create deploy mynginx --image=nginx:1.14
注意:
2.2、yaml部署
命令只是为了方便我们测试运维,实际工作中我们都是以yaml来部署的,本次我们演示yaml部署
如果不知道yaml怎么写,可以动态生成一个例子,改写,然后执行即可。
- 生成yaml例子
咱们将2.1的命令生成一个yaml,命令:
-
# 此命令意思是将 mynginx输出为mynginx.yaml 并且不执行
-
kubectl create deploy mynginx --image=nginx:1.14 -o yaml --dry-run=client >
-
mynginx.yaml
mynginx.yaml内容:
-
apiVersion: apps/v1
-
kind: Deployment
-
metadata:
-
creationTimestamp: null
-
labels:
-
app: mynginx
-
name: mynginx
-
spec:
-
replicas: 1
-
selector:
-
matchLabels:
-
app: mynginx
-
strategy: {}
-
template:
-
metadata:
-
creationTimestamp: null
-
labels:
-
app: mynginx
-
spec:
-
containers:
-
- image: nginx:1.14
-
name: nginx
-
resources: {}
-
status: {}
- 改yaml内容,执行yaml部署
涉及命令:
kubectl apply -f mynginx.yaml
3、发布
应用部署完以后,只能在k8s内部可访问,外部只有在执行了发布命令后才可以访问。
3.1、命令发布
涉及命令:
-
# 将2中部署的应用 mynginx 的80 端口暴露出去
-
kubectl expose deploy mynginx --port=80 --
type=NodePort
-
-
# 查看当前暴露服务
-
kubectl get svc
现在访问任意节点:http://ip:31845
3.2、yaml发布
当然实际工作中我们也是通过yaml来发布的,同理生成发布的yaml命令
-
# 生成yaml
-
kubectl expose deploy mynginx --port=80 --
type=NodePort -o yaml --dry-run=client > expose.yaml
-
-
# 执行
-
kubectl apply -f expose.yaml
下篇文章我们详解升级、回滚、扩缩容。
转载:https://blog.csdn.net/u011837804/article/details/128395432
查看评论