我正试图在Kubernetes集群上部署一个简单的FLASK应用(python Web框架)。我使用的是minikube。
这是我的Helm 3的东西。
部署:
apiVersion: apps/v1
kind: Deployment
metadata:
name: flask-app-deployment
labels:
app: flask-app
some: label
spec:
replicas: 1
selector:
matchLabels:
app: flask-app-pod
template:
metadata:
labels:
app: flask-app-pod
spec:
containers:
- name: flask-app-container
image: flask_app:0.0.1
imagePullPolicy: Never
ports:
- name: app
containerPort: 5000
protocol: TCP
securityContext: # root access for debugging
allowPrivilegeEscalation: false
runAsUser: 0
服务:
apiVersion: v1
kind: Service
metadata:
name: flak-app-service
labels:
service: flask-app-services
spec:
type: NodePort
ports:
- port: 5000
targetPort: 5000
protocol: TCP
name: https
selector:
app: flask-app-pod
图表。
apiVersion: v2
name: flask-app
type: application
version: 0.0.1
appVersion: 0.0.1
我是通过以下方式部署的 helm install test-chart/ --generate-name
.
输出示例 kubectl get all
:
NAME READY STATUS RESTARTS AGE
pod/flask-app-deployment-d94b86cc9-jcmxg 1/1 Running 0 8m19s
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/flak-app-service NodePort 10.98.48.114 <none> 5000:30317/TCP 8m19s
service/kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 7d2h
NAME READY UP-TO-DATE AVAILABLE AGE
deployment.apps/flask-app-deployment 1/1 1 1 8m19s
NAME DESIRED CURRENT READY AGE
replicaset.apps/flask-app-deployment-d94b86cc9 1 1 1 8m19s
我执行了pod检查它是否在正确的端口上监听,看起来很好(netstat输出)。
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:5000 0.0.0.0:* LISTEN 1/python3
我的Docker文件应该没问题 我可以创建一个容器并调用应用程序,然后运行一个 "正常 "的dcker容器。
一定是有什么问题。我在这里没有看到什么?
我希望能够去 https://localhost:30317
其中的内容会被转发到内部5000端口上监听的服务,再由服务转发到同样在5000端口上监听的pod。
为了验证流量,你可以使用以下作为它是打破。
kubectl port-forward pods/flask-app-deployment-d94b86cc9-jcmxg 5000:12345
或
kubectl port-forward deployment/flask-app-deployment 5000:12345
或
kubectl port-forward service/flak-app-service 5000:12345
取决于你想调试的位置。
另外,请通过运行 netstat -tunlp
无论你的主机是否在指定的端口上监听。
希望这能解决你的错误,如果不能解决,请告诉我。