当前位置: 首页 > news >正文

Zookeeper 集群搭建过程中常见错误

文章目录

    • Mode: standalone
    • 启动失败

Mode: standalone

这通常表示 Zookeeper 配置为单节点模式,而不是集群模式。需要检查 zoo.cfg 文件中的配置,确保包含了所有集群节点的信息。

启动失败

/usr/bin/java
ZooKeeper JMX enabled by default
Using config: /opt/zookeeper-3.5.7/bin/../conf/zoo.cfg
Starting zookeeper ... FAILED TO START
/usr/bin/java
ZooKeeper JMX enabled by default
Using config: /opt/zookeeper-3.5.7/bin/../conf/zoo.cfg
Client port found: 2181. Client address: localhost.
Error contacting service. It is probably not running.

首先查看 $ZOOKEEPER_HOME/logs 目录下的 .out 后缀文件中报错内容(在 hadoop 系统中,.log 结尾的日志文件通常用于记录应用程序的日志信息,而 .out 结尾的文件则用于存储标准输出和标准错误信息),出现其他的报错问题都可以去 .out 后缀文件里查看报错信息,根据报错信息能更容易找到问题所在,更方便解决问题。

常见的错误如下:

  • 数据目录和日志目录:写绝对路径,不要写相对路径,也不要直接写 $ZOOKEEPER_HOME/tmp/data,示例

    dataDir=/opt/zookeeper-3.5.7/tmp/data
    
  • 服务器地址问题,如果这里写的 B 写的是用户名,检查 /etc/hosts 是否配置 IP 映射

    server.A=B:C:D
    
  • myid 不匹配: 在每个 Zookeeper 节点的数据目录下的 myid 文件,其中包含一个数字,表示该节点在集群中的唯一标识。如果这个数字与 zoo.cfg 中上述配置 A 不匹配,可能会导致集群故障。

  • 权限问题: 操作系统权限不足可能导致 Zookeeper 无法启动或运行。需要确保 Zookeeper 安装目录具有适当的读写执行 rwx 权限。

  • 进程冲突: 如果在启动 Zookeeper 时出现错误信息

    already running as process XXX 
    

    表示同一台机器上已经有一个 Zookeeper 进程在运行。可能需要停止现有的进程,或者检查是否有残留的进程占用端口,可以通过查看端口占用情况,如使用 netstat -apn | grep 2181 命令,解决端口冲突问题。

  • 防火墙未关闭:防火墙可能会阻止 Zookeeper 集群之间的通信。需要确保防火墙已关闭,或者将 Zookeeper 集群的端口添加到防火墙白名单中。

    例如,如果你使用的是firewalld,关闭防火墙示例代码

    systemctl stop firewalld.service # 停止firewall
    systemctl disable firewalld.service # 禁止firewall开机启动
    

    修改完防火墙配置文件后你需要保存修改并重启防火墙服务,以使更改生效。可以使用以下命令重启防火墙。具体的命令也取决于你使用的防火墙软件

    systemctl restart firewalld
    

    如果你使用的是 iptables 添加白名单示例代码

    iptables -A INPUT -p tcp --dport 2181 -j ACCEPT
    
  • Java 环境问题Java 环境未正确配置或使用的 Java 版本与 Zookeeper 不兼容。

解决这些问题通常需要仔细检查配置文件、日志文件和操作系统设置,并根据具体错误信息进行相应的调整。

http://www.lryc.cn/news/264250.html

相关文章:

  • Linux开发工具——vim篇
  • 基于YOLOv5的吸烟检测系统设计与实现
  • 递归算法:二叉树前序、中序、后序遍历解析与递归思想深度剖析
  • WebGL开发数字孪生项目
  • 【51单片机系列】C51中的中断系统扩展实验
  • Poi实现复杂Excel导出,理解POI操作Excel思路!!!
  • 关于 jsconfig.json 文件在导入文件路径提示方面
  • 验证码:防范官网恶意爬虫攻击,保障用户隐私安全
  • python学习笔记--异常捕获
  • ChatGPT如何计算token数?
  • 页面菜单,通过get请求一个url后,跳转另外一个页面,+丢失问题
  • 高并发场景下的延时双删
  • log4js-node在nodejs项目中的使用示例
  • Java_集合进阶(Collection和List系列)
  • QT GUI代码大全(MainWindow, QFile, QPainter, QGraphicsItem/Scene/View)
  • C# Onnx Yolov8 Detect 物体检测 多张图片同时推理
  • 学习使用js保留两位小数同时去掉小数末尾多余的00
  • linux驱动的学习 驱动开发初识
  • Node.js中npm中ws的WebSocket协议的实现
  • PHP HTTPoxy CGI 应用程序漏洞 CVE-2016-5385
  • qt-C++笔记之使用QLabel和QPushButton实现一个bool状态的指示灯
  • 自动驾驶技术入门平台分享:百度Apollo开放平台9.0全方位升级
  • Elementor Pro v3.18.1和(完整模板套件)介绍说明
  • Windows如何安装使用TortoiseSVN客户端并实现公网访问本地SVN Server
  • Mybatis配置-映射器(mappers)
  • python 音视频合并
  • HttpUtils——助力高效网络通信
  • WAF绕过常见方法
  • SpringCloud微服务 【实用篇】| Docker镜像、容器、数据卷操作
  • OSPF面试总结