本文主要总结CI/CD的流程,不会详细介绍每个知识点。
啥是集成?啥是部署?
集成,就是把应用程序、相关环境、配置全局打包放在一个容器中的操作。部署就不解释了。
CI/CD
如果是自己手动部署的话,流程应该是这样的:
- 在本地打包成jar包
- 将jar包上传至服务器
- 在服务器上其他环境,比如jdk环境
- 在服务器上启动该服务
- 如果有代码更新,就先更新代码,然后重复上述步骤
现在有了CI/CD(持续集成/持续部署)之后,这个操作流程就变成自动化的了。下图是一个k8s+jenkins实现CI/CD的示意图:
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)