写点什么

Rancher 2.0 部署过程中常见问题分析与解决

  • 2020-04-15
  • 本文字数:2473 字

    阅读完需:约 8 分钟

Rancher 2.0部署过程中常见问题分析与解决

本文是 Rancher 2.0 部署与使用过程中常见的问题及其解决方法,多数问题整理收集自 Rancher 官方技术交流群内用户的提问与反馈。欢迎扫描文末二维码,添加 Rancher 小助手为好友,加群获得更多技术支持。

本文主要内容为 :

1、部署 Rancher 2.0 的环境需求


  • 推荐使用的操作系统

  • 推荐的硬件配置

  • 支持的 docker 版本

  • 防火墙需要允许通过的端口


2、部署过程中的常见问题及排查思路


  • 环境信息残留

  • openssh 版本过低问题

  • nodeport 端口只有一台机器能访问

  • 部署使用 calico 网络部署环境失败问题

  • 部署时主机 not found 问题

  • web 页面 kubectl 闪退问题

  • 非 worker 节点仍然被调度 pod 问题

  • it is a not share mount 问题

  • networkredy=false 问题

  • 集群 unavailable

环境需求

推荐使用的操作系统

  • Ubuntu 16.04 (64-bit)

  • Red Hat Enterprise Linux 7.5 (64-bit)

  • RancherOS 1.3.0 (64-bit)

推荐的硬件配置

支持的 docker 版本

  • 1.12.6

  • 1.13.1

  • 17.03.02

防火墙请允许通过已下端口

ProtocolPort rangePurpose
tcp22ssh server
tcp80Rancher Server/ingress
tcp443Rancher Server/ingress
tcp6443kubernetes api server
tcp2379-2380etcd server client api
tcp10250-10256kubernetes components
tcp30000-32767nodeport services
udp8472canal

常见问题与排查思路

环境信息残留

目前部署中,大部分问题都是因为由于部署环境的操作系统,或多次部署,升级后残留的的信息造成的。


部署前或部署时,请使用以下命令将环境的各类信息清理干净:


df -h|grep kubelet |awk -F % '{print $2}'|xargs umount rm /var/lib/kubelet/* -rfrm /etc/kubernetes/* -rfrm /var/lib/rancher/* -rfrm /var/lib/etcd/* -rfrm /var/lib/cni/* -rfiptables -F && iptables -t nat –Fip link del flannel.1docker ps -a|awk '{print $1}'|xargs docker rm -fdocker volume ls|awk '{print $2}'|xargs docker volume rm
复制代码

openssh 版本过低问题

centos 或 rhel 系统并且版本低于 7.4 的,因为默认的 openssh 和 openssl 和红帽系 ssh 默认将 AllowTcpForwarding 关闭了,rke 部署时会出现如下问题:



参考 issue:


https://github.com/rancher/rke/issues/93


需要您进行以下操作:


  1. 确保您的 openssh 版本大于等于 7.x

  2. 修改 sshd 配置打开重启 sshd

  3. 默认 centos 和 rhel 不能使用 root 用户进行 ssh tunnel,所以需要使用一个普通用户

  4. 并将这个用户加入 docker 这个 Group,useradd –G docker yourusername

nodeport 端口只有一台机器能访问

只能访问一台宿主机的 nodeport,并且还是 pod 所在那台机器,出现这种问题很大原因是因为跨集群网络有问题,或本地防火墙问题。排查思路如下:


1、在宿主机本机telnet localhost:nodeort看看是否能通,本机能通,在集群内互相 telnet 测试,如果不能通根部署环境网络有很大关系,建议联系网络管理员进行排查。


如果本机 telnet 也不能通,进行如下测试。


2、首先我们需要或取对应的 pod 信息



比如我这个test-6b4cdf4ccb-7pzt6在rancher-kf-worker01节点上,它的 ip 为 10.42.3.23


3、先在 pod 所在的宿主机上然后在另外几个节点去 ping 这个 ip,看看能否 ping 通,在 canal 网络模式下,请检查防火墙端口 8472/UDP 是否开放。查看每天机器上是否有尝试使用每台机器的 flannel.1 网卡,用的话,用 flannel.1 上的 ip 互相 ping,看看是否能通,因为 flannel 网络和 canal 网络是通过 flannel.1 网卡互相建立 vxlan 遂道的。建议操作在关闭防火墙的情况下测试。

部署使用 calico 网络部署环境失败问题

部署 rancher2.0 时网络类型为 calico 时,如果 cloud provider 默认不填会选用公有云的,导致部署失败,所以这里我们需要手动填写为 none。(后期会优化此项)


部署时主机 not found 问题

出现这个问题是因为宿主机的主机名不符合 kubernetes 的标准主机名要求也不符合标准的 linux 主机名,主机名内不能有下划线。


获取组件健康状态 forbidden 问题


大部分原因是因为部署多次,证书残留的导致的,解决办法,按照环境信息残留里面的方法把环境清空下,在重新添加。

web 页面 kubectl 闪退问题

这个主要根操作系统版本和浏览器的版本有关系,请使用上推荐使用操作系统中的操作系统,浏览器使用 Chrome

非 worker 节点仍然被调度 pod 问题

目前 rancher2.0 非 worker 节点,仍然会被调度 pod 过去,您可以选择手动将它们从 kube-scheduler 踢除,命令如下:


在获取节点在 kubernetes 集群的名字


打开 web 页面 kubectl



然后执行


kubectl taint node rancher-kf-control01 node-role.kubernetes.io/rancher-kf-control01="":NoSchedulekubectl taint node rancher-kf-control02 node-role.kubernetes.io/rancher-kf-control02="":NoSchedulekubectl taint node rancher-kf-control03 node-role.kubernetes.io/rancher-kf-control03="":NoSchedule
复制代码

it is a not share mount 问题

部署时遇到 share mount 问题时,报错提示如下:


FATA[0180] [workerPlane] Failed to bring up Worker Plane: Failed to start [kubelet] container on host [192.168.10.51]: Error response from daemon: linux mounts: Path /var/lib/kubelet is mounted on / but it is not a shared mount.
复制代码


这个问题原因主要是 kubelet 容器化部署,需要手动设置 docker 的 MuntFLAGS 为空


https://github.com/kubernetes/kubernetes/issues/4869#issuecomment-195696990


解决方法:


执行


mount --make-shared /


或配置docker.server


MountFlags=shared


重启docker.service

NetworkRedy=false 问题


这个问题通常是,在部署时网络组件在初始化,在配置,等待段时间就好了。或在对应节点查看 kubelet 日志的 docker logs kubelet。

集群 unavailable


通常此问题,是因为 rancher-server 根 kubernetes 中的 kube-apiserver 6443 端口连接有问题,建议检查防火墙和查看 kube-api-server 的日志。

总结 **

1、部署时能严格按照官方给出的操作系统版本和 docker 版本部署,可以避免掉很多问题。


2、多次部署,升级,环境一定要按照环境信息残留章节的命令,将环境清理干净。


3、如果遇到问题,建议 docker logs 查看 rancher-agent,rancher-server 的日志。


2020-04-15 23:042198

评论

发布
暂无评论
发现更多内容

黑龙江二级等保与三级等保核心差异解析

等保测评

亚马逊ICML 2023论文技术速览

qife122

机器学习

研究机构科研管控系统(源码+文档+讲解+演示)

深圳亥时科技

亚马逊商品详情API响应数据解析

tbapi

亚马逊API 亚马逊商品详情接口 亚马逊数据采集

Lombok @Builder失效问题排查与解决方案

qife122

Java maven

大数据-54 Kafka 安装配置 从 ZooKeeper 到 KRaft 的演进之路

武子康

Java 大数据 kafka 分布式 消息队列

蔚来汽车携手通义灵码入选 2025 世界人工智能大会标杆案例

阿里云云效

人工智能 阿里云 云原生 通义灵码

语音解耦技术推动语音AI的多样性与包容性

qife122

语音ai 语音解耦

利用数据绑定让动画更智能:在Rive中创建动态黄金计算器

qife122

rive 动画设计

世界人工智能大会,我们带来两个好消息!

百度Geek说

Web3 项目外包开发团队

北京木奇移动技术有限公司

区块链开发 软件外包公司 web3开发

"端云+多模态"新范式:《移远通信AI大模型技术方案白皮书》正式发布

财见

2023年八大最佳Codecademy替代平台

qife122

编程学习 技术课程

Amazon Bedrock Runtime API 集成指南——从 Invoke Model API 迁移到 Converse API,简化生成式 AI 应用开发

亚马逊云科技 (Amazon Web Services)

蔚来汽车携手通义灵码入选 2025 世界人工智能大会标杆案例

阿里巴巴云原生

人工智能 阿里云 云原生 通义灵码

黑龙江等保合规体系构建与政策依据

等保测评

PPIO亮相WAIC 2025,重磅推出国内首个Agentic AI基础设施服务平台

Lily

梦精灵AI产品动态 | 提示词工具新功能预览

龙正哲

黑龙江等保测评流程优化与效率提升

等保测评

基于YOLOv8的狗狗品种(多达60种常见犬类)品种鉴别识别项目|完整源码数据集+PyQt5界面+完整训练流程+开箱即用!

申公豹

人工智能

虚拟制作离不开高刷新率LED背景墙

Dylan

LED LED display LED显示屏 背景音乐 LED屏幕

15K的Go开发岗,坐标北京

王中阳Go

Go 面试

重塑应用搜索体验,系统级入口功能一步直达

HarmonyOS SDK

HarmonyOS NEXT HarmonyOS SDK应用服务

高压电线电力巡检六类图像识别数据集(2000张图片已划分、已标注)

申公豹

人工智能 数据集

让“创意即成片”成为现实!北电数智星火·长缨AIGC平台首秀WAIC

Lily

Astro机器人流畅运动背后的科技原理

qife122

机器人 轨迹优化

Gartner 2025报告出炉!KaiwuDB 连续三年入选中国数据库代表厂商

KaiwuDB

CST软件的非线性光学 --- 光3dB定向耦合器,Chi3材料,DC开关控制耦合

思茂信息

电磁仿真 非线性仿真 CST Studio Suite

速卖通商品列表API响应数据解析

tbapi

速卖通API 速卖通数据采集 速卖通数据接口

数据开发再提速!DataWorks正式接入Qwen3-Coder

阿里云大数据AI技术

人工智能 大数据 数据处理 Dataworks Qwen3-Coder

亚马逊Q Developer:用自然语言构建机器学习模型

qife122

机器学习 Amazon SageMaker

Rancher 2.0部署过程中常见问题分析与解决_文化 & 方法_Rancher_InfoQ精选文章