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

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 本小节主要内容为集群中应用管理,包括如何在控制台进行应用的创建及创建应用过程中详细配置的介绍。

企业级运维之云原生与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免密拉取插件常见的问题以及定位方法。

 

 

相关实践学习
通过容器镜像仓库与容器服务快速部署spring-hello应用
本教程主要讲述如何将本地Java代码程序上传并在云端以容器化的构建、传输和运行。
Kubernetes极速入门
Kubernetes(K8S)是Google在2014年发布的一个开源项目,用于自动化容器化应用程序的部署、扩展和管理。Kubernetes通常结合docker容器工作,并且整合多个运行着docker容器的主机集群。 本课程从Kubernetes的简介、功能、架构,集群的概念、工具及部署等各个方面进行了详细的讲解及展示,通过对本课程的学习,可以对Kubernetes有一个较为全面的认识,并初步掌握Kubernetes相关的安装部署及使用技巧。本课程由黑马程序员提供。   相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
17天前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker和Kubernetes入门
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术成为企业提升敏捷性和效率的关键。本篇文章将引导读者了解如何利用Docker进行容器化打包及部署,以及Kubernetes集群管理的基础操作,帮助初学者快速入门云原生的世界。通过实际案例分析,我们将深入探讨这些技术在现代IT架构中的应用与影响。
59 2
|
23天前
|
Java 应用服务中间件 Linux
【Docker容器化技术】docker安装与部署、常用命令、容器数据卷、应用部署实战、Dockerfile、服务编排docker-compose、私有仓库
本文主要讲解了Docker的安装与部署、常用命令、容器数据卷、应用部署实战、Dockerfile、服务编排docker-compose、私有仓库以及Docker容器虚拟化与传统虚拟机比较。
294 11
【Docker容器化技术】docker安装与部署、常用命令、容器数据卷、应用部署实战、Dockerfile、服务编排docker-compose、私有仓库
|
9天前
|
Kubernetes Cloud Native Docker
云原生之旅:从传统架构到容器化服务的演变
随着技术的快速发展,云计算已经从简单的虚拟化服务演进到了更加灵活和高效的云原生时代。本文将带你了解云原生的概念、优势以及如何通过容器化技术实现应用的快速部署和扩展。我们将以一个简单的Python Web应用为例,展示如何利用Docker容器进行打包和部署,进而探索Kubernetes如何管理这些容器,确保服务的高可用性和弹性伸缩。
|
7天前
|
Kubernetes Linux 开发者
深入探索容器化技术——Docker 的实战应用
深入探索容器化技术——Docker 的实战应用
34 5
|
13天前
|
Kubernetes 监控 Cloud Native
Kubernetes集群的高可用性与伸缩性实践
Kubernetes集群的高可用性与伸缩性实践
46 1
|
18天前
|
Kubernetes Cloud Native Docker
云原生技术探索:容器化与微服务的实践之道
【10月更文挑战第36天】在云计算的浪潮中,云原生技术以其高效、灵活和可靠的特性成为企业数字化转型的重要推手。本文将深入探讨云原生的两大核心概念——容器化与微服务架构,并通过实际代码示例,揭示如何通过Docker和Kubernetes实现服务的快速部署和管理。我们将从基础概念入手,逐步引导读者理解并实践云原生技术,最终掌握如何构建和维护一个高效、可扩展的云原生应用。
|
27天前
|
Kubernetes 负载均衡 Cloud Native
云原生应用:Kubernetes在容器编排中的实践与挑战
【10月更文挑战第27天】Kubernetes(简称K8s)是云原生应用的核心容器编排平台,提供自动化、扩展和管理容器化应用的能力。本文介绍Kubernetes的基本概念、安装配置、核心组件(如Pod和Deployment)、服务发现与负载均衡、网络配置及安全性挑战,帮助读者理解和实践Kubernetes在容器编排中的应用。
72 4
|
26天前
|
Cloud Native 持续交付 云计算
云原生入门指南:从容器到微服务
【10月更文挑战第28天】在数字化转型的浪潮中,云原生技术成为推动现代软件开发的关键力量。本篇文章将带你了解云原生的基本概念,探索它如何通过容器化、微服务架构以及持续集成和持续部署(CI/CD)的实践来提升应用的可伸缩性、灵活性和可靠性。你将学习到如何利用这些技术构建和部署在云端高效运行的应用,并理解它们对DevOps文化的贡献。
52 2
|
28天前
|
Kubernetes 监控 Cloud Native
云原生应用:Kubernetes在容器编排中的实践与挑战
【10月更文挑战第26天】随着云计算技术的发展,容器化成为现代应用部署的核心趋势。Kubernetes(K8s)作为容器编排领域的佼佼者,以其强大的可扩展性和自动化能力,为开发者提供了高效管理和部署容器化应用的平台。本文将详细介绍Kubernetes的基本概念、核心组件、实践过程及面临的挑战,帮助读者更好地理解和应用这一技术。
62 3
|
2月前
|
JSON Kubernetes 容灾
ACK One应用分发上线:高效管理多集群应用
ACK One应用分发上线,主要介绍了新能力的使用场景

相关产品

  • 容器服务Kubernetes版