在Kubernetes中,DaemonSet是一种用于运行一个Pod副本实例的控制器,每个节点上只会运行一个该Pod副本实例。通常情况下,DaemonSet用于运行特定的系统任务或服务。
以下是一个简单的golang DaemonSet部署示例:
- 编写golang程序
编写一个简单的golang程序 main.go
,例如:
package main
import (
"fmt"
"net/http"
)
func main() {
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "Hello from Golang DaemonSet!")
})
http.ListenAndServe(":8080", nil)
}
- 创建Docker镜像并推送到仓库
使用Dockerfile将golang程序打包为Docker镜像,并将其推送到镜像仓库中,例如:
FROM golang:1.15-alpine AS build-env
RUN apk --no-cache add ca-certificates git && \
go get -u github.com/gorilla/mux && \
mkdir /app
ADD . /app/
WORKDIR /app
RUN go build -o app .
FROM alpine:3.12
COPY --from=build-env /app/app /usr/local/bin/app
EXPOSE 8080
CMD ["app"]
执行以下命令构建并推送Docker镜像:
$ docker build -t your-repo/golang-daemonset:v1 .
$ docker push your-repo/golang-daemonset:v1
- 创建DaemonSet YAML文件
创建一个名为 golang-daemonset.yaml
的YAML文件,用于定义DaemonSet对象:
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: golang-daemonset
spec:
selector:
matchLabels:
app: golang-daemonset
template:
metadata:
labels:
app: golang-daemonset
spec:
containers:
- name: app-container
image: your-repo/golang-daemonset:v1
ports:
- containerPort: 8080
- 部署DaemonSet
执行以下命令创建并部署DaemonSet:
$ kubectl apply -f golang-daemonset.yaml
该命令会在Kubernetes集群中创建一个名为 golang-daemonset
的DaemonSet对象,并自动运行一个Pod副本实例。可以使用以下命令查看DaemonSet的状态:
$ kubectl get daemonsets.apps golang-daemonset
NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE
golang-daemonset 3 3 3 3 3 <none> 2m13s
其中, DESIRED
字段表示期望的Pod副本数(即DaemonSet所管理的节点数), CURRENT
字段表示当前正在运行的Pod副本数, READY
字段表示已经就绪的Pod副本数。
- 访问服务
由于该程序监听端口号8080,因此可以通过访问任意一个宿主机上的IP地址加端口号8080来访问服务。例如:
$ curl http://node-ip-address:8080
Hello from Golang DaemonSet!