品高公开课 | 基于Docker容器的微服务架构实践

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介:

小编的话

“品高公开课”系列文章意在分享技术牛人的知识干货,每期主题都不一样哟!期待各位读者在文后发表留言,来一场技术上的交流和思想上的碰撞!

微服务以一种全新的架构设计模式,牵动了互联网应用从设计到运维整个流程方法论的变革。 而以Docker为代表的容器技术则为微服务理念提供了匹配的实现机制。本周五,将由品高软件工程师陈洪杰带讲述微服务架构的故事

分享嘉宾

陈洪杰,目前就任品高广州云架构产品部--BingoCloud平台的软件开发工程师,拥有Docker,LXC等多个容器平台的项目经验,15年开始转向弹性容器服务(ECS)的研究,主要负责弹性容器服务的规划、设计和开发。

分享正文

随着市场的快速发展,业务的不断扩大,传统的单体应用架构面临着越来越多的挑战。微服务架构(Microservices Architecture)的诞生,对软件架构领域所带来的影响毋庸置疑。

为什么微服务架构比单体应用架构,在研发过程中更加敏捷和灵活呢?先从单体应用的架构说起。下图是一个比较经典的单体应用架构,来自Chris Richardson的《微服务系列》:

比较经典的单体应用架构

上图表示一款与滴滴或者Uber竞争的打车软件,这款新应用采用了传统的六边形架构模式。根据不同的功能需求,分成了多个不同的模块。各个模块之间直接通过API调用,互相协同工作。

由于IDE擅长构建单体应用,采用这种架构的应用非常普遍。这类应用也可以很轻松下断点测试。单体应用也便于部署,只需将软件包复制到服务器,简单配置后即可良好运行。在项目早期这么做非常有效。

但当几年过去了,随着功能的扩展,项目就变得臃肿,不够灵活。同时,开发者必须对整个应用的架构和模块,有一定程度的了解,才可能对它进行修改。而且项目可靠性差,难以持续开发、部署,扩展困难。

典型的打车软件微服务架构图

不同于单体应用,微服务架构将各个功能模块拆分成独立的服务,服务与服务之间通过REST API交流。不同的服务有自己的功能、数据库和REST API。

这种微服务架构有什么特点呢?

1. 业务功能驱动设计:不同的功能做成不同的服务,例如根据用户界面、用户管理、司机界面、司机管理、账单管理、账单支付等不同的功能,做成不同的服务;

2. 单一职责原则:每一个服务,它的功能应该都是单一的,如果有多个功能,则做成多个服务为宜,例如用户界面和用户管理就分成单独的服务;

3. 明确发布接口:接口一旦发布了,就不要轻易更改,因为更改了很可能会导致所有服务都要进行相应的更改,服务的消费者也只需要关心接口,无需关心服务的内部实现;

4. 轻量级通信:服务与服务之间,通过简单的、轻量级的通讯协议交流即可,例如,同步的REST,异步的AMQP、STOMP、MQTT等;

5. 可以异构/采用多种语言栈:每个服务的实现细节都与其它服务无关,这使得服务之间能够解耦,团队可以针对每个服务选择最合适的开发语言、持久化存储、工具和方法;

6. 独立部署、升级、扩展和替换:每个服务都可以单独部署及重新部署而不影响整个系统。这使得服务很容易升级,扩展和替换;

对应的,微服务架构有如下的优点:

1. 复杂度可控,易于开发、理解和维护;

2. 局部修改很容易部署,有利于持续集成和持续交付;

3. 故障隔离,一个服务出现问题不会影响整个应用;

4. 弹性伸缩、扩展方便,根据需求分配不同的资源;

5. 技术选型灵活,可以根据需求选择合适的技术;

同时,微服务架构也有着它的缺点:

1. 数据一致性难以保证;

2. 分布式调用造成的性能、延迟和可靠性问题;

3. 不同服务之间的依赖问题,导致复杂度增加;

4. 部署复杂,配置、部署、扩展和监控难度大;

目前,很多服务都是单体应用架构,这些老的应用该如何过渡到微服务架构呢?一般来说,都是采取以下的方式:

1. 为新功能特性创建微服务,原有的单体应用保持不变或仅做必要的修改;

2. 根据业务功能各自剥离为微服务;

3. 按照业务功能价值和需要安排优先级;

4. 不追求完全消灭单体应用;

Docker的诞生

在单体应用越来越难以满足人们需要的时候,Docker诞生了。作为一个在最近这几年异军突起的技术,仿佛就是为了微服务架构而生。每个Docker容器,只运行一个微服务。从此,开发人员摆脱了单体应用架构带来的负担,使每天都更新线上项目不再是一个梦想。

Docker容器,是类似JVM但比其更强大的容器,基于Linux内核。支持各种语言。它比VM虚拟机更加轻量,能够在云计算IaaS等平台上直接运行,使用户的应用无缝地移植到各种运行环境。

一般来说,Docker容器服务也叫弹性容器服务(ECS),或者容器云。在Docker越来越火的今天,在国内外都有很多提供弹性容器服务的提供商。例如国外的亚马逊、Tutum云和CoreOS,国内的DaoCloud、网易蜂巢、时速云和灵雀云等等。

如果要使用弹性容器服务,则必须从开发阶段开始,以微服务架构的形式开发应用,或者对现有的单体应用进行解耦。

开发、测试、部署流程示意图

开发、测试、部署流程简介:

1. 运维人员在ECS上搭建私有Docker Registry;

2. 开发人员在开发ECS上从DockerHub或私有DockerRegistry获取应用需要的基础镜像;

3. 开发人员开发ECS上构造应用容器,自测后提交容器为新的镜像并推送到私有Docker Registry,通知QA测试;

4. QA在自己的测试ECS上启动容器,测试后,有问题则a,没问题则b:

a. 通知开发修复,回到步骤3;

b. 提交到私有Docker Registry,准备发布;

5. 发布人员下载最新版本镜像并在生产ECS上启动容器。

最后再说一下,Docker弹性容器服务的关键点:

1.服务注册、发现:容器很容易创建,也非常容易被销毁,新创建的容器需要能够自动注册,并被其它服务发现。

2. 跨主机网络:容器只会暴露必要的端口,不同物理主机之间的容器服务交换数据,一般都是通过单独的、私有的网络进行交互。

3. 存储服务:容器是无状态的,即容器是不能,也不必要保存任何的数据,所以一般都是通过网络储存服务,例如S3,进行数据存储。

4. 健康检查:一般的微服务架构应用,会运行很多个容器,对这些容器的状态进行健康检查是很有必要的。不健康的容器会被销毁,然后再启动一个新的容器替代。

5. 自动弹性伸缩:时刻检测容器的资源情况,当某个服务访问量增大,资源消耗增多时,可能导致服务无法访问时,可以自动增加同一个服务的容器,达到动态平衡。

6. 监控日志:容器随时可能因为出错而被销毁,销毁后无法像普通虚拟机那样查看日志,所以一个良好的日志收集是必须的。

7. 资源隔离:目前容器的隔离性还无法做到普通VM那样的程度,所以在弹性容器服务里,一般会把容器跑在VM里,尽管性能和直接跑在物理机上没法比,但容器还是拥有启动快,开销小的特点。

8. 灰度升级:当应用上线后,服务是无法同时全部关机更新的。而灰度更新,可以逐步分批更新服务,达到无缝更新的效果。

9. 私有仓库:对企业来说,应用的镜像保存在私有的仓库中更适合,而不是分享到Docker官方源,同时私有仓库可以搭建在内网,速度快。





====================================分割线================================


本文转自d1net(转载)

相关实践学习
基于ACK Serverless轻松部署企业级Stable Diffusion
本实验指导您在容器服务Serverless版(以下简称 ACK Serverless )中,通过Knative部署满足企业级弹性需求的Stable Diffusion服务。同时通过对该服务进行压测实验,体验ACK Serverless 弹性能力。
Kubernetes极速入门
Kubernetes(K8S)是Google在2014年发布的一个开源项目,用于自动化容器化应用程序的部署、扩展和管理。Kubernetes通常结合docker容器工作,并且整合多个运行着docker容器的主机集群。 本课程从Kubernetes的简介、功能、架构,集群的概念、工具及部署等各个方面进行了详细的讲解及展示,通过对本课程的学习,可以对Kubernetes有一个较为全面的认识,并初步掌握Kubernetes相关的安装部署及使用技巧。本课程由黑马程序员提供。   相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
1月前
|
Kubernetes Cloud Native 微服务
探索云原生技术:容器化与微服务架构的融合之旅
本文将带领读者深入了解云原生技术的核心概念,特别是容器化和微服务架构如何相辅相成,共同构建现代软件系统。我们将通过实际代码示例,探讨如何在云平台上部署和管理微服务,以及如何使用容器编排工具来自动化这一过程。文章旨在为开发者和技术决策者提供实用的指导,帮助他们在云原生时代中更好地设计、部署和维护应用。
|
10天前
|
Java Linux C语言
《docker基础篇:2.Docker安装》包括前提说明、Docker的基本组成、Docker平台架构图解(架构版)、安装步骤、阿里云镜像加速、永远的HelloWorld、底层原理
《docker基础篇:2.Docker安装》包括前提说明、Docker的基本组成、Docker平台架构图解(架构版)、安装步骤、阿里云镜像加速、永远的HelloWorld、底层原理
236 89
|
1月前
|
Java 开发者 微服务
从单体到微服务:如何借助 Spring Cloud 实现架构转型
**Spring Cloud** 是一套基于 Spring 框架的**微服务架构解决方案**,它提供了一系列的工具和组件,帮助开发者快速构建分布式系统,尤其是微服务架构。
225 69
从单体到微服务:如何借助 Spring Cloud 实现架构转型
|
1月前
|
NoSQL 关系型数据库 MySQL
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
182 56
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
|
1月前
|
运维 监控 持续交付
微服务架构解析:跨越传统架构的技术革命
微服务架构(Microservices Architecture)是一种软件架构风格,它将一个大型的单体应用拆分为多个小而独立的服务,每个服务都可以独立开发、部署和扩展。
353 36
微服务架构解析:跨越传统架构的技术革命
|
5天前
|
人工智能 安全 Java
微服务引擎 MSE:打造通用的企业级微服务架构
微服务引擎MSE致力于打造通用的企业级微服务架构,涵盖四大核心内容:微服务技术趋势与挑战、MSE应对方案、拥抱开源及最佳实践。MSE通过流量入口、内部流量管理、服务治理等模块,提供高可用、跨语言支持和性能优化。此外,MSE坚持开放,推动云原生与AI融合,助力企业实现无缝迁移和高效运维。
|
1月前
|
人工智能 运维 监控
阿里云ACK容器服务生产级可观测体系建设实践
本文整理自2024云栖大会冯诗淳(花名:行疾)的演讲,介绍了阿里云容器服务团队在生产级可观测体系建设方面的实践。冯诗淳详细阐述了容器化架构带来的挑战及解决方案,强调了可观测性对于构建稳健运维体系的重要性。文中提到,阿里云作为亚洲唯一蝉联全球领导者的容器管理平台,其可观测能力在多项关键评测中表现优异,支持AI、容器网络、存储等多个场景的高级容器可观测能力。此外,还介绍了阿里云容器服务在多云管理、成本优化等方面的最新进展,以及即将推出的ACK AI助手2.0,旨在通过智能引擎和专家诊断经验,简化异常数据查找,缩短故障响应时间。
阿里云ACK容器服务生产级可观测体系建设实践
|
22天前
|
存储 人工智能 调度
容器服务:智算时代云原生操作系统及月之暗面Kimi、深势科技实践分享
容器技术已经发展成为云计算操作系统的关键组成部分,向下高效调度多样化异构算力,向上提供统一编程接口,支持多样化工作负载。阿里云容器服务在2024年巴黎奥运会中提供了稳定高效的云上支持,实现了子弹时间特效等创新应用。此外,容器技术还带来了弹性、普惠的计算能力升级,如每分钟创建1万Pod和秒级CPU资源热变配,以及针对大数据与AI应用的弹性临时盘和跨可用区云盘等高性能存储解决方案。智能运维方面,推出了即时弹性节点池、智能应用弹性策略和可信赖集群托管运维等功能,进一步简化了集群管理和优化了资源利用率。
|
1月前
|
人工智能 Cloud Native 调度
阿里云容器服务在AI智算场景的创新与实践
本文源自张凯在2024云栖大会的演讲,介绍了阿里云容器服务在AI智算领域的创新与实践。从2018年推出首个开源GPU容器共享调度方案至今,阿里云容器服务不断推进云原生AI的发展,包括增强GPU可观测性、实现多集群跨地域统一调度、优化大模型推理引擎部署、提供灵活的弹性伸缩策略等,旨在为客户提供高效、低成本的云原生AI解决方案。
|
1月前
|
运维 Kubernetes 调度
阿里云容器服务 ACK One 分布式云容器企业落地实践
阿里云容器服务ACK提供强大的产品能力,支持弹性、调度、可观测、成本治理和安全合规。针对拥有IDC或三方资源的企业,ACK One分布式云容器平台能够有效解决资源管理、多云多集群管理及边缘计算等挑战,实现云上云下统一管理,提升业务效率与稳定性。