创建一个基于Go程序的持续集成/持续部署(CI/CD)流水线

简介: 创建一个基于Go程序的持续集成/持续部署(CI/CD)流水线

创建一个基于Go程序的持续集成/持续部署(CI/CD)流水线,涉及到代码拉取、镜像构建、镜像推送以及在Kubernetes(K8s)上启动服务等多个步骤。下面是一个简化的步骤说明,以及对应的命令行操作或配置文件示例,帮助你构建这样的流水线。

步骤一:环境准备

安装Git:用于代码拉取。

安装Docker:用于镜像构建和推送。

安装kubectl:用于与Kubernetes集群交互。

配置Docker Hub或私有仓库(如Harbor):用于存储Docker镜像。

配置Kubernetes集群:确保你有权限访问一个Kubernetes集群。

步骤二:编写Go程序

确保你的Go项目在GitHub(或其他Git服务)上有版本控制。以下是一个简单的hello.go示例:

go复制代码
 package main  
 
   
 
 import (  
 
     "fmt"  
 
     "net/http"  
 
 )  
 
   
 
 func handler(w http.ResponseWriter, r *http.Request) {  
 
     fmt.Fprintf(w, "Hello, Kubernetes!")  
 
 }  
 
   
 
 func main() {  
 
     http.HandleFunc("/", handler)  
 
     fmt.Println("Server is listening on 8080")  
 
     if err := http.ListenAndServe(":8080", nil); err != nil {  
 
         panic(err)  
 
     }  
 
 }

步骤三:Dockerfile编写

在项目根目录下创建Dockerfile,用于构建镜像:

Dockerfile复制代码
 # 使用官方Go运行时作为父镜像  
 
 FROM golang:1.16  
 
   
 
 # 设置工作目录  
 
 WORKDIR /app  
 
   
 
 # 将当前目录内容复制到位于/app中的容器中  
 
 COPY . .  
 
   
 
 # 构建Go应用  
 
 RUN go build -o hello-app  
 
   
 
 # 指定容器运行时执行的命令  
 
 CMD ["./hello-app"]  
 
   
 
 # 暴露端口  
 
 EXPOSE 8080

步骤四:使用CI/CD工具(以GitHub Actions为例)

在GitHub仓库中创建.github/workflows/ci-cd.yml文件,配置CI/CD流程:

yaml复制代码
 name: CI/CD  
 
   
 
 on:  
 
   push:  
 
     branches: [ main ]  
 
   
 
 jobs:  
 
   build:  
 
     runs-on: ubuntu-latest  
 
     steps:  
 
       - uses: actions/checkout@v2  
 
         
 
       - name: Set up Docker Buildx  
 
         uses: docker/setup-buildx-action@v1  
 
   
 
       - name: Login to DockerHub  
 
         uses: docker/login-action@v1  
 
         with:  
 
           username: ${{ secrets.DOCKER_USERNAME }}  
 
           password: ${{ secrets.DOCKER_PASSWORD }}  
 
   
 
       - name: Build and push  
 
         id: docker_build  
 
         uses: docker/build-push-action@v2  
 
         with:  
 
           push: true  
 
           tags: yourusername/hello-app:latest  
 
   
 
       - name: Deploy to Kubernetes cluster  
 
         uses: azure/k8s-deploy@v1  
 
         with:  
 
           namespace: default  
 
           manifests: |  
 
             deployment.yaml  
 
            image-pull-secrets: |  
 
             name: regcred  
 
            kubectl-version: latest

注意:你需要配置secrets.DOCKER_USERNAME和secrets.DOCKER_PASSWORD在GitHub仓库设置中。

步骤五:编写Kubernetes部署文件

在项目根目录下创建deployment.yaml:

yaml复制代码
 apiVersion: apps/v1  
 
 kind: Deployment  
 
 metadata:  
 
   name: hello-app  
 
 spec:  
 
   replicas: 1  
 
   selector:  
 
     matchLabels:  
 
       app: hello-app  
 
   template:  
 
     metadata:  
 
       labels:  
 
         app: hello-app  
 
     spec:  
 
       containers:  
 
       - name: hello-app  
 
         image: yourusername/hello-app:latest  
 
         ports:  
 
         - containerPort: 8080

步骤六:运行流水线

每次将代码推送到main分支时,GitHub Actions将自动触发CI/CD流程,包括构建Docker镜像、推送镜像到Docker Hub,并在Kubernetes集群中部署应用。

这只是一个基础的示例,根据你的具体需求,你可能需要调整Dockerfile、Kubernetes配置文件或CI/CD流程。

效果:

image.png

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
1月前
|
人工智能 数据可视化 开发者
FlowiseAI:34K Star!集成多种模型和100+组件的 LLM 应用低代码开发平台,拖拽组件轻松构建程序
FlowiseAI 是一款开源的低代码工具,通过拖拽可视化组件,用户可以快速构建自定义的 LLM 应用程序,支持多模型集成和记忆功能。
117 14
FlowiseAI:34K Star!集成多种模型和100+组件的 LLM 应用低代码开发平台,拖拽组件轻松构建程序
|
3月前
|
缓存 监控 前端开发
Go 语言中如何集成 WebSocket 与 Socket.IO,实现高效、灵活的实时通信
本文探讨了在 Go 语言中如何集成 WebSocket 与 Socket.IO,实现高效、灵活的实时通信。首先介绍了 WebSocket 和 Socket.IO 的基本概念及其优势,接着详细讲解了 Go 语言中 WebSocket 的实现方法,以及二者集成的重要意义和具体步骤。文章还讨论了集成过程中需要注意的问题,如协议兼容性、消息格式、并发处理等,并提供了实时聊天、数据监控和在线协作工具等应用案例,最后提出了性能优化策略,包括数据压缩、缓存策略和连接管理优化。旨在帮助开发者更好地理解并应用这些技术。
160 3
|
3月前
|
Go 数据处理 开发者
Go 语言的反射机制允许程序在运行时动态检查和操作类型信息,提供极大的灵活性和扩展性
Go 语言的反射机制允许程序在运行时动态检查和操作类型信息,提供极大的灵活性和扩展性。本文探讨了反射的基本原理、主要操作、应用场景及注意事项,并通过实例展示了反射的实际应用,帮助开发者更好地理解和使用这一强大特性。
56 2
|
5月前
|
Kubernetes Go 持续交付
一个基于Go程序的持续集成/持续部署(CI/CD)
本教程通过一个简单的Go程序示例,展示了如何使用GitHub Actions实现从代码提交到Kubernetes部署的CI/CD流程。首先创建并版本控制Go项目,接着编写Dockerfile构建镜像,再配置CI/CD流程自动化构建、推送Docker镜像及部署应用。此流程基于GitHub仓库,适用于快速迭代开发。
117 3
|
4月前
|
存储 缓存 安全
如何使用 PHP 将天气跟踪集成到 Web 应用程序中
如何使用 PHP 将天气跟踪集成到 Web 应用程序中
51 0
|
5月前
|
IDE Go 数据处理
Go to Learn Go之第一个Go程序
Go to Learn Go之第一个Go程序
41 0
|
4月前
|
Java Maven Docker
gitlab-ci 集成 k3s 部署spring boot 应用
gitlab-ci 集成 k3s 部署spring boot 应用
|
3月前
|
消息中间件 监控 Java
您是否已集成 Spring Boot 与 ActiveMQ?
您是否已集成 Spring Boot 与 ActiveMQ?
79 0
|
7月前
|
监控 druid Java
spring boot 集成配置阿里 Druid监控配置
spring boot 集成配置阿里 Druid监控配置
351 6
|
7月前
|
Java 关系型数据库 MySQL
如何实现Springboot+camunda+mysql的集成
【7月更文挑战第2天】集成Spring Boot、Camunda和MySQL的简要步骤: 1. 初始化Spring Boot项目,添加Camunda和MySQL驱动依赖。 2. 配置`application.properties`,包括数据库URL、用户名和密码。 3. 设置Camunda引擎属性,指定数据源。 4. 引入流程定义文件(如`.bpmn`)。 5. 创建服务处理流程操作,创建控制器接收请求。 6. Camunda自动在数据库创建表结构。 7. 启动应用,测试流程启动,如通过服务和控制器开始流程实例。 示例代码包括服务类启动流程实例及控制器接口。实际集成需按业务需求调整。
513 4

热门文章

最新文章