K8S中nodePort使用端口范围受限问题

K8S中nodePort使用端口范围受限问题

场景:

在K8S集群中部署Oracle,使用NodePort对外暴露端口的时候,出现暴露端口受限的问题。

报错:

The Service “oracle-server” is invalid: spec.ports[0].nodePort: Invalid value: 1521: provided port is not in the valid range. The range of valid ports is 30000-32767

解决方式:

一、RKE方式搭建的解决
#这是我们在搭建K8S所写的配置文件,按官网步骤来,它应该是叫cluster.yaml
rke up --config rke.yaml
#==================================================================
nodes:
  - address: 172.31.0.110
    user: rke
    role: [controlplane, worker, etcd]
  - address: 172.31.0.115
    user: rke
    role: [worker]
  - address: 172.31.0.82
    user: rke
    role: [worker]

services:
  etcd:
    snapshot: true
    creation: 6h
    retention: 24h

ingress:
  provider: nginx
  options:
    use-forwarded-headers: “true”
ded-headers: “true”
#可看到缺少kube-api的配置,所以应该在services下面添加该配置
  kube-api:
    service_node_port_range: 1-32767
#再执行rke up 进行配置
rke up --config rke.yaml

官网:[cluster.yml 文件示例](cluster.yml 文件示例 | Rancher文档)

配置之后如图:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BeSHTGWw-1652922662825)(E:\AppData\Roaming\Typora\typora-user-images\image-20220519085826506.png)]

二、kubeadm方式搭建的解决

解决方式也是修改kube-api的配置,不过它有独有的配置文件可以修改

1、找到kube-apiserver.yaml文件

#查看kube-apiserver.yaml的位置
find / -name kube-apiserver.yaml

#通过位置去编辑该文件
vim /etc/kubernetes/manifests/kube-apiserver.yaml

2、修改- kube-apiserver下面的–service-cluster-ip-range范围值

    spec:
      containers:
      - command:
        - kube-apiserver
        - --service-node-port-range=1-32767

3、重启kubelet

systemctl daemon-reload
systemctl restart kubelet
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值