Go开发运维:Go服务发布到K8S集群

目录

一、实验

1.Go服务发布到k8s集群

二、问题

1.如何从Harbor拉取镜像

一、实验

1.Go服务发布到k8s集群

(1)linux机器安装go(基于CentOS 7系统)

bash 复制代码
yum install go -y

(2)查看版本

bash 复制代码
go version

(3)创建源码文件

bash 复制代码
[root@master1 ~]# mkdir test
[root@master1 ~]# cd test/
[root@master1 test]# cat main.go 
package main

import (
	"net/http"

	"github.com/gin-gonic/gin"
)

func statusOKHandler(c *gin.Context) {
	c.JSON(http.StatusOK, gin.H{"status": "success~welcome to study"})
}

func versionHandler(c *gin.Context) {
	c.JSON(http.StatusOK, gin.H{"version": "v1.1版本"})
}

func main() {
	router := gin.New()
	router.Use(gin.Recovery())
	router.GET("/", statusOKHandler)
	router.GET("/version", versionHandler)
	router.Run(":8080")
}

注意这里有小括号:

这里有2个双引号

(4)Go mod初始化项目

bash 复制代码
go mod init test

(5)设置代理

bash 复制代码
go env -w GOPROXY=https://goproxy.cn,direct
bash 复制代码
go mod tidy

(6)构建源码

bash 复制代码
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -o k8s-demo main.go

K8s-demo 为二进制文件:

(7)编写dockerfile文件

实现功能:容器里封装二进制代码

bash 复制代码
[root@master1 test]# cat Dockerfile 
FROM alpine
ADD k8s-demo /data/app/
WORKDIR /data/app/
CMD ["/bin/sh","-c","./k8s-demo"]

(8)构建镜像

bash 复制代码
docker build -t david/k8sdemo:v1 .

(9)打包镜像,传到k8s工作节点

bash 复制代码
docker save -o k8sdemo.tar.gz david/k8sdemo:v1
bash 复制代码
scp k8sdemo.tar.gz node1:/root/

(10)在node1节点解压镜像

bash 复制代码
docker load -i k8sdemo.tar.gz

(11)创建deployment的yaml文件

bash 复制代码
[root@master1 test]# cat k8s.yaml 
    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: k8s-demo
      namespace: default
      labels:
        app: k8s-demo
    spec:
      selector:
        matchLabels:
          app: k8s-demo
      replicas: 4
      template:
        metadata:
          labels:
            app: k8s-demo
        spec:
          containers:
          - image: david/k8sdemo:v1
            imagePullPolicy: IfNotPresent
            name: k8s-demo
            ports:
            - containerPort: 8080
              protocol: TCP
            resources:
              limits:
                cpu: 100m
                memory: 100Mi
              requests:
                cpu: 50m
                memory: 50Mi
            livenessProbe:
              tcpSocket:
                port: 8080
              initialDelaySeconds: 10
              timeoutSeconds: 3
            readinessProbe:
              httpGet:
                path: /
                port: 8080
              initialDelaySeconds: 10
              timeoutSeconds: 2

---
    apiVersion: v1
    kind: Service
    metadata:
      name: k8s-demo-svc
      namespace: default
      labels:
        app: k8s-demo
    spec:
      ports:
        - name: api
          port: 8080
          protocol: TCP
          targetPort: 8080
      selector:
        app: k8s-demo

(12)更新yaml文件

bash 复制代码
kubectl apply -f k8s.yaml

(13)查看pod和svc

bash 复制代码
kubectl get pods
bash 复制代码
kubectl get svc

(14)修改svc的type类型变成nodePort

bash 复制代码
kubectl edit svc k8s-demo-svc

修改前:

修改后:

(15)查看svc

bash 复制代码
kubectl get svc

(16)浏览器访问测试

二、问题

1.如何从Harbor拉取镜像

(1)每个节点修改配置文件

bash 复制代码
vim /etc/docker/daemon.json
bash 复制代码
#增加如下代码:

 "log-driver": "json-file",
"log-opts": {
  "max-size": "100m"
 },  
  "insecure-registries": ["https://192.168.204.110"]

(2)Harbor新建项目

(3)查看镜像

bash 复制代码
docker images

(4)新打标签

bash 复制代码
docker tag david/k8sdemo:v1 192.168.204.110/david-project/k8sdemo:v1

(5)如遇到Harbor登录不了

(6)启动

bash 复制代码
cd /data/install/harbor
docker-compose start

(7)成功

相关推荐
审判长烧鸡2 分钟前
GO错误处理【7】层层递进,环环相扣
go·报错处理
qq_452396231 小时前
第十五篇:《UI自动化中的稳定性优化:解决flaky tests的七种武器》
运维·ui·自动化
j_xxx404_2 小时前
Linux:静态链接与动态链接深度解析
linux·运维·服务器·c++·人工智能
Elastic 中国社区官方博客3 小时前
Elastic-caveman : 在不损失 Elastic 最佳效果的情况下,将 AI 响应 tokens 减少64%
大数据·运维·数据库·人工智能·elasticsearch·搜索引擎·全文检索
审判长烧鸡3 小时前
Go结构体与指针【3】自动解引用
go·指针·结构体·自动解引用
云天AI实战派3 小时前
Agentic AI 全流程实战:用 OpenAI on AWS 搭一个餐饮补货智能体,从 API 调用到容器化上线
人工智能·云计算·aws
jsons13 小时前
给每台虚拟机设置独立控制台密码
linux·运维·服务器
测试狗科研平台4 小时前
第一性原理差分电荷密度分析的计算方法与公式-测试GO
云计算·材料工程·空间计算
审判长烧鸡5 小时前
【GO VS PHP】之 指针/引用传递
go·php·指针·引用传递
云栖梦泽5 小时前
Linux内核与驱动:14.SPI子系统
linux·运维·服务器·c++