容器镜像服务联手 IDE 插件,实现一键部署、持续集成与交付

容器技术提供了一种标准化的交付方式,将应用的代码以及代码环境依赖都打包在一块儿,成为一个与环境无关的交付物,能够被用在软件生命周期的任何阶段,完全改变了传统的软件交付方式。小程序

甚至能够说,是在容器技术以后,DevOps、CI/CD 等运维关键问题才有了质的飞跃:实现资源的动态建立和销毁,更轻量的容器技术既能保证环境一致性也能进一步提升迭代频率,各类容器平台也能更好地保证应用高可用、自动伸缩、业务连续等等。安全

今天将跟你们分享支撑双十一的容器镜像仓库 ACR,以及它是如何实现搭配 IDE 插件和 CICD/云原生应用交付链来实现一键部署与持续集成,如下是本文提纲:服务器

  • 什么是容器镜像仓库 ACR
  • 如何搭配免费 IDE 插件实现一键部署
  • 如何运用 CICD/ 云原生应用交付链实现持续集成与交付
想听软萌音在线讲解?阿里云小姐姐直播,手把手教你,12月5日晚上8点—9点,直播间等你(还有弹幕截屏送礼品!),直播间地址点击连接: https://developer.aliyun.com/special/cloudtoolkitlive

容器镜像仓库 ACR

为了更好地支持双十一大规模分发需求,容器镜像服务(Alibaba Cloud Container Registery, ACR)团队提早进行规划及迭代更新,全面提高了大规模分发场景下的性能、可观测性和稳定性。在新的双十一来临前,容器镜像服务已达到了 PB 的镜像托管量,月均镜像拉取达数亿次,平滑度过 54.4 万笔交易峰值。微信

阿里云镜像仓库 ACR 分为默认实例版与企业版,虽然结合阿里云产品作了多维度优化,可是并不与阿里云强制绑定。ACR 默认实例版面向容器开发者,提供安全的镜像托管、便捷的镜像受权功能,方便用户进行镜像全生命周期管理,而且简化了 Registry 的搭建运维工做,支持全球 20 个地域的镜像托管。ACR 企业版面向安全需求高、业务多地域大规模部署的企业级客户,提供大规模镜像分发能力、企业级的安全独享特性,以及云原生应用交付链,全链路可观测、可跟踪以及可设置,可实现一次应用变动,多场景自动化交付。网络

1

如何搭配 免费 IDE 插件实现一键部署

2

Cloud Toolkit 是一款免费的本地 IDE 插件,不少技术博客都有相关的测评,是一款口碑较好的插件。它可以帮助开发者更高效地开发、测试、诊断并部署应用。设置好插件的初始配置以后,能够将本地应用一键部署到任意服务器 Host,甚至云端(ECS、ACR、Kubernetes 和 小程序云 等);而且还内置了 Arthas 诊断、Dubbo工具、Terminal 终端、文件上传、函数计算 和 MySQL 执行器等工具,减小了切换工做界面的时间,灵巧且实用,推荐安装试用一波。下面介绍,插件如何将应用一键部署到容器镜像仓库 ACR 。less

开发者的部署包从造成镜像到镜像仓库,手动操做的话,每一次都须要经历下图 4 个步骤:登陆阿里云Docker Registr--> 从Registry中拉取镜像 --> 将镜像推送到Registry --> 选择合适的镜像仓库地址,可是,使用 Cloud Toolkit ,开发者能够实如今本地 IDE 就能一键部署到镜像仓库。运维

3

(一)配置插件首选项

安装完插件以后,点击:顶部菜单Tools --> Alibaba Cloud Toolkit --> Preferences-->左边列表的 Alibaba Cloud Toolkit--> Accounts ,出现以下界面,配置阿里云帐号的 AK 和 SK,便可完成首选项配置。(若是是子帐号,则填写子帐号的 AK 和 SK)。函数

4

(二)设置本地 Docker 镜像打包

**点击:顶部菜单Tools --> Alibaba Cloud Toolkit --> Preferences --> 左边列表的 Alibaba Cloud Toolkit --> Docker,以下图,设置本地 Docker 镜像打包。微服务

5

(三)部署应用

第一步:在 Intellij IDEA 中,以下图点击:顶部菜单Tools --> Alibaba Cloud  -->Deploy to ACR/ACK --> Deploy to ACR。工具

6

第二步:设置 Image

  • 在 Image 标签页中,选择本地应用程序的 Context Directory 和 Dockerfile (一般会根据您本地的应用工程自动识别并设置)。
  • 选择容器镜像服务的地域、命名空间和镜像仓库。

7

第三步:执行部署

点击 Run 按钮以后,便可完成将本地 Docker 镜像推送到 ACR 中去。

如何运用 CICD/云原生应用交付链,实现持续集成与交付

8

ACR企业版的云原生交付链在托管交付分发等方面进一步提高,历经双11大促,沉淀了云原生应用万节点协同的技术经验。

目前支持容器镜像、Helm Chart 两类云原生应用资产,并采用独立网络访问控制,可细粒度控制公网及VPC 网络的访问策略,仅容许符合策略的来源方访问资产,保障访问安全。

同时实现了整个应用交付周期的流程自动化,开发者只要一次变动应用,按照配置多场景交付,便可实现一次应用变动,全球化多场景自动交付。

9

在应用交付环节,ACR EE 支持自动发起静态安全扫描并自定义配置安全阻断策略。一旦识别到静态应用中存在高危漏洞后,可自动阻断后续部署链路。用户可基于漏洞报告中的修复建议,更新优化构建成新的镜像版本,再次发起交付。
建设 CICD 体系还须要考虑到总体稳定和尽量不断提高总体交付能力,好比监控报警、容错容灾、依赖治理、限流降级、容量规划。这里能够和你们分享 ACR 团队的相关经验:

  • 在依赖治理方面,要对云原生应用交付链中相关重点环节及外部依赖进行统一管理,识别热点仓库及追踪交付链执行结果;
  • 在限流降级方面,最好分析识别云原生应用分发核心环节的主次业务功能,优先保障主要业务逻辑完成,次要业务逻辑可降级延后处理;
  • 在容量规划方面,平台根据上下游业务变化状况,对资源进行按需扩容,确保云原生应用正常交付完成。

容器镜像服务 ACR 与 插件 Cloud Toolkit 免费面向开发者,帮助技术人员提升开发、部署效率,在减小时间成本的同时提升了业务的质量,还有双十一的顶级洪峰流量场景做为实践案例,但愿这篇文章能帮助到有须要的人,并经过相关文章快速上手,真正实现业务价值。

直播介绍

想听软萌音在线讲解?阿里云小姐姐直播手把手教你高效制做、一键部署镜像,12 月 5 日晚上 8 点—9 点,直播间等你(还有弹幕截屏送礼品!),直播间地址点击连接:https://developer.aliyun.com/special/cloudtoolkitlive

“阿里巴巴云原生微信公众号(ID:Alicloudnative)关注微服务、Serverless、容器、Service Mesh等技术领域、聚焦云原生流行技术趋势、云原生大规模的落地实践,作最懂云原生开发者的技术公众号。”
相关文章
相关标签/搜索