• zookeeper调试命令


    转载自 https://www.cnblogs.com/andy6/p/7674028.html

    一、zkServer.sh

    1、查看 zkServer.sh 帮助信息
    [root@bigdata05 bin]# ./zkServer.sh help
    ZooKeeper JMX enabled by default
    Using config: /bigdata/zookeeper-3.4.10/bin/../conf/zoo.cfg
    Usage: ./zkServer.sh {start|start-foreground|stop|restart|status|upgrade|print-cmd}

    2、 启动/关闭 zk服务器
    [root@bigdata05 bin]# ./zkServer.sh start
    [root@bigdata05 bin]# ./zkServer.sh stop

    3、查看服务器状态
    [root@bigdata05 bin]# ./zkServer.sh status
    ZooKeeper JMX enabled by default
    Using config: /bigdata/zookeeper-3.4.10/bin/../conf/zoo.cfg
    Mode: follower


    二、zkCli.sh

    1、查看 zkCli.sh 帮助信息
    [zk: localhost:2181(CONNECTED) 0] help
    ZooKeeper -server host:port cmd args
    stat path [watch]
    set path data [version]
    ls path [watch]
    delquota [-n|-b] path
    ls2 path [watch]
    setAcl path acl
    setquota -n|-b val path
    history 
    redo cmdno
    printwatches on|off
    delete path [version]
    sync path
    listquota path
    rmr path
    get path [watch]
    create [-s] [-e] path data acl
    addauth scheme auth
    quit 
    getAcl path
    close 
    connect host:port


    常用命令

    0)连接zookeeper
    [root@bigdata05 bin]# ./zkCli.sh -server localhost:2181

    1)查看当前节点列表
    [zk: localhost:2181(CONNECTED) 1] ls /
    [zookeeper, yarn-leader-election, hadoop-ha]

    2)创建节点
    [zk: localhost:2181(CONNECTED) 1] ls /
    [zookeeper, yarn-leader-election, hadoop-ha]
    [zk: localhost:2181(CONNECTED) 2] create /test "test"
    Created /test
    [zk: localhost:2181(CONNECTED) 3] ls /
    [zookeeper, test, yarn-leader-election, hadoop-ha]
    [zk: localhost:2181(CONNECTED) 4] create /test/test "test"
    Created /test/test
    [zk: localhost:2181(CONNECTED) 5] ls /
    [zookeeper, test, yarn-leader-election, hadoop-ha]
    [zk: localhost:2181(CONNECTED) 6] ls /test
    [test]

    3)查看节点数据
    [zk: localhost:2181(CONNECTED) 7] get /test
    test
    cZxid = 0x400000031
    ctime = Mon Oct 16 04:05:02 CST 2017
    mZxid = 0x400000031
    mtime = Mon Oct 16 04:05:02 CST 2017
    pZxid = 0x400000032
    cversion = 1
    dataVersion = 0
    aclVersion = 0
    ephemeralOwner = 0x0
    dataLength = 4
    numChildren = 1

    4)设置节点数据
    [zk: localhost:2181(CONNECTED) 8] set /test "666666"
    cZxid = 0x400000031
    ctime = Mon Oct 16 04:05:02 CST 2017
    mZxid = 0x400000033
    mtime = Mon Oct 16 04:08:44 CST 2017
    pZxid = 0x400000032
    cversion = 1
    dataVersion = 1
    aclVersion = 0
    ephemeralOwner = 0x0
    dataLength = 6
    numChildren = 1
    [zk: localhost:2181(CONNECTED) 10] get /test
    666666
    cZxid = 0x400000031
    ctime = Mon Oct 16 04:05:02 CST 2017
    mZxid = 0x400000033
    mtime = Mon Oct 16 04:08:44 CST 2017
    pZxid = 0x400000032
    cversion = 1
    dataVersion = 1
    aclVersion = 0
    ephemeralOwner = 0x0
    dataLength = 6
    numChildren = 1

    5)删除节点
    [zk: localhost:2181(CONNECTED) 11] delete /test
    Node not empty: /test
    [zk: localhost:2181(CONNECTED) 12] ls /
    [zookeeper, test, yarn-leader-election, hadoop-ha]
    [zk: localhost:2181(CONNECTED) 13] delete /test/test
    [zk: localhost:2181(CONNECTED) 14] ls /test
    []
    [zk: localhost:2181(CONNECTED) 15] delete /test
    [zk: localhost:2181(CONNECTED) 16] ls /
    [zookeeper, yarn-leader-election, hadoop-ha]

    三、 ZooKeeper服务器端四字命令

    ZooKeeper 支持某些特定的四字命令(The Four Letter Words)与其进行交互。它们大多是查询命令,用来获取 ZooKeeper 服务的当前状态及相关信息。用户在客户端可以通过 telnet 或 nc 向 ZooKeeper 提交相应的命令。 ZooKeeper 常用四字命令主要如下:

    ZooKeeper四字命令
    功能描述
    conf 3.3.0版本引入的。打印出服务相关配置的详细信息。
    cons 3.3.0版本引入的。列出所有连接到这台服务器的客户端全部连接/会话详细信息。包括"接受/发送"的包数量、会话id、操作延迟、最后的操作执行等等信息。
    crst 3.3.0版本引入的。重置所有连接的连接和会话统计信息。
    dump 列出那些比较重要的会话和临时节点。这个命令只能在leader节点上有用。
    envi 打印出服务环境的详细信息。
    reqs 列出未经处理的请求
    ruok 测试服务是否处于正确状态。如果确实如此,那么服务返回"imok",否则不做任何相应。
    stat 输出关于性能和连接的客户端的列表。
    srst 重置服务器的统计。
    srvr 3.3.0版本引入的。列出连接服务器的详细信息
    wchs 3.3.0版本引入的。列出服务器watch的详细信息。
    wchc 3.3.0版本引入的。通过session列出服务器watch的详细信息,它的输出是一个与watch相关的会话的列表。
    wchp 3.3.0版本引入的。通过路径列出服务器watch的详细信息。它输出一个与session相关的路径。
    mntr 3.4.0版本引入的。输出可用于检测集群健康状态的变量列表

    conf conf 命令是在 3.3.0 版本中引入的, 它会打印输出服务器配置的详细信息。以便运维人员能够很快速的查看 ZooKeeper 服务器当前运行时的一些配置参数。

    telnet示例

    conf_telnet

    可以看到有些配置项我们没有在 zoo.cfg 配置文件中配置, 服务器使用了默认配置。

    nc示例

    conf_nc

    运行模式

    conf 命令会根据当前的运行模式来决定打印输出的服务器配置信息, 上面的两个示例是集群模式下的示例, 如果是单机模式(standalone), 则不会输出 initLimit、syncLimit、electionAlg 以及 electionPort 等集群配置信息。

    standalone


    cons cons 命令是 3.3.0 版本中引入的, 它用于输出所有连接到该服务器的客户端的完整连接和会话信息, 包括接收和发送包的数量、会话ID、操作延迟以及最后执行的操作等信息。

    cons

    可以看到本机上有一个客户端连接。


    crst crst 命令是在 3.3.0 版本中引入的, 用于重置所有客户端连接的连接和会话统计信息。

    crst


    dump dump 命令用于输出未完成的会话和临时节点。

     leader示例

     dump_leader

      follower示例

     dump_follower


    envi envi 命令用于打印输出服务器运行时的环境变量信息。

    envi


    ruok ruok 命令用于测试当前服务器是否正在运行。如果服务器正在运行则返回 "imok", 否则没有任何响应。

    ruok

    需要注意的是, "imok" 响应不一定能够表明服务器已经加入到集群中, 仅仅说明服务器进程处于活动状态并且已经绑定到指定的客户端端口。 可以使用 "stat" 获取集群状态以及客户端连接信息。


    srst srst 命令用于重置服务器统计信息。

    srst


    srvr srvr 命令是在 3.3.0 版本中引入的, 它用于输出服务器的完整信息。

    srvr


    stat stat 命令用于输出服务器以及连接到该服务器的客户端的概要信息。

    stat

    srvr 命令和 stat 命令的唯一区别是 srvr 不会输出客户端的概要信息。


    wchs wchs 命令是在 3.3.0 版本中引入的, 用于输出当前服务器上 Watcher 的概要信息。

    wchs


    wchc wchc 命令是在 3.3.0 版本中引入的, 用于按会话输出当前服务器上 watches 的详细信息。它会输出会话(连接)以及相关的 watches (路径) 列表。

    wchc

    因为暂时没有 watches, 所以没有任何输出。

    注意, 取决于 watches 的数量, 这个操作可能会非常耗时 (影响服务器性能), 所以需要谨慎使用。


    wchp wchp 命令是在 3.3.0 版本中引入的, 用于按路径输出当前服务器上 watches 的详细信息。它会输出路径 (znodes) 以及相关会话列表。

    wchp

    同样的, 因为暂时没有 watches, 所以没有任何输出。

    注意, 取决于 watches 的数量, 这个操作可能会非常耗时 (影响服务器性能), 所以需要谨慎使用。


    mntr mntr 命令是在 3.4.0 版本中引入的, 用于输出可用于监控集群健康的变量列表。

    leader示例

     mntr_leader 

    follower示例

     mntr_follower 

    示例说明 从上面两个示例可以看到, zk_followers, zk_synced_followers 和 zk_pending_syncs 只有在 leader 服务器上运行 mntr 命令时才会输出。还需要注意的是, zk_open_file_descriptor_count 和 zk_max_file_descriptor_count 这两个变量只有在 Unix 平台上才可用。

  • 相关阅读:
    Rhino 是一个完全使用Java语言编写的开源JavaScript实现。Rhino通常用于在Java程序中,为最终用户提供脚本化能力。它被作为J2SE 6上的默认Java脚本化引擎。
    VS的快捷键F12改成和ECLIPSE一样用ctrl+点击下载线
    到底要不要拆分函数
    “DllRegisterServer的调用失败”问题解决办法(转)
    select into的缺点
    win8 下脚本安装IIS
    快速打开IIS的方法
    windows下硬盘的逻辑结构
    sql server 2005/2008R2 报“红叉”错,即“不允许所请求的注册表访问权”的错误
    rundll32.exe的相关使用语句
  • 原文地址:https://www.cnblogs.com/zooqkl/p/10600002.html
Copyright © 2020-2023  润新知