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)成功

相关推荐
dragoooon3418 小时前
[Linux系统编程——Lesson6.进程切换与调度]
linux·运维·服务器
waves浪游18 小时前
Linux基本指令(下)
linux·运维·服务器
2401_8315017318 小时前
Linux之lvm存储卷管理篇
运维
The Future is mine19 小时前
.Net Core 在Linux系统下创建服务
linux·运维·.netcore
一只积极向上的小咸鱼19 小时前
Windows中通过wsl运行Ubuntu
linux·运维·ubuntu
爱吃汽的小橘19 小时前
异步串口通信和逻辑分析仪
运维·服务器·网络·单片机·嵌入式硬件·fpga开发
Serverless 社区20 小时前
阿里云函数计算 AgentRun 全新发布,构筑智能体时代的基础设施
人工智能·阿里云·云原生·serverless·云计算
Maple_land21 小时前
Linux进程第八讲——进程状态全景解析(二):从阻塞到消亡的完整生命周期
linux·运维·服务器·c++·centos
爱吃生蚝的于勒21 小时前
【Linux】零基础学会Linux之权限
linux·运维·服务器·数据结构·git·算法·github
Cyan_RA921 小时前
Linux 远程Ubuntu服务器本地部署大模型 EmoLLM 中常见的问题及解决方案 万字详解
linux·运维·服务器·ubuntu·大模型·远程部署·emollm