容器技术入门3:chaos混沌工程

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 参加冬季实战营第四期:零基础容器技术实战。参加学习一下,教程很好,做笔记记录一下。本文记录冬季实战营第四期:零基础容器技术实战动手实战-Chaos带你快速上手混沌工程。

1. 什么是混沌工程

1.1 混沌工程的开始

2014年,Netflix团队创建了一种新的角色,叫作混沌工程师(Chaos Enigneer),并开始向工程社区推广。项目目标、业务场景、人员结构、实施方式的不同导致了对于稳定状态行为的定义不太标准。

多元化的业务场景、规模化的服务节点及高度复杂的系统架构,每天都会遇到各式各样的故障。这些故障信息就是最真实的混沌工程变量。为了能够更体感、有效率地描述故障,优先分析了P1和P2的故障,提出一些通用的故障场景并按照IaaS层、PaaS层、SaaS层的角度绘制了故障画像。

image.png

1.2. 混沌工程是什么

根据 Netflix 的解释,混沌工程师通过应用一些经验探索的原则,来学习观察系统是如何反应的。这就跟科学家做实验去学习物理定律一样,混沌工程师通过做实验去了解系统。

image.png

上图就是混沌工程的典型代表 - 猴子。拜 Netflix 所赐,现在大部分的混沌工程项目都叫做 Monkey,也就是一只讨厌的猴子,在你的系统里面上蹦下窜,不停捣乱,直到搞挂你的系统。

然后,我们需要知道,为什么需要混沌工程。应用混沌工程能提升整个系统的弹性。通过设计并且进行混沌实验,我们可以了解到系统脆弱的一面,在还没出现对用户造成伤害之前,我们就能主动发现这些问题。

“在分布式系统上进行实验的学科,目的是建立对系统承受生产环境中湍流条件能力的信心。

Chaos Engineering is the discipline of experimenting on a systemin order to build confidence in the system’s capabilityto withstand turbulent conditions in production.

1.3 混沌工程师和测试工程师区别

混沌工程其实是很重要的,但我之前一直以为混沌工程就是测试,但它们还是有区别的。虽然混沌工程跟传统测试通常都会共用很多测试工具的,譬如都会使用错误注入工具,但混沌工程是通过实践对系统有更新的认知,而传统测试则是使用特定方式对某一块进行特定测试。譬如在传统测试里面,我们可以写一个断言,我们给定特定的条件,产生一个特定的输出,如果不满足断言条件,测试就出错了,这个其实是具有很明确的特性。但混沌工程是试验,而试验会有怎样的新信息生成,我们是不确定的。譬如我们可以进行下面的这些试验:

  • 模拟整个 IDC 当掉
  • 选择一部分网络连连接注入特定时间的延迟
  • 随机让一些函数抛出异常
  • 强制 NTP 时间不同步
  • 生成 IO 错误
  • 榨干 CPU

这些试验到底会有什么样的结果,有些我们可以预料,但有些可能我们就不会预先知道,只有发生了,才会恍然大悟,有一种『喔,这也会出现!』的感叹。

2. 开源混沌工程

2012年,Netflix开源了Chaos Monkey。

项目地址:https://github.com/Netflix/chaosmonkey

image.png

2021年,阿里巴巴开源了ChaosBlade。

项目地址:https://github.com/chaosblade-io/chaosblade

image.png

其他开源工具及对比:

image.png

3. 阿里混沌工程试用

3.1 创建应用

  1. 点击右侧 图标,切换到远程桌面操作界面。
  2. 双击打开虚拟桌面的Firefox ESR浏览器,在RAM用户登录框中点击“下一步”,复制云产品资源列表中子用户密码,粘按CTRL+V把密码粘贴到密码输区,登陆子账户(后续在远程桌面里的粘贴操作均使用CTRL + V快捷键)。
  3. 复制容器服务ACK控制台地址,在FireFox浏览器打开新页签,粘贴并访问容器服务ACK控制台。

https://cs.console.aliyun.com/

  1. 集群页面,单击详情

image.png

  1. 在左侧导航栏,单击无状态

image.png

  1. 无状态页面,单击使用YAML创建资源

image.png

  1. 创建页面,复制以下代码并粘贴到模板框中,然后单击创建

apiVersion: apps/v1 kind: Deployment metadata:   name: nacos-server-app spec:   selector:     matchLabels:       app: nacos-server-app   template:     metadata:       labels:         app: nacos-server-app     spec:       containers:         - name: nacos-standalone           image: registry.cn-beijing.aliyuncs.com/ahas_demo/nacos:1.0.0           ports:             - containerPort: 8848           env:             - name: PREFER_HOST_MODE               value: "hostname"             - name: MODE               value: "standalone"           resources:             limits:               cpu: 1               memory: 2048Mi             requests:               cpu: 200m               memory: 512Mi --- apiVersion: v1 kind: Service metadata:   name: nacos-server-app spec:   type: ClusterIP   selector:     app: nacos-server-app   ports:     - name: http       port: 8848       targetPort: 8848 --- apiVersion: apps/v1 kind: Deployment metadata:   name: cart-redis spec:   selector:     matchLabels:       app: cart-redis   replicas: 1   template:     metadata:       labels:         app: cart-redis     spec:       containers:         - name: cart-redis           image: redis:alpine           imagePullPolicy: IfNotPresent           ports:             - containerPort: 6379           resources:             limits:               cpu: 1               memory: 512Mi             requests:               cpu: 200m               memory: 128Mi --- apiVersion: v1 kind: Service metadata:   labels:     app: cart-redis   name: cart-redis spec:   ports:     - port: 6379       targetPort: 6379   selector:     app: cart-redis --- apiVersion: apps/v1 kind: Deployment metadata:   name: cartservice-app spec:   selector:     matchLabels:       app: cartservice-app   template:     metadata:       labels:         app: cartservice-app     spec:       containers:         - name: cartservice-app           image: registry.cn-beijing.aliyuncs.com/ahas_demo/cartservice:1.0.0           imagePullPolicy: Always           env:             - name: dubbo.registry.address               value: "nacos://nacos-server-app:8848"             - name: spring.cloud.nacos.discovery.server-addr               value: "nacos-server-app:8848"             - name: spring.cloud.nacos.config.server-addr               value: "nacos-server-app:8848"           resources:             limits:               cpu: 1               memory: 512Mi             requests:               cpu: 200m               memory: 128Mi --- apiVersion: apps/v1 kind: Deployment metadata:   name: recommendation-service spec:   selector:     matchLabels:       app: recommendation-service   template:     metadata:       labels:         app: recommendation-service         version: 1.0.0-SNAPSHOT     spec:       containers:         - name: recommendation-service           image: registry.cn-beijing.aliyuncs.com/ahas_demo/recomendationservice:1.0.0           # imagePullPolicy: Always           env:             - name: dubbo.registry.address               value: "nacos://nacos-server-app:8848"             - name: spring.cloud.nacos.discovery.server-addr               value: "nacos-server-app:8848"             - name: spring.cloud.nacos.config.server-addr               value: "nacos-server-app:8848"           resources:             limits:               cpu: 1               memory: 512Mi             requests:               cpu: 200m               memory: 128Mi --- apiVersion: apps/v1 kind: Deployment metadata:   name: product-mysql spec:   selector:     matchLabels:       app: product-mysql   replicas: 1   strategy:     type: Recreate   template:     metadata:       labels:         app: product-mysql     spec:       containers:         - args:             - --character-set-server=utf8mb4             - --collation-server=utf8mb4_unicode_ci           env:             - name: MYSQL_DATABASE               value: product             - name: MYSQL_ROOT_PASSWORD               value: productservice           image: mysql:5.6           name: product-mysql           ports:             - containerPort: 3306           resources:             limits:               cpu: 1               memory: 512Mi             requests:               cpu: 200m               memory: 128Mi --- apiVersion: v1 kind: Service metadata:   labels:     app: product-mysql   name: product-mysql spec:   ports:     - port: 3306       targetPort: 3306   selector:     app: product-mysql --- apiVersion: apps/v1 kind: Deployment metadata:   name: product-service spec:   selector:     matchLabels:       app: product-service   template:     metadata:       labels:         app: product-service         version: 1.0.0-SNAPSHOT     spec:       containers:         - name: product-service           image: registry.cn-beijing.aliyuncs.com/ahas_demo/productservice:1.0.0           imagePullPolicy: Always           env:             - name: dubbo.registry.address               value: "nacos://nacos-server-app:8848"             - name: spring.cloud.nacos.discovery.server-addr               value: "nacos-server-app:8848"             - name: spring.cloud.nacos.config.server-addr               value: "nacos-server-app:8848"           resources:             limits:               cpu: 1               memory: 512Mi             requests:               cpu: 200m               memory: 128Mi --- apiVersion: apps/v1 kind: Deployment metadata:   name: checkout-mysql spec:   selector:     matchLabels:       app: checkout-mysql   replicas: 1   strategy:     type: Recreate   template:     metadata:       labels:         app: checkout-mysql     spec:       containers:         - args:             - --character-set-server=utf8mb4             - --collation-server=utf8mb4_unicode_ci           env:             - name: MYSQL_DATABASE               value: checkout             - name: MYSQL_ROOT_PASSWORD               value: checkoutservice           image: mysql:5.6           name: checkout-mysql           ports:             - containerPort: 3306           resources:             limits:               cpu: 1               memory: 512Mi             requests:               cpu: 200m               memory: 128Mi --- apiVersion: v1 kind: Service metadata:   labels:     app: checkout-mysql   name: checkout-mysql spec:   ports:     - port: 3306       targetPort: 3306   selector:     app: checkout-mysql --- apiVersion: apps/v1 kind: Deployment metadata:   name: checkout-service spec:   selector:     matchLabels:       app: checkout-service   template:     metadata:       labels:         app: checkout-service     spec:       containers:         - name: checkout-service           image: registry.cn-beijing.aliyuncs.com/ahas_demo/checkoutservice:health           imagePullPolicy: Always           ports:             - name: liveness-port               containerPort: 8080               protocol: TCP           env:             - name: dubbo.registry.address               value: "nacos://nacos-server-app:8848"             - name: spring.cloud.nacos.discovery.server-addr               value: "nacos-server-app:8848"             - name: spring.cloud.nacos.config.server-addr               value: "nacos-server-app:8848"           resources:             limits:               cpu: 1               memory: 512Mi             requests:               cpu: 200m               memory: 128Mi           livenessProbe:             failureThreshold: 3             httpGet:               path: /health               port: liveness-port               scheme: HTTP             initialDelaySeconds: 5             periodSeconds: 10             successThreshold: 1             timeoutSeconds: 1           startupProbe:             failureThreshold: 3             httpGet:               path: /health               port: liveness-port               scheme: HTTP             initialDelaySeconds: 40             periodSeconds: 5             successThreshold: 1 --- apiVersion: apps/v1 kind: Deployment metadata:   name: front-end spec:   selector:     matchLabels:       app: front-end   template:     metadata:       labels:         app: front-end     spec:       containers:         - name: front-end           image: registry.cn-beijing.aliyuncs.com/ahas_demo/frontend:async-test           imagePullPolicy: Always           ports:             - name: liveness-port               containerPort: 8080               protocol: TCP           env:             - name: dubbo.registry.address               value: "nacos://nacos-server-app:8848"             - name: spring.cloud.nacos.discovery.server-addr               value: "nacos-server-app:8848"             - name: spring.cloud.nacos.config.server-addr               value: "nacos-server-app:8848"           resources:             limits:               cpu: 1               memory: 512Mi             requests:               cpu: 200m               memory: 128Mi           livenessProbe:             failureThreshold: 3             httpGet:               path: /health               port: liveness-port               scheme: HTTP             initialDelaySeconds: 5             periodSeconds: 10             successThreshold: 1             timeoutSeconds: 1           startupProbe:             failureThreshold: 3             httpGet:               path: /health               port: liveness-port               scheme: HTTP             initialDelaySeconds: 60             periodSeconds: 5             successThreshold: 1 --- apiVersion: v1 kind: Service metadata:   name: front-end spec:   type: ClusterIP   selector:     app: front-end   ports:     - name: http       port: 8080       targetPort: 8080 --- apiVersion: v1 kind: Service metadata:   name: frontend-external spec:   type: LoadBalancer   selector:     app: front-end   ports:     - name: http       port: 8080       targetPort: 8080

image.png

  1. 在左侧导航栏,单击无状态
  2. 无状态页面,等待几分钟,单击刷新,容器组数量全部为1/1之后,表示应用部署完成。

注意 :

如果出现某服务无法正常启动的情况,您只需单击目标服务右侧操作列表下的更多>重新部署即可。如果遇到frontend无法正常启动的情况,此时您需要先将checkoutservice重新部署后,再将frontend重新部署即可。

image.png

  1. 无状态页面,单击frontend

image.png

  1. frontend服务页面,单击访问方式页签。

image.png

  1. frontend服务的访问方式页签,单击frontend-external服务的外部端点。

image.png

若返回如下页面,表示应用部署成功。

image.png

  1. 商品概览页面,单击任意商品,例如Air Jordan Legacy 312

image.png

  1. 商品详情页面,单击添加购物车

image.png

  1. 购物车页面,单击确认订单

image.png

若返回如下页面,表示订单支付成功。

image.png

3.2 安装探针

  1. 回到容器服务控制台页面,单击左侧导航栏上方的 图标。

image.png

  1. 集群列表页面的左侧导航栏中,单击应用目录

image.png

  1. 应用目录页面,单击ack-ahas-pilot

image.png

  1. 在ack-ahas-pilot的详情页面,单击创建

image.png

返回如下页面,表示探针已经部署完成。

image.png

3.3 通过架构感知查看系统整体架构

  1. 复制应用高可用服务控制台地址,在Firefox浏览器打开新页签,粘贴并访问容器服务应用高可用服务控制台。

https://chaos.console.aliyun.com/

  1. 概览页面顶部,选择资源所在地域。例如下图中,地域切换为华东1(杭州)。

image.png

  1. 在左侧导航栏,单击故障演练>架构感知

image.png

  1. 架构地图页面,单击Kubernetes监控视图卡片中的查看视图

image.png

  1. 架构地图页面,打开Kubernetes监控视图下拉列表,选择命令空间为default,然后单击确定即可查看实验资源的Kubernetes监控视图。

image.png

3.4 自动恢复场景演练

在分布式系统设计中有一种容错策略是故障恢复(failback),通过健康检查等机制,能在机器或者应用出现问题时自动的进行重新部署。我们利用Chaos进行故障演练,测试我们的系统是否具有这样的能力

  1. 进行稳态假设。定义一个稳态指标,来评估系统的健康状态并且在实施混沌过程当中进行监控和处理。

我们将稳态定义为 能访问我们的frontend界面,并正常使用各种购物车、下单等功能。

  1. 模拟真实事件。

2.1 切换回应用高可用服务控制台。在左侧导航栏中,单击我的空间

image.png

2.2 在演练场景页面,单击JAVA应用并选择容器内Java延迟,然后单击创建演练

image.png

2.3 在演练配置页面,完成以下操作:

(1)设置演练名称

image.png

(2)在演练对象配置向导中,演练应用选择frontend,应用分组选择frontend-group,机器列表选择任意一台机器,单击添加演练内容

image.png

(3)在演练配置页面,单击容器内Java延迟

image.png

(4)在容器内Java延迟面板中,依次输入类的全限定名方法名进程关键字目标容器名称,单击关闭

  • 类的全限定名:输入com.alibabacloud.hipstershop.web.HealthController
  • 方法名:输入health
  • 进程关键字:输入java
  • 目标容器名称:选择frontend

image.png

image.png

(5)在演练内容区域中,单击保存

image.png

(6)单击下一步

image.png

(7)在全局配置监控策略区域,单击新增策略

image.png

(8)在新增策略对话框中,选择业务监控>业务状态观察(Http),单击确定

image.png

(9)在业务状态观察(Http)面板中,请求类型选择get,URL输入http:///

说明 :

frontend的外部端点在容器服务ACK控制台frontend服务的访问方式页签中获取。

image.png

image.png

(10)在全局配置配置向导中,单击下一步

image.png

(11)在成功对话框中,单击演练详情

image.png

2.4 在演练详情页面,单击演练

image.png

2.5 在开始执行演练对话框中,单击确认

image.png

  1. 检测实验影响。

3.1 在演练记录详情页面,查看业务状态观测(Http)时序图。您可以看到health接口的调用在遇到故障之后,先降低,然后马上自动恢复至正常状态,说明我们的设计奏效了。

image.png

3.2 切换回容器服务ACK控制台,在frontend服务页面,单击事件页签。

您可以看到frontend自动的进行了扩容。

image.png

  1. 终止实验。

4.1 切换回应用高可用服务控制台。在演练记录详情页面中,单击终止

image.png

4.2 在停止演练对话框中,单击确定

image.png

4.3 等待演练场景终止之后,在结果反馈对话框中,单击确定

image.png

3.5 强弱依赖场景演练

在微服务架构中,各个服务之间存在许多依赖关系。但是当一个不重要的弱依赖宕机时,一个健壮的系统应该仍然能够正常的运行。我们利用Chaos进行故障演练,测试我们的系统处理强弱依赖的能力如何。

  1. 进行稳态假设。

1.1 切换回容器服务ACK控制台,单击frontend的外部端点。

1.2 在Hipster Shop页面,多次刷新页面。您可以看到页面商品的排序每一次都不一样。您可以理解为商品推荐服务会根据个性化进行推荐,使产品存在优先级。因此我们将稳态定义为,每次刷新页面,商品的排序不同。

image.png

  1. 模拟真实事件。

2.1 切换回应用高可用服务控制台。在左侧导航栏,单击我的空间

image.png

2.2 在演练场景页面,单击JAVA应用并选择容器内Java延迟,然后单击创建演练

image.png

2.3 在演练配置页面,完成以下操作:

(1)设置演练名称

image.png

(2)在演练对象配置向导中,演练应用选择recommendationservice,应用分组选择recommendationservice-group,机器列表选择机器,单击添加演练内容

image.png

(3)在演练内容区域中,单击容器内Java延迟

image.png

(4)在容器内Java延迟面板中,依次输入类的全限定名方法名、进程关键字目标容器名称,单击关闭。

  • 类的全限定名:输入com.alibabacloud.hipstershop.recomendationservice.service.RecommendationServiceImpl
  • 方法名:输入sortProduct
  • 进程关键字:输入java
  • 目标容器名称:选择recommendationservice

image.png

image.png

(5)在演练对象中,单击保存

image.png

(6)单击下一步

image.png

(7)在全局配置中,单击下一步

image.png

(8)在成功对话框中,单击演练详情

image.png

2.4 在演练详情页面,单击演练

image.png

2.5 在开始执行演练对话框中,单击确认

image.png

  1. 检测实验影响。

3.1 切换回容器服务ACK控制台。在无状态页面,单击frontend

image.png

3.2 在frontend页面,单击访问方式页签,然后单击frontend的外部端点。

image.png

3.3 在Hipster Shop页面,多次刷新页面。您可以发现每次刷新,产品顺序不会改变。说明推荐服务宕机,但并没有影响别的服务。

  1. 终止实验。

4.1 切换至应用高可用服务控制台,在演练记录详情页面,单击终止

image.png

4.2 在停止演练对话框中,单击确定

image.png

4.3 在结果反馈对话框中,单击确定

image.png

3.6. 失败重试场景演练

在微服务架构中,一个大系统被拆分成多个小服务,小服务之间存在大量RPC调用,经常可能因为网络抖动等原因导致RPC调用失败,这时候使用重试机制可以提高请求的最终成功率,减少故障影响,让系统运行更稳定。我们通过利用Chaos,给系统注入失败,看看系统失败重试的性能如何。

  1. 进行稳态假设。

1.1 切换回容器服务ACK控制台,在无状态页面,单击cartservice

image.png

1.2 在cartservice页面,单击伸缩

image.png

1.3 在伸缩对话框中,将所需容器组数量更改为2,单击确定

image.png

待状态变为Running,表示容器组扩容成功。

image.png

1.4 切换至Hispter Shop页面,单击购物车

image.png

返回如下页面,表示购物车服务正常。因此我们将稳态定义为,能够正常使用frontend的购物车功能。

image.png

  1. 模拟真实事件。

2.1 切换回应用高可用服务控制台,在左侧导航栏,单击我的空间

image.png

2.2 在我的空间页面,在新建演练下拉列表中单击新建空白演练

image.png

2.3 在演练配置页面,完成以下操作:

(1)设置演练名称

image.png

(2)在演练对象中,演练应用选择cartservice,应用分组选择cartservice-group,机器列表选择任意一台机器,单击添加演练内容

image.png

(3)在选择演练故障对话框中, 选择JAVA应用>抛异常>容器内Java延迟抛出自定义异常,单击确定

image.png

(4)在演练内容区域中,单击容器内Java延迟抛出自定义异常

image.png

(5)在容器内Java延迟抛出自定义异常面板中,依次输入方法名、类的全限定名异常进程关键字目标容器名称,单击关闭

  • 方法名:输入viewCart
  • 类的全限定名:输入com.alibabacloud.hipstershop.cartserviceprovider.service.CartServiceImpl
  • 异常:输入java.lang.Exception
  • 进程关键字:输入java
  • 目标容器名称:选择cartservice。

image.png

image.png

(6)在演练对象中,单击保存

image.png

(7)单击下一步

image.png

(8)在全局配置中,单击下一步

image.png

(9)在成功对话框中,单击演练详情

image.png

2.4 在演练详情页面,单击演练

image.png

2.5 在开始执行演练对话框中,单击确认

image.png

  1. 检测实验影响。

3.1 切换至Hispter Shop页面,单击购物车

image.png

返回如下页面,您发现无法访问购物车。这是因为流量并没有切换到没有宕机的那台机器,同时 说明我们的系统并没有失败重试的能力,或者是一开始就没有设计,或者是没有生效。通过这次故障注入,我们发现了系统的缺陷。

image.png

3.2 切换至应用高可用服务控制台,在演练记录详情页面,单击终止

image.png

3.3 在停止演练对话框中,单击确定

image.png

3.4 在结果反馈对话框中,单击确定

image.png

返回如下页面,表示演练结束。

image.png

3.7. 微服务演练

在体验了上述三个场景演练之后,我们对混沌工程有了初步的了解,也掌握了应用高可用服务的基本功能。但是这样手动部署参数的过程还是比较繁琐的。接下来我们体验一下更为方便快捷的强弱依赖治理。

  1. 切换至应用高可用服务控制台。在左侧导航栏中,单击微服务演练

image.png

并选择强弱依赖治理页面。

image.png

  1. 强弱依赖治理页面中,单击创建治理方案

image.png

  1. 创建治理方案的配置向导页面,完成以下操作。

3.1 在应用接入中,自定义方案名称,治理应用选择frontend,单击下一步

image.png

3.2 在强弱依赖治理以30天为治理周期对话框中,单击确认

image.png

3.3 在依赖分析中,等待分析完成,单击下一步

image.png

3.4 在依赖预判中,自行选择依赖对象的强弱依赖预判,例如nacos-standalone和checkoutservice的强弱依赖预判可选择强依赖,其他依赖对象默认弱依赖,然后单击下一步

image.png

3.5 在依赖验证中,选择任意用例进行验证。例如选择frontend与nacos-standalone强弱依赖验证用例,单击去验证

image.png

3.6 在去验证前的参数确认对话框中,单击确定验证

image.png

注意:

如果窗口没有跳转,请注意跳转是否被拦截,请手动解除

  1. 在演练详情页面中,单击演练

image.png

  1. 开始执行演练对话框中,单击确认

image.png

  1. 切换至Hipster Shop页面,单击网页的任意功能。您可以发现Hipster Shop网页和相关功能均可以正常访问,说明frontend服务与nacos-standalone服务是弱依赖关系。
  2. 切换至应用高可用服务控制台,在演练记录详情页面,单击终止

image.png

  1. 停止演练对话框中,单击确定

image.png

  1. 结果反馈对话框中,结论选择不符合预期验证结果选择弱依赖,单击确定,返回强弱依赖治理

image.png

  1. 在依赖验证中,您可以验证其他用例,验证完成后,单击方案归档

image.png

  1. 您确定要归档此方案吗对话框中,单击确认归档

image.png

返回如下页面,表示归档完毕。

image.png

您还可以通过使用MSHA快速体验异地、同城多活容灾。动手实验室地址:https://developer.aliyun.com/adc/scenario/998a993afe624e3eadcf5f8f6b791064

参考:

混沌工程(Chaos Engineering) 到底是什么? - 云+社区 - 腾讯云 (tencent.com)

浩鲸科技基于ChaosBlade的混沌工程实践 (qq.com)

Chaos带你快速上手混沌工程

相关实践学习
使用ACS算力快速搭建生成式会话应用
阿里云容器计算服务 ACS(Container Compute Service)以Kubernetes为使用界面,采用Serverless形态提供弹性的算力资源,使您轻松高效运行容器应用。本文将指导您如何通过ACS控制台及ACS集群证书在ACS集群中快速部署并公开一个容器化生成式AI会话应用,并监控应用的运行情况。
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
3月前
|
存储 容器
46.[HarmonyOS NEXT RelativeContainer案例三] 打造自适应容器:内容驱动的智能尺寸调整技术
在HarmonyOS NEXT的UI开发中,创建能够根据内容自动调整尺寸的容器是实现灵活布局的关键。RelativeContainer结合自适应尺寸设置,可以实现内容驱动的智能尺寸调整,使UI更加灵活且易于维护。本教程将详细讲解如何创建自适应尺寸的RelativeContainer,帮助你掌握这一实用技术。
127 5
|
1月前
|
Kubernetes Cloud Native 持续交付
Docker:轻量级容器化技术解析
Docker:轻量级容器化技术解析
|
1月前
|
运维 测试技术 Docker
Docker:轻量级容器化技术革命
Docker:轻量级容器化技术革命
|
9月前
|
Kubernetes Cloud Native 微服务
探索云原生技术:容器化与微服务架构的融合之旅
本文将带领读者深入了解云原生技术的核心概念,特别是容器化和微服务架构如何相辅相成,共同构建现代软件系统。我们将通过实际代码示例,探讨如何在云平台上部署和管理微服务,以及如何使用容器编排工具来自动化这一过程。文章旨在为开发者和技术决策者提供实用的指导,帮助他们在云原生时代中更好地设计、部署和维护应用。
|
5月前
|
弹性计算 Java Maven
从代码到容器:Cloud Native Buildpacks技术解析
Cloud Native Buildpacks(CNB)是一种标准化、云原生的容器镜像构建系统,旨在消除手动编写Dockerfile,提供可重复、安全且高效的构建流程。它通过分层策略生成符合OCI标准的镜像,实现应用与基础镜像解耦,并自动化依赖管理和更新。阿里云应用管理支持通过CNB技术一键部署应用至ECS,简化构建和运行流程。
|
6月前
|
存储 虚拟化 Docker
|
6月前
|
开发工具 虚拟化 git
自学软硬件第755 docker容器虚拟化技术youtube视频下载工具
docker容器虚拟化技术有什么用?怎么使用?TubeTube 项目使用youtube视频下载工具
|
7月前
|
存储 SQL 索引
Python入门:7.Pythond的内置容器
Python 提供了强大的内置容器(container)类型,用于存储和操作数据。容器是 Python 数据结构的核心部分,理解它们对于写出高效、可读的代码至关重要。在这篇博客中,我们将详细介绍 Python 的五种主要内置容器:字符串(str)、列表(list)、元组(tuple)、字典(dict)和集合(set)。
Python入门:7.Pythond的内置容器
|
7月前
|
存储 缓存 C++
C++ 容器全面剖析:掌握 STL 的奥秘,从入门到高效编程
C++ 标准模板库(STL)提供了一组功能强大的容器类,用于存储和操作数据集合。不同的容器具有独特的特性和应用场景,因此选择合适的容器对于程序的性能和代码的可读性至关重要。对于刚接触 C++ 的开发者来说,了解这些容器的基础知识以及它们的特点是迈向高效编程的重要一步。本文将详细介绍 C++ 常用的容器,包括序列容器(`std::vector`、`std::array`、`std::list`、`std::deque`)、关联容器(`std::set`、`std::map`)和无序容器(`std::unordered_set`、`std::unordered_map`),全面解析它们的特点、用法
C++ 容器全面剖析:掌握 STL 的奥秘,从入门到高效编程
|
9月前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
277 5