全部产品
Search
文档中心

云效:Java 应用测试构建并发布至 ACK/K8S

更新时间:Sep 27, 2021

一、背景

如果你

  • 使用Java进行开发

  • 使用容器镜像的制品形式进行交付制品

  • 最终会运行在阿里云ACK或者其他K8S集群上

  • 那么本文档可以帮助您实现研发流程的协同自动化。

二、用户诉求

一般来说,使用K8S部署场景如下:

  • 对源代码进行一定的质量检测,比如单元测试,代码扫描

  • 将源代码构建成为可交付的制品,也就是容器镜像

  • 对制品进行测试环境验证

  • 使用完成验证的制品进行线上部署

  • 使用基础设施即代码的方式,在代码库中管理与应用相关的所有yaml文件。使用这种方式,将k8s的编排能力完全交给开发,比较灵活,也更加利于DevOps的实施。

三、云效操作实践

接下来以一个 Java Spring Boot 的代码库为例,讲解如何进行构建并以kubectl apply的方式部署到阿里云 ACK。

创建流水线

1. 进入云效 Flow(https://flow.alibabacloud.com/)。

2. 点击”创建流水线”。

1

3. 选择"Java · Test, build Image, and deploy to Kubernetes cluster/ACK"模板,并点击创建。

123

配置代码库

1. 添加代码库,选择“通用Git”,输入示例代码库地址“https://github.com/yunxiao-devops/spring-boot-example.git”,默认分支输入”master“。由于示例代码库为公开代码库,可以随意输入个人证书。

2. 示例代码库地址为:https://github.com/yunxiao-devops/spring-boot-example.git,请先查看相关的manifest文件,其中包含了一个deployment,一个service,以及一个ingress将这个服务暴露到公网上:

123231

配置镜像构建任务

1. 你需要先在cr.console.aliyun.com上创建一个镜像仓库,然后在流水线中进入“镜像构建并推送至阿里云镜像仓库”的任务进行编辑。点击”新建服务授权”,进行阿里云授权。同意授权之后,Flow会将创建好的服务授权自动回填写到表单中。

12312332 1231232

2. 接下来完成区域、仓库的选取。标签填入“${DATETIME}”,表示以流水线触发时的时间戳作为镜像的标签。Dockerfile路径填入”Dockerfile2”

12312

3. 配置好之后再“镜像构建并推送至阿里云镜像仓库”任务的下方可以看到该任务输出的变量,这些变量可以在后续的任务中引用。关注其中的第二个和第三个变量即可,其中第二个是该镜像地址的公网地址,第三个是该镜像地址的VPC地址。这里推荐将镜像仓库和ACK集群放在同一个集群,然后在后续的部署任务中选择VPC地址,以加速部署过程。

123212312

配置部署任务

1. 点击“Kubernetes发布”任务,进入配置。点击”新建连接”,填写集群名和Kubeconfig信息。点击确认之后,集群信息会自动填到任务配置中。

12312312213123

2. 配置变量,填入IMAGE,并选择镜像的地址作为变量值。这样在运行时,Flow会把YAML路径下的所有文件中的${IMAGE}都替换成镜像的地址,然后再进行kubectl发布。

12312

3. 示例代码库中的文件https://github.com/yunxiao-devops/spring-boot-example/blob/master/app-configs/manifest-app/app.yaml的内容如下,所以其中的${IMAGE}就会被替换成实际的镜像地址。

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  labels:
    run: spring-boot-sample
  name: spring-boot-sample
spec:
  replicas: 2
  selector:
    matchLabels:
      run: spring-boot-sample
  template:
    metadata:
      labels:
        run: spring-boot-sample
    spec:
      containers:
      - image: ${IMAGE}
        name: app

4. 配置变量,填入HOST,并输入ACK集群中的“测试域名”:

123212

5. 示例代码库中的文件https://github.com/yunxiao-devops/spring-boot-example/blob/master/app-configs/manifest-app/ingress.yaml的内容如下,所以其中的${HOST}就会被替换成实际的测试地址。

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: spring-boot-route
spec:
  rules:
    - host: www.${HOST}
      http:
        paths:
          - backend:
              serviceName: spring-boot-service
              servicePort: 8080
            path: /

运行流水线

1. 配置完毕,点击”保存并运行”触发流水线:

12312123

2. 由于在manifest中包含了ingress配置,因此可以通过ack的ingress提供的域名访问服务:

$ curl http://www.${HOST}
Greetings from Spring Boot!