【云原生】持续集成&持续部署

本文主要总结CI/CD的流程,不会详细介绍每个知识点。

啥是集成?啥是部署?

集成,就是把应用程序、相关环境、配置全局打包放在一个容器中的操作。部署就不解释了。

CI/CD

如果是自己手动部署的话,流程应该是这样的:

  • 在本地打包成jar包
  • 将jar包上传至服务器
  • 在服务器上其他环境,比如jdk环境
  • 在服务器上启动该服务
  • 如果有代码更新,就先更新代码,然后重复上述步骤

现在有了CI/CD(持续集成/持续部署)之后,这个操作流程就变成自动化的了。下图是一个k8s+jenkins实现CI/CD的示意图:

Docker&K8S

一文带你认识「Docker」与「k8s」 - 掘金

在K8S中,有很多个pod,每个pod对应一个namespace(命名空间)。

每个pod中,有很多个container容器,每个container对应一个应用程序。

如果写成树结构,就是这样的:

复制代码
K8S
    pod1(namespace1)
        container11(应用程序)
        container12(应用程序)
        ...
    pod2(namespace2)
        container21(应用程序)
        container22(应用程序)
        ...
    ...

Nginx-ingress

现在应用程序在每个容器中运行起来了。那用户如何通过k8s访问到内部的应用呢?用Nginx-ingress。
Kubernetes(k8s)Ingress原理 - 大数据老司机 - 博客园

实现上来说,就是加一个.yaml配置文件,用于将请求映射到k8s中某个运行的容器。然后应用 yaml 到 k8s kubectl apply -f <yaml文件名>,至此,就可以通过配置的域名进行访问了。

总结

如果自己要进行CI/CD,步骤应该是这样的:

  • 写好代码,push到代码托管平台
  • 代码托管平台封装Docker镜像(CI)
  • K8S拉取Docker镜像,并运行(CD)
  • 用户访问服务,Nginx根据用户的请求将请求转发到K8S中对应的运行的应用(Nginx-Ingress)
相关推荐
一战成名9968 小时前
AI 模型持续集成流水线:CANN 支持的 DevOps 最佳实践
人工智能·ci/cd·devops
我会一直在的8 小时前
Devps持续集成
git·ci/cd
池央2 天前
CANN oam-tools 诊断体系深度解析:自动化信息采集、AI Core 异常解析与 CI/CD 流水线集成策略
人工智能·ci/cd·自动化
池央2 天前
CANN GE 深度解析:图编译器的核心优化策略、执行流调度与模型下沉技术原理
人工智能·ci/cd·自动化
3GPP仿真实验室2 天前
【Matlab源码】6G候选波形:OFDM-IM 增强仿真平台 DM、CI
开发语言·matlab·ci/cd
小Tomkk2 天前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
_运维那些事儿3 天前
VM环境的CI/CD
linux·运维·网络·阿里云·ci/cd·docker·云计算
木童6623 天前
Ruo-Yi 项目 CI/CD 详细部署文档
ci/cd
爬山算法3 天前
Hibernate(85)如何在持续集成/持续部署(CI/CD)中使用Hibernate?
java·ci/cd·hibernate
吹牛不交税3 天前
gitea安装windows并实现CICD持续集成部署
ci/cd·gitea