我一直在尝试使用本地 minikube 安装的 skaffold。能够在尽可能接近生产的东西上开发您的项目真是太好了。
如果我使用skaffold github repo 上提供的入门示例,一切正常,我的 IDE(intellij idea)在断点处停止,当我修改代码时,更改会立即反映。
现在,在我的个人项目中,它比简单的 main.go 文件更复杂一些,但事情并没有按预期工作。IDE 在断点处停止,但即使我在控制台中看到 skaffold 检测到对该特定文件所做的更改,但热代码重新加载也没有发生,但不幸的是,这些更改没有反映/应用。
一个docker文件用于构建镜像,docker文件如下
FROM golang:1.14 AS builder
WORKDIR /app
COPY go.mod go.sum ./
RUN go mod download
COPY . .
RUN CGO_ENABLED=0 go build -o /app.o ./cmd/shortener/shortener.go
FROM alpine:3.12
COPY --from=builder /app.o ./
COPY --from=builder /app ./
EXPOSE 3000
ENV GOTRACEBACK=all
CMD ["./app.o"]
在 kubernetes 方面,我正在创建一个部署和一个服务,如下所示:
apiVersion: apps/v1
kind: Deployment
metadata:
name: url-shortener-deployment
spec:
selector:
matchLabels:
app: url-shortener
template:
metadata:
labels:
app: url-shortener
spec:
containers:
- name: url-shortener
image: url_shortener
ports:
- containerPort: 3000
---
apiVersion: v1
kind: Service
metadata:
name: url-shortener-service
spec:
selector:
app: url-shortener
ports:
- port: 3000
nodePort: 30000
type: NodePort
至于 skaffold,这里是 skaffold.yaml 文件:
apiVersion: skaffold/v2beta5
kind: Config
metadata:
name: url-shortener
build:
artifacts:
- image: url_shortener
context: shortener
docker:
dockerfile: build/docker/Dockerfile.dev
noCache: false
deploy:
kubectl:
manifests:
- stack/mongo/mongo.yaml
- shortener/deployments/kubernetes/shortener.yaml
我已启用详细日志记录,每当我保存 (CTRL+S) 源代码文件时,我都会在输出中注意到这一点。
time="2020-07-05T22:51:08+02:00" level=debug msg="Found dependencies for dockerfile: [{go.mod /app true} {go.sum /app true} {. /app true}]"
time="2020-07-05T22:51:08+02:00" level=info msg="files modified: [shortener/internal/handler/rest/rest.go]"
我假设这意味着已检测到更改。
断点在 IDE 中正常工作,但 kubernetes 中的代码交换似乎没有发生