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

相关推荐
feilieren6 分钟前
Docker 安装 Elasticsearch 9
运维·elasticsearch·docker·es
小皮侠1 小时前
nginx的使用
java·运维·服务器·前端·git·nginx·github
Wo3Shi4七1 小时前
哈希冲突
数据结构·算法·go
Maki Winster2 小时前
在 Ubuntu 下配置 oh-my-posh —— 普通用户 + root 各自使用独立主题(共享可执行)
linux·运维·ubuntu
泊浮目2 小时前
未来数据库硬件-网络篇
数据库·架构·云计算
翻滚吧键盘2 小时前
debian及衍生发行版apt包管理常见操作
运维·debian
Code季风2 小时前
GORM 部分关键字详解与关联查询实战:Preload 与 Association 的使用对比
go·orm
Code季风2 小时前
深入理解 gRPC 服务定义:从基础到高级
rpc·go
Code季风2 小时前
深入学习 gRPC 流式通信:四种模式详解与实战代码解析
go·grpc