【热门主题】000062 云原生后端:开启高效开发新时代
前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕
目录
- 【热门主题】000062 云原生后端:开启高效开发新时代
- 📚 一、云原生后端概述
- 📘(一)概念
- 📘(二)特点
- 📘(三)关键技术支撑
- 📘(四)优势
- 提高开发效率
- 增强系统灵活性
- 降低运维成本
- 提升用户体验
- 📘(五)应用场景
- 电商行业
- 金融行业
- 互联网服务行业
- 📘(六)面临的挑战及应对措施
- 挑战
- 应对措施
- 📚二、云原生后端的核心特点
- 📘1. 容器化
- 📘2. 动态编排
- 📘3. 微服务架构
- 📘4. 自动化运维
- 📘5. 弹性扩展和可观测性
- 📚三、云原生后端的架构组件
- 📘1. API 网关
- 📘2. 服务发现和注册
- 📘3. 服务网格
- 📘4. 消息队列和事件流
- 📘5. 持久化存储
- 📚四、云原生后端的常见技术栈
- 📘1. 编程语言
- 📘2. 容器化工具
- 📘3. 编排和管理
- 📘4. 服务网格
- 📘5. 监控和日志
- 📚五、云原生后端与传统后端架构的对比
- 📘1. 设计理念差异
- 📘2. 弹性扩展与自动化运维
- 📚六、云原生后端的优势
- 📘1. 提高开发效率
- 📘2. 增强系统灵活性
- 📘3. 降低运维成本
- 📘4. 提升用户体验
- 📚七、云原生后端的应用场景
- 📘1. 电商行业
- 📘2. 金融行业
- 📘3. 互联网服务行业
- 📚八、云原生后端面临的挑战及应对措施
- 📘1. 挑战
- 📘2. 应对措施
- 📚九、云原生后端的未来发展方向
- 📚十、总结
📚📗📕📘📖🕮💡📝🗂️✍️🛠️💻🚀🎉🏗️🌐🖼️🔗📊👉🔖⚠️🌟🔐⬇️·正文开始
⬇️·🎥😊🎓📩😺🌈🤝🤖📜📋🔍✅🧰❓📄📢📈 🙋0️⃣1️⃣2️⃣3️⃣4️⃣5️⃣6️⃣7️⃣8️⃣9️⃣🔟🆗*️⃣#️⃣
【热门主题】000062 云原生后端:开启高效开发新时代
📚 一、云原生后端概述
云原生后端是基于云环境进行设计和开发的一种理念,利用云服务和云原生技术构建服务端应用,旨在提供灵活、高效、弹性和可扩展的解决方案。
在当今数字化飞速发展的时代,企业对于应用程序的开发、部署和运维提出了更高的要求。云原生后端作为一种新兴的技术理念和架构模式,正逐渐成为推动应用现代化的核心力量。它为企业带来了更高效、灵活、可扩展且可靠的后端解决方案,助力企业在激烈的市场竞争中脱颖而出。
📘(一)概念
云原生后端是基于云原生技术构建的应用程序后端部分。它充分利用了云计算的优势,将容器化、微服务、持续交付等关键技术融合在一起,旨在打造一个具有高度弹性、可快速迭代且易于管理的后端架构。
📘(二)特点
容器化:通过将应用及其依赖打包成容器,实现了应用的隔离和可移植性。容器就像是一个个独立的运行单元,无论在何种云环境或本地环境下,都能保证应用的一致运行,大大降低了环境差异带来的部署难题。
微服务架构:将后端应用拆分成多个小型的、相互独立的微服务。每个微服务专注于完成特定的业务功能,它们之间通过轻量级的通信机制(如 RESTful API 或消息队列)进行交互。这种架构使得团队可以针对不同的微服务进行独立开发、部署和扩展,提高了开发效率和系统的灵活性。
持续交付与自动化:云原生后端强调持续交付管道的建立,通过自动化的构建、测试、部署等流程,确保代码能够快速且稳定地从开发环境推向生产环境。这不仅缩短了应用的上线周期,还能及时响应市场需求的变化,实现快速迭代。
弹性可扩展:能够根据业务负载的变化自动调整资源的分配。当业务流量增加时,可以迅速增加容器或微服务的数量来满足需求;反之,当流量减少时,相应地减少资源占用,有效节约成本的同时保证系统的稳定运行。
📘(三)关键技术支撑
容器编排技术(如 Kubernetes)
Kubernetes 是目前最为流行的容器编排工具,它负责管理容器的生命周期,包括容器的创建、部署、调度、扩展等操作。通过 Kubernetes,可以轻松实现容器的集群化管理,确保容器在不同节点上的高效运行,并且能够根据预设的规则自动调整容器的数量和分布,以适应业务需求的变化。
微服务框架(如 Spring Cloud、Dubbo 等)
这些微服务框架为开发人员提供了便捷的方式来构建、部署和管理微服务。它们包含了一系列的组件,如服务注册与发现、配置管理、熔断器等,帮助微服务之间实现稳定的通信和协同工作,同时也提高了微服务的可维护性和可扩展性。
自动化运维工具(如 Ansible、Chef 等)
自动化运维工具在云原生后端中起到了至关重要的作用。它们可以实现对服务器、容器、微服务等的自动化配置、部署和管理。通过编写脚本或使用预定义的模块,这些工具可以按照设定的流程自动完成各项运维任务,大大减轻了运维人员的工作量,提高了运维效率。
📘(四)优势
提高开发效率
微服务架构使得不同的团队可以并行开发不同的微服务,减少了开发过程中的相互依赖和等待时间。同时,持续交付的实现也让代码能够更快地进入生产环节,加速了应用的开发进程。
增强系统灵活性
由于采用了容器化和微服务架构,企业可以根据业务需求灵活地调整后端架构。例如,当推出新的业务功能时,可以快速添加相应的微服务;当某个业务功能不再需要时,可以轻松地删除或修改相关微服务,而不会对整个系统造成太大的影响。
降低运维成本
自动化运维工具和弹性可扩展的特性使得运维人员可以更轻松地管理后端系统。无需人工手动调整资源分配,系统会根据负载自动变化,同时自动化的流程也减少了运维过程中的人为错误,从而降低了运维成本。
提升用户体验
云原生后端能够快速响应用户的需求变化,通过弹性可扩展保证在高流量时期系统的稳定运行,为用户提供流畅的服务体验。而且,持续交付的不断迭代也可以让应用不断优化,满足用户更高的要求。
📘(五)应用场景
电商行业
在电商领域,云原生后端可以处理海量的订单、库存管理、用户信息管理等业务。例如,在购物节等高峰期,通过弹性可扩展的特性迅速增加资源来处理剧增的订单流量,保证购物流程的顺畅;平时则可以根据实际业务量合理调整资源,节约成本。
金融行业
对于金融机构,云原生后端可用于交易处理、风险评估、客户账户管理等方面。其安全性和可靠性通过技术手段得以保障,同时弹性可扩展的特性也能应对金融市场波动带来的业务流量变化。
互联网服务行业
如社交媒体、在线视频等互联网服务,云原生后端可以负责内容管理、用户互动管理、视频流传输等业务。通过持续交付不断优化服务,通过弹性可扩展满足不同时间段的流量差异,如视频平台在黄金时段的高流量需求。
📘(六)面临的挑战及应对措施
挑战
技术复杂性:云原生后端涉及到众多先进的技术,如容器化、微服务、自动化运维等,这些技术的掌握和融合需要专业的技术人员,对于企业来说,培养和招聘这样的人才可能存在一定难度。
安全风险:由于云原生后端的开放性和灵活性,也带来了一些安全风险,比如容器的安全漏洞、微服务之间的通信安全等问题,需要采取有效的安全措施来保障系统的安全。
性能优化:在满足弹性可扩展的同时,如何确保系统在高流量情况下的性能优化也是一个挑战,需要不断探索合适的算法和技术手段来提高系统的性能。
应对措施
对于技术复杂性问题,企业可以加强内部培训,提高现有员工的技术水平。同时,也可以与高校、培训机构等合作,引进专业人才。此外,还可以通过参加行业会议、技术论坛等方式,了解最新的技术动态和解决方案。
针对安全风险,企业可以采取一系列安全措施,如加强容器的安全管理,定期进行安全漏洞扫描和修复;采用加密通信技术,保障微服务之间的通信安全;建立完善的安全监控体系,及时发现和处理安全事件。
在性能优化方面,企业可以采用性能测试工具,对系统进行全面的性能测试,找出性能瓶颈并进行优化。同时,也可以借鉴行业内的最佳实践,采用合适的算法和技术手段,提高系统的性能和稳定性。
📚二、云原生后端的核心特点
📘1. 容器化
云原生后端应用通常使用容器化技术,如 Docker,将应用程序与其依赖的环境一起打包。容器化带来了诸多优势,首先确保了应用在不同环境中具有一致的运行行为。无论应用部署在开发环境、测试环境还是生产环境,都能以相同的方式运行,大大降低了环境差异带来的部署难题。容器就像是一个个独立的运行单元,具有良好的隔离性,这提高了系统的安全性。不同的容器之间相互独立,一个容器出现问题不会影响到其他容器的正常运行,从而保障了整个系统的稳定性。
📘2. 动态编排
为了管理大规模的容器,云原生后端通常使用容器编排工具,例如 Kubernetes。这些工具可以实现容器的自动部署、扩展、监控和故障恢复,保证应用程序在高负载下的稳定性和高可用性。Kubernetes 作为目前最为流行的容器编排工具,负责管理容器的生命周期,包括容器的创建、部署、调度、扩展等操作。通过 Kubernetes,可以轻松实现容器的集群化管理,确保容器在不同节点上的高效运行,并且能够根据预设的规则自动调整容器的数量和分布,以适应业务需求的变化。例如,当业务流量增加时,Kubernetes 可以自动增加容器的数量来满足需求;反之,当流量减少时,相应地减少容器数量,有效节约成本的同时保证系统的稳定运行。
📘3. 微服务架构
云原生后端通常采用微服务架构,将应用程序分解为一系列小而独立的服务。每个服务可以独立开发、部署和扩展,提高了系统的灵活性和可维护性。微服务之间通过轻量级的通信协议(如 HTTP、gRPC)进行交互。这种架构使得团队可以针对不同的微服务进行独立开发,减少了开发过程中的相互依赖和等待时间。不同的团队可以使用最适合其服务的技术栈,促进技术创新。例如,一个团队可以选择 Java 开发某个微服务,而另一个团队可以选择 Python 开发另一个微服务。同时,微服务架构还具有故障隔离的优点,服务之间的隔离确保了某一服务的故障不会影响整个系统。如果一个微服务出现故障,其他微服务可以继续运行,从而提升系统的稳定性。
📘4. 自动化运维
通过 DevOps 和 CI/CD 自动化管理应用的开发、测试和部署流程,提高发布的频率和质量。DevOps 强调开发与运维团队的紧密合作,打破部门壁垒,共同为软件的快速交付和可靠运行负责。自动化运维则是利用技术手段,减少人为操作,实现运维任务的自动化。例如,使用 Ansible、Terraform 等工具,实现基础设施即代码(IaC),通过代码来管理和配置基础设施,使得基础设施管理更加灵活和可重复。CI/CD 使得代码变更可以快速、可靠地交付到生产环境,确保软件持续交付高质量。CI/CD 工具还支持自动化回滚和故障处理,进一步提升系统的稳定性。通过 Prometheus、Grafana 等工具,实时监控系统状态,并在异常时自动报警。这些工具可以帮助团队快速发现并解决问题,确保系统的稳定性和高可用性。
📘5. 弹性扩展和可观测性
云原生后端可以根据实际负载自动进行水平扩展或缩减,并通过可观测性工具进行监控,及时发现并解决问题。通过 Horizontal Pod Autoscaler (HPA) 根据 CPU 和内存使用率或其他自定义 metrics 自动调整 Pod 的数量,实现水平伸缩。Vertical Pod Autoscaler (VPA) 动态调整单个 Pod 的资源请求,以优化资源利用率和性能。Kubernetes Event Driven Autoscaling (KEDA) 基于事件驱动进行弹性扩缩容,特别适合处理基于消息队列的任务或应对突发流量。可观测性方面,推荐使用 Prometheus 进行监控,Grafana 进行数据可视化,以及 ELK Stack(Elasticsearch、Logstash、Kibana)进行日志分析,帮助团队及时发现和解决问题。例如,当业务流量突然增加时,系统可以自动扩展资源以满足需求;当流量减少时,自动缩减资源以节约成本。同时,通过可观测性工具,团队可以实时了解系统的运行状态,快速定位问题并采取相应的措施。
📚三、云原生后端的架构组件
📘1. API 网关
API 网关作为云原生架构的入口,起着至关重要的作用。在最基本的形式中,API 网关接收 API 请求并返回答案,充当 API 使用者和一个或多个 API 服务之间的中间人或 “中间件”。它跨 API 服务系统处理常见任务,例如用户身份验证、速率限制、实时指标等。
API 网关是所有终端流量的入口,负责把终端的 API 请求路由到正确的上游服务进行处理,然后再把返回的数据返回给原始请求方,同时保证整个过程的安全、可靠和低延迟。在云原生整个微服务架构中,API 网关充当着非常重要的一环,它不仅要负责外部所有的流量接入,同时还要在网关入口处根据不同类型请求提供流量控制、日志收集、性能分析、速率限制、熔断、重试等细粒度的控制行为。
一方面,API 网关将外部访问与微服务进行了隔离,保障了后台微服务的安全,另一方面也节省了后端服务的开发成本,有益于进行应用层面的扩展。与此同时,API 网关也应具备解决外界访问带来的安全问题,例如 TLS 加密、数据丢失、跨域访问、认证授权、访问控制等。
云原生 API 网关的产品特色和功能也十分丰富。例如腾讯云的云原生 API 网关,它是一款高性能高可用的云上网关托管产品,减少用户自建网关的开发及运维成本。作为云上微服务架构的流量入口,集成请求分发、API 管理、流量监控、访问限制等功能。它完美兼容开源,100% 兼容开源网关,兼容多个版本,开箱即用,用户从自建网关迁移无门槛;具备高性能,提供多种规格的实例,支持无缝扩缩容,轻松应对流量洪峰;高性价比,采用腾讯云底层资源,由腾讯云托管网关,无自建网关的人力成本及运维成本;免运维,保证网关的健康运行,让用户专注于自身业务实现;高可用,提供多可用区部署、健康探测等能力,保证网关持续、稳定、安全运行。同时,还具有腾讯云特色功能,提供与腾讯云环境、腾讯云产品的标准化对接方式,支持腾讯云开发的特色网关插件。其功能包括数据可视化、批量修改系统参数、日志监控、不停服扩缩容、IP 黑白名单、容灾备份、免运维、轻松迁移等。在应用场景方面,云原生 API 网关用于实现完整 API 托管的服务,协助开发者轻松完成 API 的创建、维护、发布、监控等整个生命周期的管理。通过云原生 API 网关,可以封装后端各种服务,以 API 的形式,提供给各方使用。同时,通过多种插件功能,提供路由转发、认证鉴权、参数转换等丰富的流量管理功能。
📘2. 服务发现和注册
在云原生架构中,由于服务众多且单个服务具有多个实例,同时部署在 Kubernetes 集群中,实例的 IP 地址可能随时变化,因此需要服务发现和注册机制来对服务调用进行集中统一管理。
服务发现允许组件动态查找网络中的服务端点,服务注册则是服务实例将自己的存在公布给系统的过程。服务注册中一个关键的概念是注册中心,通常是一个可靠的存储服务实例信息的系统。在云环境中,服务实例可能频繁地启动或消失,服务发现机制确保客户端总能找到可用的服务实例。
云原生服务发现概述中提到,服务发现在云原生系统中的作用不容小觑。它解决了在变动的云环境下动态定位服务实例的问题。通过组件如 DNS 或服务发现平台,应用能动态查询服务实例的网络位置。应用进行服务调用时,通常不会直接连接到硬编码的 IP 地址。相反,它会请求服务发现组件以获取当前有效的服务端点。这种模式提高了系统的弹性,使其能适应底层基础设施的变化,如主机故障或资源弹性伸缩。
服务注册的运作主要由具体的服务实例承担。服务实例启动时需自行注册到中心目录,并以适当的机制报告其健康状态。这通常通过心跳机制实现,服务实例每隔一定时间向注册中心发送 “我还活着” 的信号。注册中心负责监控这些心跳,若服务实例不再发送心跳,则认为其已下线,从而在目录中去除。这确保了注册中心只包含活跃的服务实例,客户端因而只会被导向当前健康的服务端点。
服务发现可以通过多种方式实施,包括客户端发现和服务端发现。在客户端发现中,客户端应用直接查询服务注册表以找到服务端点。然后,客户端使用此信息来进行远程调用。这种方法的优点是客户端有更多控制权,但缺点是每个客户端需要实现服务发现的逻辑。与之相对的是服务端发现,在此模式下,客户端发送请求给一个中间层(例如 API 网关或服务代理),该中间层负责服务查找并将请求路由到适当的服务实例。服务端发现降低了客户端的复杂性,但增加了中间层可能成为故障点的风险。
注册中心是服务发现机制中的关键部分,它必须可靠且易于维护。市场上有多种注册中心的解决方案,如 Consul、Etcd 和 Zookeeper。Consul 提供了多数据中心分布式高可用的注册中心。它通过健康检查服务实例,并提供 HTTP 及 DNS 两种服务发现方式。Etcd 是一个开源的分布式键值存储系统,用于配置共享和服务发现。Etcd 依赖于强一致性算法 Raft 来保持注册信息的一致性,从而确保即便在出现网络分区的情况下,服务发现的信息也能够是可靠的。Zookeeper 是另一种被广泛使用的服务协调系统,它通过创建节点(称为 znodes)来存储服务的元数据。Zookeeper 也实现了一个领导者选举算法,可用于在注册中心的服务实例之间选择一个领导者。
对于云原生环境中动态的服务发现和注册,这些技术解决方案提供了不同的特性和权衡,开发人员和架构师可以根据自己的需求选择合适的工具。当前云原生应用越来越倾向于使用容器化技术和编排工具如 Kubernetes。Kubernetes 自身内建了服务发现和注册的机制,降低了开发人员的负担。Kubernetes 使用标签选择器将服务和 Pod 实例关联起来。当 Pod 实例符合服务定义的标签选择器时,Kubernetes 会自动处理相关的服务注册逻辑。此外,使用内建服务对象,Kubernetes 能为服务提供持久的访问点,并处理内部的负载平衡。随着云原生技术的发展,服务网格也开始成为服务发现与注册的高级实现。服务网格提供了一个基础设施层,它在应用程序之外处理服务间通信的所有方面。这包括故障处理、动态路由、服务度量和安全。Istio 和 Linkerd 是两个流行的服务网格解决方案。
📘3. 服务网格
服务网格(Service Mesh)是一种用于管理微服务架构中服务间通信的基础设施层。它提供了一种透明的方式来处理服务之间的网络通信,通常通过代理(sidecar proxy)来实现。
服务网格的主要功能包括流量管理、安全性、可观察性和故障恢复等。流量管理方面,实现负载均衡,自动将请求分配到多个服务实例,以实现高可用性和性能优化;支持流量控制,如蓝绿部署、金丝雀发布、A/B 测试等高级流量管理策略;提供服务发现功能,自动检测和路由请求到可用的服务实例。安全性方面,确保身份验证和授权,只有经过验证的服务才能相互通信;通过 mTLS(双向传输层安全)加密服务间通信,保护数据隐私;定义和实施安全策略,控制服务间的访问权限。可观察性方面,收集和分析服务间通信的指标和日志,提供可视化的监控面板;通过分布式追踪,跟踪请求在多个服务之间的流动,帮助识别性能瓶颈和故障点。故障恢复方面,自动重试失败的请求,并设置请求超时以防止长时间等待;在检测到服务故障时,自动停止请求以防止级联故障;限制请求速率以保护服务免受过载影响。
服务网格通常通过在每个服务实例旁边部署一个代理(sidecar proxy)来实现。这些代理负责拦截和管理服务间的所有网络流量。服务网格由控制平面和数据平面组成。控制平面负责配置和管理代理,提供策略和配置的集中管理。数据平面由代理组成,负责实际的数据传输和执行控制平面下发的策略。服务网格的设计通常是无侵入的,意味着应用程序代码无需修改即可受益于服务网格的功能。
常见的服务网格实现有 Istio、Linkerd 和 Consul Connect 等。Istio 是一个功能丰富的服务网格,支持多种流量管理和安全功能。Linkerd 是一个轻量级的服务网格,专注于简单性和性能。Consul Connect 由 HashiCorp 提供的服务网格解决方案,集成了服务发现和配置管理功能。
服务网格适用于微服务架构、多云和混合云环境以及 DevOps 和 CI/CD 等应用场景。在复杂的微服务架构中,服务网格可以简化服务间通信的管理,提高系统的可靠性和安全性。在多云和混合云环境下,服务网格可以跨多个云提供商和本地数据中心提供一致的服务管理。通过流量管理和可观察性功能,服务网格支持更快速和安全的应用程序发布和运维。
📘4. 消息队列和事件流
消息队列和事件流在云原生架构中起着重要的作用,实现了微服务之间的异步通信,解耦服务并提高系统的可靠性。
以 RocketMQ 为例,RocketMQ 5.0 全面迈进云原生时代,从消息服务升级到云原生事件流处理平台。RocketMQ 服务于众多企业客户,覆盖多个行业,具有多样性、一致性、稳定性和高性能等核心优势。随着云原生以及数字化时代的到来,RocketMQ 也在快速变化,全面拥抱云原生和实时数据。RocketMQ 5.0 进行了云原生架构升级,客户端采用轻量 SDK 设计理念,满足现代化应用轻量化、Serverless 化以及 Mesh 化的趋势,更容易被集成;同时实现了弹性、高可用,并走向 Kubernetes 化,拥抱 OpenTelemetry,依托于阿里云提供的 ARMS、Prometheus 以及 Grafana 实现可观测能力的云原生化。此外,RocketMQ 5.0 还推出了轻量无状态消费模型,解决了业务消息领域中的一些问题。
消息队列通常用于实现微服务之间的异步通信,如 RabbitMQ、Kafka 或 Amazon SQS 等工具可以解耦服务并提高系统的可靠性。这些工具可以在不同的业务场景下发挥作用,如金融场景、事件驱动架构等。消息队列可以处理不同类型的消息,如定时消息、事务消息、顺序消息等,还提供了消息轨迹、消息回溯等一系列的消息治理能力。
📘5. 持久化存储
在云原生架构中,持久化存储满足每个微服务的持久化需求,可使用关系型数据库、NoSQL 数据库或分布式存储等。
云原生架构下的数据持久化策略涉及几个核心要素:无状态与状态保持服务的搭配、容器存储方案、数据备份与灾难恢复、跨云与混合云数据持久化、自动化与弹性策略。
在无状态与状态保持服务的搭配方面,云原生架构之下,区分状态保持(stateful)与无状态(stateless)服务是至关重要的。无状态服务易于水平扩展,不保存任何用户会话信息,通常由外部数据库或缓存系统持久化。状态保持服务需要维持数据的持久性和一致性,面临更复杂的扩展和管理挑战。为了有效管理状态数据,可以将状态服务的持久化层与无状态层解耦,通过持久卷和存储服务使它们独立于容器的生命周期之外。
容器存储方案中,容器化环境原生并不是为长期数据存储设计,但通过持久卷(Persistent Volume, PV)和持久卷声明(Persistent Volume Claim, PVC)的概念实现了对持久化数据的支持。PV 是集群中的一块存储,而 PVC 则是用户对这块存储的请求。结合 StorageClass 资源,可以实现动态绑定,使容器可以无缝接入不同类型的后端存储系统,包括本地硬盘、公有云的块存储以及网络文件系统。常见的存储解决方案有本地存储、网络存储如 NFS、云供应商提供的块存储方案,以及更高级的分布式存储系统如 Ceph 和 GlusterFS 等。容器存储接口(CSI)中的弹性和模块化设计使得开发者能够在各种存储系统间更自由地选择,存储服务提供商也利用 CSI 插件将他们的解决方案无缝集成到 Kubernetes 等容器编排平台中。
数据备份与灾难恢复是云原生环境下数据持久化策略的重要一环。这不仅包括将数据复制到另一个地方作为冗余,还包括备份操作的自动化、测试备份恢复的能力以及对备份数据的完整性和一致性的确保。备份策略的制订需要考虑到数据的变化频率、重要性和可用性需求。快照和镜像提供了数据恢复到某一时间点(Point-in-Time Recovery)的能力,而数据复制则能提供更高的数据可用性和较低的恢复时间目标(RTO)。
跨云与混合云数据持久化需要考虑在不同的云环境下如何实现无缝的数据迁移和同步。跨云数据持久化可能涉及到跨区域甚至跨供应商的数据同步问题,这时会涉及到数据迁移的性能、成本以及云之间的兼容性和数据一致性问题。对于跨云数据持久化,策略的设计将需要围绕标准化的接口和协议,以适配不同云服务商的存储解决方案。
自动化与弹性策略方面,自动化不仅降低了操作的复杂性,提高了效率,同时也减少了因人为错误导致的数据丢失的风险。弹性意味着系统能够根据数据负载的变化动态调整资源,这一点在云原生架构中尤为重要。弹性可以通过多种机制实现,如自动扩展(Auto-Scaling)、弹性块存储和即用型数据服务。这些技术通过对底层资源的自动管理,让上层应用能够获得按需的存储资源,从而优化性能与成本。
📚四、云原生后端的常见技术栈
📘1. 编程语言
云原生后端通常使用多种编程语言,各有其优势和适用场景。
Golang:由 Google 开发,专为简化构建高性能、可靠的软件而设计。其简洁的语法、出色的并发支持和内置的工具链,使它成为开发复杂的云原生应用的首选。在云原生环境中常见的分布式系统设计和微服务架构方面表现出色,对并发的原生支持允许开发者轻松实现复杂的并行任务处理,这在处理大量数据和高并发请求的云应用中非常关键。
Java:长期以来一直是企业级应用开发的主流语言,在云原生应用开发中仍然扮演着重要角色。强类型系统、成熟的生态系统以及广泛的社区支持,使其在构建大型、复杂的企业级和云原生应用时具有不可忽视的优势。Spring Boot 等现代 Java 框架简化了云原生应用的开发,通过提供对容器化和微服务架构的原生支持,进一步巩固了 Java 在此领域的地位。
Python:因其易学易用而在开发者中广受欢迎,尤其适合快速原型设计和迭代。拥有庞大的库生态,非常适合数据分析、机器学习、自动化脚本和 Web 开发。在云原生开发中,经常被用于编写自动化脚本和服务集成代码,以及进行数据处理和分析。
📘2. 容器化工具
Docker 是云原生后端最常用的容器化工具。它将应用程序与其依赖打包为一个可以在任何环境中运行的可移植的容器,确保应用在不同环境中具有一致的运行行为,同时容器的隔离性提高了系统的安全性。
Docker 镜像包含了运行应用程序所需的所有代码、运行时、库和配置,大大降低了系统不一致和环境冲突的风险。通过 Dockerfile 和 Docker 镜像,开发团队可以创建标准化的应用环境,而运维团队则可以利用这些环境快速部署和扩展应用程序。这种模式支持工作负载的一致性和可预测性,降低了沟通成本,提高了工作效率。
📘3. 编排和管理
Kubernetes 是容器编排标准,自动化容器的部署、扩展和管理。它负责管理容器的生命周期,包括容器的创建、部署、调度、扩展等操作。通过 Kubernetes,可以轻松实现容器的集群化管理,确保容器在不同节点上的高效运行,并且能够根据预设的规则自动调整容器的数量和分布,以适应业务需求的变化。
例如,当业务流量增加时,Kubernetes 可以自动增加容器的数量来满足需求;反之,当流量减少时,相应地减少容器数量,有效节约成本的同时保证系统的稳定运行。Kubernetes 还能够实现多云和混合云部署,这对于企业在不同云平台保持灵活性和选择性至关重要。
📘4. 服务网格
Istio 和 Linkerd 是常用的服务网格工具,用于管理服务之间的通信,提供负载均衡、故障恢复和流量控制等功能。
服务网格通常通过在每个服务实例旁边部署一个代理(sidecar proxy)来实现。这些代理负责拦截和管理服务间的所有网络流量。服务网格由控制平面和数据平面组成。控制平面负责配置和管理代理,提供策略和配置的集中管理。数据平面由代理组成,负责实际的数据传输和执行控制平面下发的策略。
例如,Istio 是一个功能丰富的服务网格,支持多种流量管理和安全功能。Linkerd 是一个轻量级的服务网格,专注于简单性和性能。Consul Connect 由 HashiCorp 提供的服务网格解决方案,集成了服务发现和配置管理功能。
📘5. 监控和日志
Prometheus 和 Grafana 用于监控系统运行状况,ELK 堆栈用于日志收集和分析。
Prometheus 是一款开源的监控和警报工具,专门用于监控云原生应用和基础设施。它采用了多维度的数据模型和灵活的查询语言,可以实时收集和存储应用的指标数据,并提供强大的查询和警报功能。Grafana 是一款开源的数据可视化工具,可以与 Prometheus 等监控系统集成,提供丰富的仪表盘和图表展示。
ELK Stack 是由 Elasticsearch、Logstash 和 Kibana 组成的一套日志管理解决方案。Elasticsearch 是一个分布式搜索和分析引擎,可以用于存储和搜索大量的日志数据。Logstash 是一个数据收集和传输工具,可以将各种来源的日志数据进行过滤、转换和传输。Kibana 是一个数据可视化工具,可以与 Elasticsearch 集成,提供强大的查询和可视化功能。
📚五、云原生后端与传统后端架构的对比
📘1. 设计理念差异
传统后端架构多为单体架构,云原生后端结合容器化和微服务,更能快速响应业务需求。
在传统后端架构中,通常采用单体架构,即将整个应用程序构建为一个单一的、庞大的软件单元。这种架构模式在开发初期可能较为简单直接,因为所有的功能模块都集中在一个项目中,便于开发和维护。然而,随着业务的不断发展和扩张,单体架构逐渐暴露出一些明显的局限性。
首先,单体架构的可扩展性较差。由于所有功能模块都在一个应用中,当业务流量增加时,很难对特定的功能模块进行独立扩展。例如,在电商平台的传统后端架构中,如果订单处理模块的负载增加,要想单独扩展该模块就会变得非常困难,往往需要对整个应用进行升级和扩展,这不仅耗时耗力,还可能影响到其他正常运行的功能模块。
其次,单体架构的开发效率较低。在开发过程中,不同功能模块的开发人员需要在同一个项目中协同工作,这容易导致代码冲突和开发进度的相互制约。例如,在金融机构的传统后端架构中,交易处理模块和风险评估模块的开发人员可能会因为代码的相互影响而需要频繁地进行沟通和协调,从而降低了开发效率。
相比之下,云原生后端架构采用容器化和微服务的设计理念,具有显著的优势。容器化技术将应用程序及其依赖打包成一个个独立的容器,使得应用在不同环境中具有一致的运行行为。微服务架构则将后端应用拆分成多个小型的、相互独立的微服务,每个微服务专注于完成特定的业务功能。
这种设计理念使得云原生后端架构能够快速响应业务需求。例如,在互联网服务行业中,当社交媒体平台需要推出新的用户互动功能时,可以快速开发和部署一个新的微服务来实现该功能,而不会对整个系统造成太大的影响。同时,不同的微服务可以由不同的团队独立开发、部署和扩展,提高了开发效率和系统的灵活性。
📘2. 弹性扩展与自动化运维
云原生后端的弹性扩展和自动化运维降低了开发和运维成本,提高了应用的稳定性和可维护性。
在传统后端架构中,弹性扩展通常需要手动进行硬件升级或增加服务器数量,这个过程不仅耗时较长,而且成本较高。例如,在传统的电商平台后端架构中,当购物节等高峰期到来时,为了应对剧增的订单流量,往往需要提前进行大量的硬件准备工作,包括购买新的服务器、进行安装和配置等,这不仅需要投入大量的资金,还可能因为准备不充分而导致系统在高峰期出现性能问题。
此外,传统后端架构的运维工作主要依靠人工操作,容易出现人为错误,且运维效率低下。例如,在金融机构的传统后端架构中,运维人员需要手动监控服务器的运行状态、进行软件的安装和升级等工作,这不仅耗费大量的时间和精力,还可能因为人为失误而导致系统故障。
而云原生后端架构通过弹性扩展和自动化运维,有效地解决了这些问题。云原生后端可以根据业务负载的变化自动调整资源的分配。当业务流量增加时,可以迅速增加容器或微服务的数量来满足需求;反之,当流量减少时,相应地减少资源占用,有效节约成本的同时保证系统的稳定运行。
例如,在云原生架构的电商平台中,当购物节等高峰期到来时,系统可以自动增加容器或微服务的数量,快速提升系统的处理能力,保证购物流程的顺畅;而在平时,系统可以根据实际业务量合理调整资源,节约成本。
自动化运维工具在云原生后端中起到了至关重要的作用。通过编写脚本或使用预定义的模块,这些工具可以按照设定的流程自动完成各项运维任务,大大减轻了运维人员的工作量,提高了运维效率。例如,使用 Ansible、Chef 等自动化运维工具,可以实现对服务器、容器、微服务等的自动化配置、部署和管理,减少了人为错误的发生,提高了应用的稳定性和可维护性。
📚六、云原生后端的优势
📘1. 提高开发效率
微服务架构和持续交付使得不同团队可以并行开发,代码能够更快进入生产环节。在云原生后端中,微服务架构将后端应用拆分成多个小型的、相互独立的微服务。每个微服务专注于完成特定的业务功能,不同的团队可以针对不同的微服务进行独立开发,减少了开发过程中的相互依赖和等待时间。例如,在一个大型电商平台的开发中,订单管理、库存管理、用户管理等不同功能模块可以由不同的团队分别负责开发各自对应的微服务。
同时,持续交付管道的建立,通过自动化的构建、测试、部署等流程,确保代码能够快速且稳定地从开发环境推向生产环境。以云原生的 DevOps 实践为例,强调跨职能团队的协作,包括开发人员、运维人员、质量保证人员等。这种协作可以帮助团队更快地响应市场变化,提高软件开发效率。例如,通过自动化构建、自动化测试、自动化部署等,减少人工错误,提高软件开发效率,降低运维成本,提高软件质量。
📘2. 增强系统灵活性
容器化和微服务架构让企业可以根据业务需求灵活调整后端架构。容器化技术将应用程序及其依赖打包成一个个独立的容器,使得应用在不同环境中具有一致的运行行为。微服务架构将后端应用拆分成多个小型的、相互独立的微服务,每个服务可以独立开发、部署和扩展。
当企业推出新的业务功能时,可以快速添加相应的微服务。比如在互联网服务行业中,当社交媒体平台需要推出新的用户互动功能时,可以快速开发和部署一个新的微服务来实现该功能,而不会对整个系统造成太大的影响。当某个业务功能不再需要时,可以轻松地删除或修改相关微服务。例如,在金融机构中,如果某个特定的风险评估模块不再适用,可以轻松地对其进行修改或删除,而不会影响其他正常运行的服务。
📘3. 降低运维成本
自动化运维工具和弹性可扩展特性减少了人工干预,降低了运维成本。在传统后端架构中,弹性扩展通常需要手动进行硬件升级或增加服务器数量,运维工作主要依靠人工操作,容易出现人为错误,且运维效率低下。而云原生后端架构通过弹性扩展和自动化运维,有效地解决了这些问题。
云原生后端可以根据业务负载的变化自动调整资源的分配。当业务流量增加时,可以迅速增加容器或微服务的数量来满足需求;反之,当流量减少时,相应地减少资源占用,有效节约成本的同时保证系统的稳定运行。例如,在电商平台中,购物节等高峰期到来时,系统可以自动增加容器或微服务的数量,快速提升系统的处理能力,保证购物流程的顺畅;而在平时,系统可以根据实际业务量合理调整资源,节约成本。
自动化运维工具在云原生后端中起到了至关重要的作用。通过编写脚本或使用预定义的模块,这些工具可以按照设定的流程自动完成各项运维任务,大大减轻了运维人员的工作量,提高了运维效率。例如,使用 Ansible、Chef 等自动化运维工具,可以实现对服务器、容器、微服务等的自动化配置、部署和管理,减少了人为错误的发生,提高了应用的稳定性和可维护性。
📘4. 提升用户体验
能够快速响应用户需求变化,保证系统在高流量时期的稳定运行。云原生后端采用容器化、微服务架构和持续交付等技术,使得系统能够快速响应市场需求的变化。当用户的需求发生变化时,开发团队可以快速调整微服务,通过持续交付将新的功能快速推向生产环境,满足用户的需求。
在高流量时期,云原生后端的弹性可扩展特性能够保证系统的稳定运行。例如,在视频平台的黄金时段,高流量需求下,系统可以自动扩展资源,确保视频流的稳定传输,为用户提供流畅的观看体验。同时,持续交付的不断迭代也可以让应用不断优化,满足用户更高的要求。例如,通过不断优化用户互动管理功能,提升用户在社交媒体平台上的体验。
📚七、云原生后端的应用场景
📘1. 电商行业
在电商行业中,云原生后端发挥着至关重要的作用。它能够高效地处理海量订单,确保订单的快速处理和准确配送。通过容器化和微服务架构,各个订单处理模块可以独立运行和扩展,当购物节等高峰期到来时,系统能够迅速增加资源,如增加容器或微服务的数量,以应对剧增的订单流量。这不仅保证了购物流程的顺畅,还能提高用户的购物体验。
同时,云原生后端在库存管理方面也表现出色。它可以实时监控库存数量,通过自动化的流程及时补充库存,避免缺货情况的发生。并且,利用弹性可扩展的特性,根据不同季节、促销活动等业务量的变化,合理调整资源分配,节约成本。此外,在用户信息管理方面,云原生后端能够确保用户信息的安全存储和快速检索,为用户提供个性化的服务推荐。
例如,一些大型电商平台采用云原生后端技术后,在购物节期间能够轻松应对数倍甚至数十倍于平时的订单流量。通过容器编排工具 Kubernetes,可以自动调整容器的数量和分布,确保系统的稳定运行。同时,利用微服务架构,各个业务模块独立开发、部署和扩展,提高了开发效率和系统的灵活性。
📘2. 金融行业
金融行业对交易处理的安全性和可靠性要求极高,云原生后端正好满足了这一需求。它可以用于交易处理,确保交易的快速、准确执行。通过容器化技术,将交易处理应用及其依赖打包成容器,实现了应用的隔离和可移植性,大大降低了环境差异带来的部署难题。
在风险评估方面,云原生后端可以利用大数据分析和机器学习技术,快速准确地评估风险。通过微服务架构,不同的风险评估模块可以独立开发和部署,提高了开发效率和系统的灵活性。同时,弹性可扩展的特性能够应对金融市场波动带来的业务流量变化,确保系统在高流量时期的稳定运行。
对于客户账户管理,云原生后端可以提供安全、高效的解决方案。它可以实时监控客户账户的变动情况,确保账户的安全。并且,利用自动化运维工具,减少人为错误,提高运维效率。
例如,一些金融机构采用云原生后端技术后,在交易处理速度和风险评估准确性方面都有了显著提高。通过容器编排工具 Kubernetes,可以自动调整资源分配,确保系统在高流量时期的稳定运行。同时,利用微服务架构,各个业务模块独立开发、部署和扩展,提高了开发效率和系统的灵活性。
📘3. 互联网服务行业
在互联网服务行业中,云原生后端负责内容管理、用户互动等业务。对于内容管理,它可以实现对大量内容的快速上传、存储和检索。通过容器化和微服务架构,不同的内容管理模块可以独立运行和扩展,提高了系统的灵活性和可维护性。
在用户互动管理方面,云原生后端可以实时处理用户的评论、点赞、分享等互动行为。通过持续交付优化服务,不断推出新的功能和优化用户体验。例如,一些社交媒体平台采用云原生后端技术后,能够快速响应用户的互动需求,提供流畅的用户体验。
对于视频流传输等业务,云原生后端通过弹性可扩展满足不同时间段的流量差异。在黄金时段等高流量需求时期,系统可以自动扩展资源,确保视频流的稳定传输。同时,利用可观测性工具,实时监控系统状态,及时发现并解决问题。
例如,一些在线视频平台采用云原生后端技术后,在黄金时段能够为用户提供流畅的视频观看体验。通过容器编排工具 Kubernetes,可以自动调整容器的数量和分布,确保系统的稳定运行。同时,利用微服务架构,各个业务模块独立开发、部署和扩展,提高了开发效率和系统的灵活性。
📚八、云原生后端面临的挑战及应对措施
📘1. 挑战
技术复杂性:云原生后端涉及众多先进技术,如容器化、微服务、自动化运维等,这对技术人员提出了更高的要求。一方面,掌握这些技术需要投入大量的时间和精力,不仅要熟悉容器的创建、部署、调度等操作,还要了解微服务架构下的服务注册与发现、配置管理等内容。另一方面,将这些技术融合在一起并非易事,需要技术人员具备全面的知识体系和丰富的实践经验。对于企业来说,培养和招聘这样的专业人才存在一定难度。
安全风险:云原生后端的开放性和灵活性带来了一些安全风险。容器的安全漏洞是一个重要问题,例如容器镜像可能存在恶意软件,或者容器运行时可能被攻击者利用。微服务之间的通信安全也不容忽视,如数据在传输过程中可能被窃取或篡改。此外,服务网格中的代理也可能成为攻击的目标。
性能优化:在满足弹性可扩展的同时,确保系统在高流量情况下的性能优化是一个挑战。随着业务的增长,系统可能会面临大量的并发请求,这对系统的响应时间、吞吐量等性能指标提出了更高的要求。例如,在电商购物节等高峰期,系统需要快速处理大量的订单,这就需要不断探索合适的算法和技术手段来提高系统的性能。
📘2. 应对措施
培养专业技术人员:企业可以加强内部培训,提高现有员工的技术水平。例如,可以组织内部培训课程,邀请行业专家进行讲座,分享云原生技术的最新发展和实践经验。同时,企业也可以与高校、培训机构等合作,引进专业人才。此外,还可以通过参加行业会议、技术论坛等方式,了解最新的技术动态和解决方案,鼓励员工不断学习和提升自己的技术能力。
采取有效的安全措施:针对安全风险,企业可以采取一系列安全措施。首先,加强容器的安全管理,定期进行安全漏洞扫描和修复。可以使用安全扫描工具对容器镜像进行检测,及时发现并修复潜在的安全漏洞。其次,采用加密通信技术,保障微服务之间的通信安全。例如,使用 SSL/TLS 加密协议对数据进行加密传输,防止数据被窃取或篡改。同时,建立完善的安全监控体系,及时发现和处理安全事件。可以使用安全监控工具对系统进行实时监测,一旦发现异常情况,立即采取相应的措施进行处理。
探索合适的算法和技术手段:在性能优化方面,企业可以采用性能测试工具,对系统进行全面的性能测试,找出性能瓶颈并进行优化。例如,可以使用 JMeter 等性能测试工具对系统进行压力测试,分析系统在高负载情况下的性能表现。同时,也可以借鉴行业内的最佳实践,采用合适的算法和技术手段,提高系统的性能和稳定性。例如,使用缓存技术、异步处理等方式来提高系统的响应速度和吞吐量。
📚九、云原生后端的未来发展方向
随着边缘计算的普及,云原生技术将扩展到边缘设备,减少延迟并提高用户体验。
边缘计算作为云计算的重要补充,正逐渐成为一种趋势。在 5G 时代,80% 的数据和计算将发生在边缘,这使得边缘计算的重要性日益凸显。云原生技术与边缘计算的结合,将为未来的应用架构带来新的发展方向。
云原生技术在边缘侧的应用面临着诸多挑战。首先,网络带宽和延迟问题是一个关键因素。虽然边缘计算可以减少数据传输的带宽和延迟,但在一些偏远地区或网络环境较差的情况下,数据传输仍然会受到很大的限制。因此,提高网络带宽和减少延迟是云原生边缘计算需要解决的首要问题。其次,数据安全和隐私保护问题也不容忽视。边缘端设备数量庞大,数据量巨大,如何保证数据的安全和隐私保护是云原生边缘计算需要解决的另一个重要问题。在实际应用中,可以采用加密算法、身份认证、访问控制等手段来保护数据的安全和隐私。此外,系统可维护性和可扩展性问题以及业务场景适配问题也是云原生边缘计算需要面对的挑战。
为了应对这些挑战,阿里云等企业进行了充分的实践。例如,阿里云推出了边缘容器的产品方案,从五个具体场景出发,为大家介绍了阿里云边缘节点服务(ENS)的一些落地实践经验。同时,阿里云还举办了「KubeMeet|EDGE X Kubernetes」专场沙龙,邀请了来自不同行业和应用场景的社区贡献者共同分享云原生在边缘的实践与应用。
在实际应用中,云原生技术在边缘侧的应用场景非常广泛。例如,在工业制造、自动驾驶、智慧城市、智能家居等领域,云原生边缘计算都可以发挥重要作用。在工业制造领域,云原生边缘计算可以用于优化风力涡轮机,并需要预测性维护和振动分析。在自动驾驶领域,云原生边缘计算可以实现车路协同、交通监测等功能。在智慧城市领域,云原生边缘计算可以用于道路计算、公用事业计算、消费计算、安全计算和家庭计算等场景。在智能家居领域,云原生边缘计算可以实现云游戏、VR/AR 等功能。
未来,云原生技术在边缘侧的应用将越来越广泛。随着技术的不断发展和应用的不断深入,相信云原生边缘计算将会越来越成熟和普及。同时,云原生技术在边缘侧的应用也将为未来的后端开发带来新的趋势和挑战。例如,未来的后端开发将更加注重云原生技术与边缘计算的结合,以实现更低的延迟和更高的用户体验。同时,未来的后端开发也将更加注重数据安全和隐私保护,以应对边缘端设备数量庞大、数据量巨大的挑战。此外,未来的后端开发还将更加注重系统的可维护性和可扩展性,以适应不断变化的业务需求。
📚十、总结
云原生后端结合了容器化、微服务、动态编排和自动化运维等技术,为企业提供强大的支持,使开发者能够以更加敏捷和高效的方式应对市场变化和技术挑战。
云原生后端在当今数字化时代具有重要意义。它的出现满足了企业对于应用程序开发、部署和运维的更高要求,为企业带来了更高效、灵活、可扩展且可靠的后端解决方案。
从概念上看,云原生后端是基于云原生技术构建的应用程序后端部分,充分利用云计算的优势,将容器化、微服务、持续交付等关键技术融合,打造具有高度弹性、可快速迭代且易于管理的后端架构。
在特点方面,容器化通过将应用及其依赖打包成容器,实现了应用的隔离和可移植性,降
低了环境差异带来的部署难题,提高了系统安全性。微服务架构将后端应用拆分成多个小型、相互独立的微服务,每个微服务专注于特定业务功能,通过轻量级通信机制交互,提高了开发效率和系统灵活性。持续交付与自动化通过建立持续交付管道,实现自动化的构建、测试、部署等流程,缩短了应用上线周期,及时响应市场需求变化。弹性可扩展能够根据业务负载自动调整资源分配,保证系统稳定运行的同时节约成本。
关键技术支撑包括容器编排技术如 Kubernetes,负责管理容器的生命周期,实现容器的集群化管理;微服务框架如 Spring Cloud、Dubbo 等,为开发人员提供便捷方式构建、部署和管理微服务;自动化运维工具如 Ansible、Chef 等,实现对服务器、容器、微服务等的自动化配置、部署和管理。
云原生后端具有诸多优势,提高开发效率方面,微服务架构使不同团队可以并行开发不同微服务,减少相互依赖和等待时间,持续交付让代码更快进入生产环节。增强系统灵活性方面,容器化和微服务架构让企业可根据业务需求灵活调整后端架构,快速添加或删除微服务。降低运维成本方面,自动化运维工具和弹性可扩展特性减少人工干预,降低运维成本。提升用户体验方面,能够快速响应用户需求变化,保证系统在高流量时期稳定运行,通过持续交付不断优化应用。
在应用场景上,电商行业可利用云原生后端处理海量订单、库存管理和用户信息管理等业务,在购物节等高峰期通过弹性可扩展特性增加资源,保证购物流程顺畅,平时合理调整资源节约成本。金融行业可用于交易处理、风险评估和客户账户管理,保障安全性和可靠性的同时应对业务流量变化。互联网服务行业负责内容管理、用户互动管理和视频流传输等业务,通过持续交付优化服务,满足不同时间段的流量差异。
然而,云原生后端也面临着挑战,技术复杂性要求专业技术人员掌握众多先进技术并融合运用,企业培养和招聘这样的人才存在难度。安全风险方面,容器的安全漏洞和微服务之间的通信安全等问题需要采取有效安全措施。性能优化方面,在满足弹性可扩展的同时确保系统在高流量情况下的性能优化是一个挑战。
针对这些挑战,可以采取培养专业技术人员、采取有效的安全措施、探索合适的算法和技术手段等应对措施。
随着边缘计算的普及,云原生技术将扩展到边缘设备,减少延迟并提高用户体验。未来,云原生后端将继续围绕自动化和智能化展开,为企业实现数字化转型提供重要支持。
到此这篇文章就介绍到这了,更多精彩内容请关注本人以前的文章或继续浏览下面的文章,创作不易,如果能帮助到大家,希望大家多多支持宝码香车~💕,若转载本文,一定注明本文链接。
更多专栏订阅推荐:
👍 html+css+js 绚丽效果
💕 vue
✈️ Electron
⭐️ js
📝 字符串
✍️ 时间对象(Date())操作