本篇主要讲解如何将golang的服务部署到kubernetes集群里,附带相关的golang的demo和yml文件内容。纯新手入门方式,生产服务需要完整的CI/CD流程来支持。
golang服务代码
这里简单写一个k8s-demo的服务,提供两个接口ping和version接口,main.go文件代码如下:
构建命令:CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -o k8s-demo main.go
Dockerfile文件
这里只提供最基础的demo写法,如果有额外的需求在dockerfile文件内补充就行,Dockerfile文件内容如下:
FROM alpine
ADD k8s-demo /data/app/
WORKDIR /data/app/
CMD ["/bin/bash","-c","./k8s-demo"]
CI构建脚本
写一个build.sh,用于编译二进制文件,然后进行docker镜像打包和推送进行到镜像仓库:
#!/bin/bash
set -e
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -o k8s-demo main.go
docker build -t www.5bug.wang/docker/k8s-demo:1.0 .
docker push www.5bug.wang/docker/k8s-demo:1.0
执行build.sh脚本文件即可,请确保此步骤成功将镜像推送到你的镜像仓库里。
kubernetes部署
准备创建deployment的yaml文件
kubernetes版本1.18,我这里使用yaml文件创建deployment来部署k8s-demo服务到k8s集群里,k8s-demo.yaml文件内容如下:
此yaml文件里主要定义了三种资源:deployment、service、ingress,都配置在默认的namespace里,yaml文件里的每项内容做什么用的下一篇再补充,这里先把服务部署起来找找成就感!
k8s部署
在已经搭建好k8s环境的master节点里使用kubectl命令来执行部署,命令如下:
kubectl apply -f k8s-demo.yaml
执行效果如下:
稍等会通过通过查询pods列表的命令:kubectl get pods 来查看pod运行状态,如下图:
配置外部访问
k8s的服务支持外部访问的方式有好几种,我这里我采用了ingress的方式,由于是本地使用,所以这里需要绑下host文件,通过查询ingress的命令查询ingress列表可以得知host绑什么IP地址,如下::
5bug.wang-MacBook:~/codes/projects/k8s-demo$ kubectl get ingress
NAME CLASS HOSTS ADDRESS PORTS AGE
k8s-demo-ingress <none> k8s-demo.local 192.168.99.103 80 7m26s
修改/etc/hosts文件,增加:192.168.99.103 k8s-demo.local即可。
浏览器里访问:http://k8s-demo.local/ping即可看到ping接口的返回值了,到这里k8s-demo成功部署到k8s集群里了。