Zookeeper Windows版的服务安装和管理工具

以前研究过负载均衡,最近正在项目上实施(从来没做过小项目以上级别的东西,哈)。然后遇到了多个一模一样但是同时运行的服务、不同服务但依赖同相同的配置数据(前端网页服务:Nginx+IIS+nodejs、后端接口:Ngnix+IIS、WebSocke:Service服务),这种算是分布式的配置同步、服务发现、定时任务、缓存数据一致性问题,用Zookeeper来解决挺好,不过Windows上使用有点为难,每次都要手动打开,而且打开都有一个黑不溜秋的控制台,重点是还不能关(虽然可以自己把call调用改成改成start)。

这种单个jar包启动的程序基本上都没有提供安装为服务的方式,Windows Service多好用啊,开机自动运行。因此有了此工具,地址:https://github.com/xiangyuecn/Zookeeper-Windows-Service-Manager

copy之前说点什么

本地环境已经进入懒人模式,没必要每次开机都去手动开启那些基础的软件。

其实像这种没有提供Service服务的软件,都应该可以用winsw包装成服务运行:不管你是命令行执行的还是一个可执行文件,参考最开始的Nginx源项目:https://github.com/xiangyuecn/Nginx-Windows-Service-Manager。

刚开始选择Zookeeper的理由是配置同步、服务发现、分布式锁,这种功能是后端多个相同服务协同运行的基础,就尝试的研究了一番。

后来发现其实Redis也能实现目前需要的这几个简单功能,天然的配置同步(订阅发布)、服务发现(订阅发布+KeyValue)、分布式锁(KeyValue)。本来Redis就是系统里面必备的,一个软件能解决更多问题都省了不少内存(电脑内存小的可怜,各种抠,囧)。

然后xxx,各种写代码,各种看数据,然后搞出了这个什么玩意(Dangerous:臣·独秀来了):

基于Redis的简单集群管理

Redis中的注册的服务

服务发现核心代码

基于Redis的简单集群管理:查看服务列表,服务状态查询,手动执行命令(所有服务器)。
然后系统原有的只能单机跑的功能微调几行代码就有了分布式特性。

Redis简单轻巧值得拥有,但Zookeeper也不能放弃,下面还是重点介绍Zookeeper Windows版的服务安装和管理工具。

以下内容copy自README

本工具用于Zookeeper Windows版的服务安装和管理

xiangyuecn编写,学习zookeeper之用,还没弄懂怎么配置zookeeper,先把安装问题先解决了,不然服务器一注销zookeeper也自动关掉了,首次使用于2018-07-21。

此项目基于Ngnix Windows版的服务安装和管理,更详细的介绍可以参考Nginx的这个项目。

使用方法

  1. 把bin目录内的4个文件复制到zookeeper根目录下(和zookeeper-x.x.jar同一目录,参考图1),config.txt为可选的配置模板文件。

  2. 运行start.bat进行安装/卸载Windows服务、管理服务运行/停止/重启、更新配置、重新加载配置。

关于bin目录4个文件说明

start.bat

主脚本,对zookeeper服务管理每次都运行这个脚本即可完成轻松管理;如果需要调整服务名称和配置文件名称,更改此文件即可,下面有专门介绍。

tp.vbs

配置模板文件格式处理、日期替换更新脚本

winsw1.9.exe

windows服务安装器,用于把zookeeper安装为系统服务,下载地址:http://central.maven.org/maven2/com/sun/winsw/winsw/1.9/ ,配置介绍:https://github.com/kohsuke/winsw/blob/master/doc/xmlConfigFile.md

config.txt

配置模板文件,支持任意格式重复内容只需定义一次,任何地方引用替换,大大简化重复配置的编写(起源于Ngnix配置);此文件不提供不影响使用。

关于start.bat

文件内配置部分可以调整:

  1. 对于config.txt模板文件并非一定要放到根目录,可以放到其他地方,通过修改configTxt定义,指向配置模板文件。
  2. 配置文件名称通过confPath指定,默认为conf/zoo.cfg,如果需要改成别的文件名,修改即可。
  3. 服务名称通过svs修改,默认为Zookeeper;服务安装后默认为本地系统账户,如需更改请到服务管理里面更改账户

服务安装运行后,winsw会产生3个log文件(参考图1),可以删除,winsw1.9.xml文件不可删除,否则无法卸载和启动。

关于config.txt

此文件内容可以和Zookeeper配置文件内容完全一致,也可以使用扩充语法,省去那些不适合手动编辑的场景。

暂时没有使用场景,本功能基于Nginx项目,详细语法可以参考https://github.com/xiangyuecn/Nginx-Windows-Service-Manager。

{y}、{m}、{d}、{h}、{M}、{s}

当前时间日期变量

内容支持宏定义和替换

定义:DEF(标识) 宏名称=宏内容 (标识)END,宏名称支持&、<、>、/、_、-、空格、换行、字母、数字、文字组合,宏内容可以多行。
使用:在需要替换的地方写上宏名称即可。

图例

文件组成:

图1

安装服务:

图2

服务管理:

图3

已安装服务:

图4

java进程:

图5

### 回答1: ZookeeperWindows安装步骤如下: 1. 下载ZookeeperWindows安装包,可以从官网或者其他可靠的下载站点下载。 2. 解压安装包到指定的目录,例如C:\zookeeper。 3. 在解压目录下创建一个data目录,用于存储Zookeeper的数据。 4. 复制conf目录下的zoo_sample.cfg文件并重命名为zoo.cfg,用于配置Zookeeper的参数。 5. 修改zoo.cfg文件中的dataDir参数,将其指向之前创建的data目录。 6. 启动Zookeeper服务,可以通过命令行或者图形界面启动。命令行启动方式为进入bin目录,执行命令zkServer.cmd。 7. 验证Zookeeper服务是否正常运行,可以通过telnet命令连接到Zookeeper的默认端口2181,如果连接成功则说明服务正常运行。 8. 安装完成后,可以通过Zookeeper提供的客户端API或者命令行工具进行操作和管理。 ### 回答2: Zookeeper是一个开源的分布式应用程序协调服务,可以帮助管理和协调分布式任务和服务。以下是在Windows安装Zookeeper的步骤: 1. 首先,您需要下载ZookeeperWindows本。您可以在官方网站(https://zookeeper.apache.org/releases.html)上找到最新本的Zookeeper安装包。请选择与您的操作系统相匹配的二进制压缩文件。 2. 下载完成后,将压缩文件解压到您选择的目录中。解压后的文件夹包含有关Zookeeper的标准目录结构。 3. 在Zookeeper的根目录中,找到conf文件夹。在该文件夹中创建一个新的文本文件,并将其命名为zoo.cfg。 4. 用文本编辑器打开zoo.cfg文件,并添加以下内容: tickTime=2000 dataDir=/path/to/zookeeper/data clientPort=2181 其中,tickTime表示Zookeeper使用的基本时间单元,单位是毫秒。dataDir表示Zookeeper存储数据的目录。clientPort是Zookeeper客户端连接的端口号。 5. 保存并关闭zoo.cfg文件。 6. 打开命令提示符(cmd)并导航到Zookeeper的bin目录。在命令提示符中运行以下命令启动Zookeeper服务器: zookeeper-server-start.bat ../conf/zoo.cfg 7. 稍等片刻,如果一切正常,您将在命令行窗口中看到一系列日志信息,表示Zookeeper服务器已成功启动。 现在,您已经成功在Windows安装Zookeeper。您可以使用Zookeeper的客户端连接到服务器,并开始管理和协调分布式任务和服务
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值