企业级运维之云原生与Kubernetes实战课程 - 第二章第2讲 阿里云容器服务集群应用管理

简介: 本小节主要内容为集群中应用管理,包括如何在控制台进行应用的创建及创建应用过程中详细配置的介绍。

企业级运维之云原生与Kubernetes实战课程

第二章第2讲 阿里云容器服务集群应用管理

 

 

视频地址:https://developer.aliyun.com/learning/course/913/detail/14504

 

摘要:本小节主要内容为集群中应用管理,包括如何在控制台进行应用的创建及创建应用过程中详细配置的介绍。

 

目录

 

  • 控制台使用
  • 详细配置介绍

 

一、控制台使用

 

1.  如何在控制台创建应用

 image.png

 

  • 登录阿里云控制台,点击容器服务,选择集群,选择无状态服务进行应用创建;
  • 设置deployment名称、Pod副本数量、服务类型也可选择配置多个container容器,然后选择镜像、镜像tag、镜像拉取策略、配置容器资源限制、设置初始化容器(init Container)、容器端口(页面设置的端口类似注释功能,不等价于启动了该端口)、健康检查、生命周期、数据卷、日志服务;
  • 点击下一步“高级配置”,可以创建SVCdeployment建立对应关系、路由(通过路由访问后端Pod)、HPA(自动伸缩配置)、节点亲和性、反亲和性、污点、标签、注解等配置,点击完成应用的创建。

 

二、详细配置介绍

 image.png

 

1. 健康检查

 

a.  健康检查以下三种类型:

 

  • 存活检查:检查容器内应用是否运行正常,有三种探测方式,Http请求(对Pod内发起http服务请求,根据返回状态码进行判断服务是否正常)、Tcp连接(四层探测,配置探测端口,通过三次握手进行探测)、命令行(在容器内运行某个脚本,如果返回为0则通过探测,否则探测不通过);
  • 就绪检查:判断应用是否准备完成,检查方式与存活检查类似;
  • 启动探测:检查方式与存活检查类似。

 

b.  存活检查与就绪检查的区别:

 

  • 当应用启动后首先会通过就绪检查,才会将流量通过SVC转发到后端的Pod中,如果就绪检查不通过,容器的IP和端口将不会加到SVCEndpoint中,即流量不会转发到该Pod中;
  • 是否有流量进来与存活检查无关,如果存活检查不通过,会将Pod进行Kill,重启该Pod

 

2.  Pod生命周期

 

a.  设置Pod生命周期参数:

 

  • 启动执行:设置进程的启动参数;
  • 启动后处理:为容器设置启动后的命令,对应程序中postStart字段;
  • 停止前处理:为容器设置预结束命令,对应程序中preStop字段。

 

示例:定义postStartpreStop字段,如:

 

apiVersion: v1

kind: Pod

metadata:

 name: lifecycle-demo

spec:

 containers:

 - name: lifecycle-demo-container

   image: nginx

   lifecycle:

     postStart:

       exec:

command: ["/bin/sh", "-c", "echo Hello from the postStart handler > /usr/share/message"]

     preStop:

       exec:

command: ["/bin/sh","-c","nginx -s quit; while killall -0 nginx; do sleep 1; done"]

 

在上述配置文件中,你可以看到postStart命令在容器的/usr/share目录下写入文件message。命令preStop负责优雅地终止nginx服务。当因为失效而导致容器终止时,这一处理方式很有用

 

b.  当停止一个应用时,Pod状态是如何变化的?

 image.png

 

  • 如上图,首先Pod处于Running状态,在某一时刻删除或者更新该Pod副本,此时该Podendpoint会从SVC中摘除,新的流量将不会再打到该Pod上,Pod处于terminating状态,节点上kubelet会给Pod内进程发送一个kill信号,应用被杀掉,如果应用上仍有业务在进行,会导致应用不平滑;
  • 如果Pod配置了postStart,设置sleep一段时间保证业务完成后,kubelet再给Pod中的进程发送一个kill信号,这样就保证了业务在退出前可以完成所有请求。

 

3.  数据卷

 

数据卷可以选择本地存储和云存储:

 

  • 本地存储:可以选择挂载配置项(configMap)、保密字典(密钥)、临时目录,如主机目录/tmp目录挂载到容器/tmp目录中;
  • 云存储:可以选择OSSNAS,然后选择容器挂载目录;

 

日志服务可以通过配置日志库和填写容器日志路径配置日志采集。

 

四.本讲小结

 

容器镜像服务以及服务的管理,包括:

 

1.  阿里云容器镜像企业版/默认版,harbor,区别,优劣势。

2.  Configmap/secretConfigmap保存的为明文配置信息,secret保存的为敏感信息。

3.  镜像拉取密钥:创建一个secret,将secret添加到deployment里面的imagePullSecret

4.  Secretpatchserviceaccount实现免密拉取镜像。

5.  ACR免密拉取插件配置,原理,使用场景。

6.  创建deployment,参数:镜像地址,镜像拉取策略,健康检查配置,存活检查/就绪检查的原理以及区别。

7.  preStoppostStart特点以及应用。

8.  SecretACR免密拉取插件常见的问题以及定位方法。

 

 

相关实践学习
Docker镜像管理快速入门
本教程将介绍如何使用Docker构建镜像,并通过阿里云镜像服务分发到ECS服务器,运行该镜像。
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
Kubernetes Cloud Native 微服务
探索云原生技术:容器化与微服务架构的融合之旅
本文将带领读者深入了解云原生技术的核心概念,特别是容器化和微服务架构如何相辅相成,共同构建现代软件系统。我们将通过实际代码示例,探讨如何在云平台上部署和管理微服务,以及如何使用容器编排工具来自动化这一过程。文章旨在为开发者和技术决策者提供实用的指导,帮助他们在云原生时代中更好地设计、部署和维护应用。
668 59
|
11月前
|
Cloud Native 中间件 调度
云原生信息提取系统:容器化流程与CI/CD集成实践
本文介绍如何通过工程化手段解决数据提取任务中的稳定性与部署难题。结合 Scrapy、Docker、代理中间件与 CI/CD 工具,构建可自动运行、持续迭代的云原生信息提取系统,实现结构化数据采集与标准化交付。
1212 1
云原生信息提取系统:容器化流程与CI/CD集成实践
|
Kubernetes Cloud Native 区块链
Arista cEOS 4.30.10M - 针对云原生环境设计的容器化网络操作系统
Arista cEOS 4.30.10M - 针对云原生环境设计的容器化网络操作系统
425 0
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
846 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
供应链 安全 Cloud Native
阿里云容器服务助力企业构建云原生软件供应链安全
本文基于2024云栖大会演讲,探讨了软件供应链攻击的快速增长趋势及对企业安全的挑战。文中介绍了如何利用阿里云容器服务ACK、ACR和ASM构建云原生软件供应链安全,涵盖容器镜像的可信生产、管理和分发,以及服务网格ASM实现应用无感的零信任安全,确保企业在软件开发和部署过程中的安全性。
|
存储 人工智能 调度
容器服务:智算时代云原生操作系统及月之暗面Kimi、深势科技实践分享
容器技术已经发展成为云计算操作系统的关键组成部分,向下高效调度多样化异构算力,向上提供统一编程接口,支持多样化工作负载。阿里云容器服务在2024年巴黎奥运会中提供了稳定高效的云上支持,实现了子弹时间特效等创新应用。此外,容器技术还带来了弹性、普惠的计算能力升级,如每分钟创建1万Pod和秒级CPU资源热变配,以及针对大数据与AI应用的弹性临时盘和跨可用区云盘等高性能存储解决方案。智能运维方面,推出了即时弹性节点池、智能应用弹性策略和可信赖集群托管运维等功能,进一步简化了集群管理和优化了资源利用率。
|
监控 安全 Cloud Native
阿里云容器服务&云安全中心团队荣获信通院“云原生安全标杆案例”奖
2024年12月24日,阿里云容器服务团队与云安全中心团队获得中国信息通信研究院「云原生安全标杆案例」奖。
|
人工智能 Kubernetes Cloud Native
阿里云容器服务,智算时代云原生操作系统
2024云栖大会,阿里巴巴研究员易立分享了阿里云容器服务的最新进展。容器技术已成为云原生操作系统的基石,支持多样化的应用场景,如自动驾驶、AI训练等。阿里云容器服务覆盖公共云、边缘云、IDC,提供统一的基础设施,助力客户实现数字化转型和技术创新。今年,阿里云在弹性计算、网络优化、存储解决方案等方面进行了多项重要升级,进一步提升了性能和可靠性。
|
Kubernetes Cloud Native Docker
云原生之旅:从容器化到微服务
本文将带领读者踏上云原生的旅程,深入探讨容器化和微服务架构的概念、优势以及它们如何共同推动现代软件的发展。我们将通过实际代码示例,展示如何在Kubernetes集群上部署一个简单的微服务应用,并解释相关的配置和操作。无论你是云原生新手还是希望深化理解,这篇文章都将为你提供有价值的见解和实操指南。
|
Kubernetes Cloud Native 开发者
云原生入门:从容器到微服务
本文将带你走进云原生的世界,从容器技术开始,逐步深入到微服务架构。我们将通过实际代码示例,展示如何利用云原生技术构建和部署应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和启示。

相关产品

  • 容器服务Kubernetes版