k8s kubect lexpose deployment 修改nginx的端口时显示 not found
时间: 2023-10-06 18:11:40 浏览: 132
这个问题可能是因为您在使用 `kubectl` 命令时没有指定正确的资源类型或名称。请确保您输入的是正确的命令和资源名称。
例如,如果您要修改名为 `my-nginx` 的 Deployment 的端口,您可以使用以下命令:
```
kubectl edit deployment/my-nginx
```
然后在编辑器中找到 `spec.template.spec.containers[].ports[].containerPort` 字段并修改它以反映您想要的端口号。保存并退出编辑器后,Kubernetes 将更新该 Deployment 的配置,以便使用新的端口。
如果您仍然遇到问题,请提供更多详细信息,以便我更好地帮助您解决问题。
相关问题
kubectl set image deploy deployment-nginx nginx=nginx:1.17.4 -n dev && kubectl rollout pause deploy deployment-nginx
`kubectl set image deploy deployment-nginx nginx=nginx:1.17.4 -n dev && kubectl rollout pause deploy deployment-nginx` 这个命令的作用是更新名为 `deployment-nginx` 的部署中的 `nginx` 容器镜像为 `nginx:1.17.4`,并将其应用到名为 `dev` 的命名空间中。然后,使用 `kubectl rollout pause deploy deployment-nginx` 命令暂停该部署的滚动更新过程。
这个命令可以用于在不中断服务的情况下更新容器镜像。通过暂停滚动更新,可以确保在更新过程中不会启动新的副本,从而避免潜在的问题。在确认更新无误后,可以使用 `kubectl rollout resume deploy deployment-nginx` 命令恢复滚动更新。
k8s mysql yaml deployment
Kubernetes(K8s)是一个开源的容器编排平台,可以帮助我们自动化部署、扩展和管理容器化应用程序。MySQL是一个流行的开源关系型数据库管理系统,可以用于存储和管理数据。在K8s环境中部署MySQL数据库需要使用yaml文件来创建Deployment和Service。Deployment定义了MySQL容器的副本数和更新策略,而Service定义了MySQL容器的访问方式和端口号。以下是一个示例的K8s MySQL YAML Deployment文件:
```yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: mysql-deployment
spec:
replicas: 1
selector:
matchLabels:
app: mysql
template:
metadata:
labels:
app: mysql
spec:
containers:
- name: mysql
image: mysql:latest
env:
- name: MYSQL_ROOT_PASSWORD
value: password
ports:
- containerPort: 3306
volumeMounts:
- name: mysql-persistent-storage
mountPath: /var/lib/mysql
volumes:
- name: mysql-persistent-storage
persistentVolumeClaim:
claimName: mysql-pv-claim
---
apiVersion: v1
kind: Service
metadata:
name: mysql-service
spec:
selector:
app: mysql
ports:
- name: mysql
port: 3306
targetPort: 3306
type: ClusterIP
```
该文件定义了一个名为mysql-deployment的Deployment和一个名为mysql-service的Service。Deployment使用MySQL的最新镜像,并定义了一个名为mysql的容器,该容器使用了一个名为mysql-persistent-storage的持久化存储卷来存储数据。Service定义了一个名为mysql的端口,该端口将流量转发到MySQL容器的端口3306。
阅读全文