使用 Linux 上的 Kubernetes 管理微服务的实操指南
一 环境准备与集群搭建
curl -Lo minikube https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64 \
&& chmod +x minikube && sudo mv minikube /usr/local/bin/
minikube start
kubectl cluster-info
kubectl get nodes
二 构建镜像与部署微服务
FROM node:14
WORKDIR /usr/src/app
COPY package*.json ./
RUN npm install
COPY . .
EXPOSE 3000
CMD ["npm","start"]
docker build -t my-node-app:latest .
eval $(minikube docker-env) # 仅在 Minikube 本地环境使用
docker build -t my-node-app:latest .
apiVersion: apps/v1
kind: Deployment
metadata:
name: my-node-app
labels:
app: my-node-app
spec:
replicas: 3
selector:
matchLabels:
app: my-node-app
template:
metadata:
labels:
app: my-node-app
spec:
containers:
- name: app
image: my-node-app:latest
ports:
- containerPort: 3000
---
apiVersion: v1
kind: Service
metadata:
name: my-node-app
spec:
type: ClusterIP
selector:
app: my-node-app
ports:
- port: 80
targetPort: 3000
kubectl apply -f deployment.yaml
kubectl get pods -l app=my-node-app
kubectl get svc my-node-app
minikube service my-node-app --url
kubectl scale deployment my-node-app --replicas=5
kubectl rollout status deployment/my-node-app
kubectl rollout undo deployment/my-node-app
三 服务暴露与流量治理
| 类型 | 访问范围 | 典型用途 |
|---|---|---|
| ClusterIP | 集群内部 | 微服务间内部通信(默认类型) |
| NodePort | 节点 IP + 静态端口 | 开发/测试环境对外暴露 |
| LoadBalancer | 云平台负载均衡器 | 生产环境对外暴露 |
| ExternalName | DNS CNAME | 将服务映射为外部域名 |
apiVersion: v1
kind: Service
metadata:
name: my-node-app-np
spec:
type: NodePort
selector:
app: my-node-app
ports:
- port: 80
targetPort: 3000
nodePort: 30001
访问地址:http://<任意节点IP>:30001apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: my-ingress
annotations:
nginx.ingress.kubernetes.io/rewrite-target: /
spec:
rules:
- host: app.example.com
http:
paths:
- path: /
pathType: Prefix
backend:
service:
name: my-node-app
port:
number: 80
kubectl -n kube-system edit cm kube-proxy # 将 mode: 改为 "ipvs"
# 重启 kube-proxy Pod 生效
kubectl -n kube-system delete pod -l k8s-app=kube-proxy
ipvsadm -Ln # 验证 IPVS 规则
minikube dashboard
四 弹性伸缩与运维管理
apiVersion: autoscaling/v2
kind: HorizontalPodAutoscaler
metadata:
name: my-node-app-hpa
spec:
scaleTargetRef:
apiVersion: apps/v1
kind: Deployment
name: my-node-app
minReplicas: 2
maxReplicas: 10
metrics:
- type: Resource
resource:
name: cpu
target:
type: Utilization
averageUtilization: 50
kubectl apply -f hpa.yaml
kubectl get hpa
kubectl create configmap app-config --from-literal=LOG_LEVEL=info
kubectl create secret generic app-secret --from-literal=DB_PASSWORD=xxxx
在 Pod 中引用:envFrom:
- configMapRef:
name: app-config
- secretRef:
name: app-secret
readinessProbe:
httpGet:
path: /health
port: 3000
initialDelaySeconds: 5
periodSeconds: 5
livenessProbe:
httpGet:
path: /health
port: 3000
initialDelaySeconds: 15
periodSeconds: 10
lifecycle:
preStop:
exec:
command: ["/bin/sh","-c","sleep 15"]
kubectl logs -f deployment/my-node-app
kubectl describe pod <pod-name>
kubectl get events --sort-by=.metadata.creationTimestamp
五 落地清单与最佳实践