Docker 与 K8S学习笔记(十七)—— 在K8S集群中部署应用

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: 我们今天来通过在在K8S集群中部署web应用来体验一下K8S的使用,我们需要提前准备一个基于springboot的web应用镜像,这个应用也很简单,就一个hello接口: @RestController @RequestMapping("/api") public class ApiControll

Docker 与 K8S学习笔记(十七)—— 在K8S集群中部署应用


我们今天来通过在在K8S集群中部署web应用来体验一下K8S的使用,我们需要提前准备一个基于springboot的web应用镜像,这个应用也很简单,就一个hello接口:


@RestController
@RequestMapping("/api")
public class ApiController {
    @GetMapping("/hello")
    public String hello() {
        return "Hello my friend";
    }
}

 

一、创建Deployment


我们首先创建Deployment文件webapp.yaml,内容如下:


apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    app: webapp
  name: webapp
spec:
  replicas: 2
  selector:
    matchLabels:
      app: webapp
  template:
    metadata:
      labels:
        app: webapp
    spec:
      containers:
      - name: webapp
        image: 172.16.194.135:5000/webapp:latest
        ports:
        - containerPort: 4567


对于这个文件,这里有几个属性需要说明下:


  • replicas:定义Pod的副本数量


  • selector:目标Pod的标签选择器


  • template:用于自动创建新Pod副本的模板


接着我们使用如下命令创建Deployment对象:


$ sudo kubectl apply -f webapp.yaml
deployment.apps/webapp created

我们来看下Deployment的信息:


$ sudo kubectl get deployments
NAME     READY   UP-TO-DATE   AVAILABLE   AGE
webapp   2/2     2            2           5s


  • READY:当前Pod数与期望Pod数


  • UP-TO-DATE:最新版本的Pod数量,用于指示在滚动升级的过程中,有多少个Pod副本已经成功升级


  • AVAILABLE:当前集群中可用的Pod副本数量,即当前集群中存储的Pod数量


我们通过Deployment信息可以看到Pod都启动完毕,通过一下命令可以查看Pod信息:


$ sudo kubectl get pods
NAME                      READY   STATUS    RESTARTS   AGE
webapp-5fb8547b77-d9txl   1/1     Running   0          8m7s
webapp-5fb8547b77-jtmt7   1/1     Running   0          8m7s


我们还可以通过docker命令查看正在运行的容器信息,我们可以发现除了webapp容器外还有pause容器,这个就是Pod的根容器:


$ sudo docker ps | grep webapp
f098a5f6e54e   172.16.194.135:5000/webapp                                      "java -jar /opt/soft…"   8 minutes ago       Up 8 minutes                                                   k8s_webapp_webapp-5fb8547b77-d9txl_default_cc7450ec-3949-4051-9c4b-b955195fcb87_0
7146447c160e   172.16.194.135:5000/webapp                                      "java -jar /opt/soft…"   8 minutes ago       Up 8 minutes                                                   k8s_webapp_webapp-5fb8547b77-jtmt7_default_fbf22e91-f72a-439e-ac92-74f1ec76487b_0
332672e7ad5a   registry.cn-hangzhou.aliyuncs.com/google_containers/pause:3.2   "/pause"                 8 minutes ago       Up 8 minutes                                                   k8s_POD_webapp-5fb8547b77-d9txl_default_cc7450ec-3949-4051-9c4b-b955195fcb87_0
816e9e983d7c   registry.cn-hangzhou.aliyuncs.com/google_containers/pause:3.2   "/pause"                 8 minutes ago       Up 8 minutes


Deployment资源对象其实还与ReplicaSet资源对象密切相关,Kubernetes内部会根据Deployment对象自动创建相关联的ReplicaSet对象,我们通过以下命令来看看ReplicaSet对象信息:


$ sudo kubectl get replicasets
NAME                DESIRED   CURRENT   READY   AGE
webapp-5fb8547b77   2         2         2       4m48s

 

二、创建Service


最后我们创建一个Service文件webapp_service.yaml,其文件内容如下:


apiVersion: v1
kind: Service
metadata:
  name: webapp
spec:
  type: NodePort
  ports:
  - port: 4567
    nodePort: 30001
  selector:
    app: webapp


其中,metadata.name是Service的服务名,spec.type设置为NodePort意味着这个服务开启了NodePort格式的外网访问模式,这样在集群外就可以通过客户端访问此服务,spec.selector确定了哪些Pod关联于本服务。接下来我们通过如下命令创建Service对象:


$ sudo kubectl create -f webapp_service.yaml
service/webapp created


我们来看看所创建的Service的信息:


$ sudo kubectl get svc webapp
NAME     TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)    AGE
webapp   ClusterIP   10.108.237.8   <none>        4567/TCP   2m32s


我们可以看到kubernetes集群为webapp服务分配了一个10.108.237.8地址,这意味着在集群中其它Pod都可以通过此IP+端口号来访问。


截至目前我们的webapp应用已经部署上去了,我们通过浏览器访问对应URL:


 

分类: 容器技术

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
8天前
|
存储 Kubernetes 负载均衡
CentOS 7.9二进制部署K8S 1.28.3+集群实战
本文详细介绍了在CentOS 7.9上通过二进制方式部署Kubernetes 1.28.3+集群的全过程,包括环境准备、组件安装、证书生成、高可用配置以及网络插件部署等关键步骤。
72 3
CentOS 7.9二进制部署K8S 1.28.3+集群实战
|
9天前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
8天前
|
虚拟化 Docker Windows
window 10专业版部署docker环境
本文介绍了如何在Windows 10专业版上部署Docker环境,包括安装步骤、配置镜像加速以及可能遇到的错误处理。
25 2
window 10专业版部署docker环境
|
8天前
|
Kubernetes 负载均衡 前端开发
二进制部署Kubernetes 1.23.15版本高可用集群实战
使用二进制文件部署Kubernetes 1.23.15版本高可用集群的详细教程,涵盖了从环境准备到网络插件部署的完整流程。
18 2
二进制部署Kubernetes 1.23.15版本高可用集群实战
|
5天前
|
Kubernetes Docker Python
如何在K8s中使用Python应用
一文带你了解如何在K8s中使用Python应用
15 4
|
8天前
|
存储 Kubernetes Ubuntu
Ubuntu 22.04LTS版本二进制部署K8S 1.30+版本
这篇文章详细介绍了在Ubuntu 22.04 LTS系统上使用VMware Fusion虚拟化软件部署Kubernetes 1.30+版本的完整过程,包括环境准备、安装containerd、配置etcd、生成证书、部署高可用组件、启动Kubernetes核心组件以及网络插件的部署和故障排查。
36 4
|
8天前
|
Kubernetes Ubuntu 网络安全
Ubuntu基于kubeadm快速部署K8S实战
关于如何在Ubuntu系统上使用kubeadm工具快速部署Kubernetes集群的详细实战指南。
42 2
|
9天前
|
Kubernetes Linux API
CentOS 7.6使用kubeadm部署k8s 1.17.2测试集群实战篇
该博客文章详细介绍了在CentOS 7.6操作系统上使用kubeadm工具部署kubernetes 1.17.2版本的测试集群的过程,包括主机环境准备、安装Docker、配置kubelet、初始化集群、添加节点、部署网络插件以及配置k8s node节点管理api server服务器。
37 0
CentOS 7.6使用kubeadm部署k8s 1.17.2测试集群实战篇
|
9天前
|
Kubernetes 容器
Kubernetes附加组件Dashboard部署实战篇
关于如何在Kubernetes集群中部署和配置Dashboard组件的详细实战指南,涵盖了从创建证书、部署Dashboard、设置服务访问到登录认证的完整流程。
44 0
Kubernetes附加组件Dashboard部署实战篇
|
9天前
|
NoSQL 关系型数据库 数据库
JumpServer的Docker部署实战案例
JumpServer的Docker部署实战案例,详细介绍了JumpServer的概述、环境准备、基于Docker的快速部署步骤,以及如何访问JumpServer的WebUI。
11 0