zookeeper -- Mac 上 Intellij IDEA 配置 zookeeper(3.5.8) 源码阅读、运行、调试环境
近期需要整理MIT6.824 中 分布式系统协调服务 zookeeper 的一些知识,想要在Mac 本地搭建一个可以方便运行调试的zookeeper环境,这玩意竟然耗费了一上午的时间,实在是不可忍;当然,主要还是因为对Java的编译运行环境 以及 周边工具不太熟悉。
希望能够为后续想要学习的同学们节省更多的时间。
OS环境:MAC
zookeeper 版本:3.5.8 (更高版本 因为变更了编译配置,所以没有去搞)
java环境:15.0.1
文章目录
- 1. 编译前基本环境准备
- 2. 编译 及 导入 Intellij IDEA
- 3. Zookeeper 运行环境配置
1. 编译前基本环境准备
安装基本的java以及jdk
运行java --version
,显示如下:
表示java环境已经配置好了,不需要再进行java环境的配置。否则需要执行如下步骤:
a. 安装javabrew install java
b. 安装jdk环境,通过https://www.oracle.com/java/technologies/javase-jdk15-downloads.html 下载mac操作系统的最新版本jdk,直接按照正常的软件安装方式安装即可。安装软件,这里还是用强大通用的
intellij-idea
即可
brew cask intall intellij-idea
,可能需要搞一个破解的,这里就看大家各显神通了,淘宝、闲鱼啥的安装
maven
,用来安装java的包依赖
brew install mvnvm
最后运行mvn --version
,显示如下表示安装成功
通过mvn 安装
idea
的java依赖包
mvn -e idea:idea
或者 也可以通过 后面下载好的zookeeper代码中的pox.xml
导入到idea打开的zookeeper项目中
安装ant
https://ant.apache.org/bindownload.cgi 下载最新的tar包,将解压好的目录中的bin文件可以添加到环境变量中export PATH=$PATH:/xxx/bin/
。 大家都说这是一个巨古老的java编译方式,比较好奇zookeeper为什么还会一直用zookeeper 3.5.8 源码准备
git clone https://github.com/apache/zookeeper.git git checkout branch-3.5.8
2. 编译 及 导入 Intellij IDEA
编译 zookeeper代码
a.cd zookeeper
b.ant eclipse
导入Intellij IDEA
打开zookeeper目录即可
项目的依赖配置,这里主要是指定一下jdk版本即可
command + ;
打开项目配置
或者 File --> Project Structure
因为我们已经下载了最新版本的sdk,所以这里Add JDK之后会默认打开已经下载好的目录,直接Open即可配置zookeeper项目的依赖包
找到zookeeper目录下的pox.xml文件,右键点击 进行Reimport
3. Zookeeper 运行环境配置
zoo.cfg 配置
zookeeper服务运行的时候需要加载zoo.cfg 文件,这个文件默认是没有的,但是zoo_sample.cfg
文件存储在下载好的源码目录中:zookeeper/conf
可以cp zoo_sample.cfg zoo.cfg
,可以直接用默认的配置即可(测试也只是本地运行,非集群模式)zookeeper 的编译运行配置
zk的运行需要通过主类org.apache.zookeeper.server.ZooKeeperServerMain
启动
编辑 run configuration
将主类信息,zoo.cfg绝对路径,你的zookeeper主目录添加进去
如下:
运行
点击运行,Intellij IDEA会先编译,再运行zk server如果,编译过程中出现如下问题:
a.SLF4J: Class path contains multiple SLF4J bindings.
同时这个错误下应该还会有两个冲突路径,大体原因是再初始化日志模块时发现zk依赖了两个日志类,java认为是有冲突的,我的做法是将其中的一个直接注掉(mv xx xx-bak),因为我的两个冲突日志类是一样的,之前执行mvn -e idea:idea的时候有一部分类导入了两次。或者更好的解决办法是 从项目的依赖中将另一个类的路径 标记为exclude中的一项。
b.
log4j:WARN No appenders could be found for logger
这个问题同样是日志问题,是找不到log4j的初始化配置,即同样存在于目录zookeeper/conf/log4j.properties
文件。我的做法是直接将绝对路径设置到运行时的编译配置中。
回到 Exit configurationcommand + option + r
添加路径:
-Dlog4j.configuration=file:/Users/xxxxx/IdeaProjects/zookeeper/conf/log4j.properties
到VM options
选项中即可
再次运行 即zk sever 已经正常启动,并输出日志:
链接测试
再用终端的zkCli.sh
工具链接测试,能够与server通信,进入zk交互命令行成功cd /zookeeper/bin sh zkCli.sh ... 2020-11-15 13:31:40,529 [myid:] - INFO [main:ClientCnxn@1653] - zookeeper.request.timeout value is 0. feature enabled= Welcome to ZooKeeper! 2020-11-15 13:31:40,539 [myid:localhost:2181] - INFO [main-SendThread(localhost:2181):ClientCnxn$SendThread@1112] - Opening socket connection to server localhost/127.0.0.1:2181. Will not attempt to authenticate using SASL (unknown error) JLine support is enabled 2020-11-15 13:31:40,554 [myid:localhost:2181] - INFO [main-SendThread(localhost:2181):ClientCnxn$SendThread@959] - Socket connection established, initiating session, client: /127.0.0.1:58600, server: localhost/127.0.0.1:2181 2020-11-15 13:31:40,599 [myid:localhost:2181] - INFO [main-SendThread(localhost:2181):ClientCnxn$SendThread@1394] - Session establishment complete on server localhost/127.0.0.1:2181, sessionid = 0x10057c92b3d0000, negotiated timeout = 30000WATCHER::WatchedEvent state:SyncConnected type:None path:null [zk: localhost:2181(CONNECTED) 4] stat / cZxid = 0x0 ctime = Thu Jan 01 08:00:00 CST 1970 mZxid = 0x0 mtime = Thu Jan 01 08:00:00 CST 1970 pZxid = 0x0 cversion = -1 dataVersion = 0 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 0 numChildren = 1
相关文章:

南昌大学计算机专业高数课本,南昌大学高等数学期末考试.pdf
南昌大学2008学年第二学期高等数学期末考试试卷( 3 15 )一、 填空题 每空 分,共 分 a 3i j 2k, b i 2j k, (2a)(3b)1.设 则 _____.2 2 2 22. 函数 z ln[(25 x y )(x y 4)]的定义域是_______________________…

金智教育CTO:大数据人才培养要先行一步
金智教育CTO、北航云计算硕士项目主任陈滢博士认为,虽然在中国,互联网行业已经有了比较多的大数据实践,而且像金融、电信等行业也确实感受到了大数据给业务带来的压力,但是从整个大数据市场来看,还是“雷声大、雨点小”…

[NOIP2015]子串
Luogu2679 /* 思路清晰: 1.状态 2.转移方程:哪些状态相互影响/记忆化搜索思想 3.循环顺序 4.优化*/ #include<bits/stdc.h>using namespace std;typedef long long LL;const int mod1e97; const int MAXN1005; const int MAXM205;char a[MAXN],b[M…

Go 分布式学习利器(5)-- 数组和切片
文章目录1. 数组的声明2. 数组元素的遍历3. 数组的截取4. Go 语言的切片5. 数组 和 切片的共同点1. 数组的声明 声明并初始化为默认的零值 var a [3]int声明同时初始化为指定的值 b : [3]int{1,2,3}多维数组初始化 c : [2][2]int{{1,2},{3,4}} 测试函数: func Te…

如何用计算机求锐角三角比,9.3用计算器求锐角三角比教学案
侨润中学教学案八年级数学学科第 6 周第 4 节总29 课时主备人唐云玲授课人上课时间2012年3月22 日课题9.3用计算器求锐角三角比(1)课型教学目标1、学会用计算器求任意角的三角函数值。2、培养学生熟练地使用现代化辅助计算手段的能力3、培养学生运用现代化仪器的思想࿰…

详解设计模式在Spring中的应用
设计模式作为工作学习中的枕边书,却时常处于勤说不用的尴尬境地,也不是我们时常忘记,只是一直没有记忆。今天,螃蟹在IT学习者网站就设计模式的内在价值做一番探讨,并以spring为例进行讲解,只有领略了其设计…

二级域名session 共享方案
1.利用COOKIE存放session_id(); 实例:域名一文件php代码:<?php session_start(); setcookie("session_id",session_id(),time()3600*24*365*10,"/",".session.com");$_SESSION[user_name] 梁山良民; echo $_SESSION[…

idea中文乱码问题
需要统一编码,具体步骤如下所示: 最好在编辑页面右键设置file encoding也为utf-8编码方式 转载于:https://www.cnblogs.com/q-1993/p/10630496.html

Go 分布式学习利器(6)-- Map
文章目录1. Map的声明2. Map 元素访问带来的问题3. Map 元素的遍历4. 通过Map 实现 函数对象(C)5. 通过Map实现一个简单Set功能1. Map的声明 基本的几种声明和初始化方式如下: m : map[string]int{"one":1, "two":2, &…

Javascript 拖拽的一些高级的应用——逐行分析代码,让你轻松了解拖拽的原理...
我们看看之前的拖拽在周围有东西的时候会出现什么问题? 在高级浏览器中不会有啥问题,我们放到IE7下面测试一下,问题就出来了。如图 我们可以很清楚的看到,文字都已经被选中了。那这个用户体验很不好,用起来也不方便。顺…

计算机用英语bos,宏基电脑boss界面英文翻译,不知道的可以看看。
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼information(数据) cpu type(CPU类型)intel(R)Atom(TM)CPU Z2760 1.80GHzcpu speed(CPU的速度)1.80GHzsystem bios version(系统BIOS版本)V1.0cGOP Version(画面组版本)6.019.1018EMMC Model Name(EMMC模型名称)G23MESEMMC serial…

linux文件操作篇 (一)文件属性与权限
文件的属性和权限是linux中 目录 和 文件 的两个基本特性. #属性: 1. 所有者属性 2. 访问权限属性 -rwxrwxr-x #第一个字符是文件类别 -表示 普通文件 d 表示目录 b 表示块输入输出设备文件 c 表示连续输入输出设备 l 表示链接文件 …

Go 分布式学习利器(7)-- 字符串
文章目录1. 字符串 声明2. Unicode 和 utf-8的区别3. string中的字符遍历4. string的 字符分隔 和字符拼接函数5. string to Int和 Int to string函数1. 字符串 声明 Go中的字符串类型与其他编译型语言的主要差异如下: string 是数据类型,不是指针或 引…

Python学习笔记十一:面向对象
面向对象技术简介 类(Class): 用来描述具有相同的属性和方法的对象的集合。它定义了该集合中每个对象所共有的属性和方法。对象是类的实例。类变量:类变量在整个实例化的对象中是公用的。类变量定义在类中且在函数体之外。类变量通常不作为实例变量使用。数据成员&a…

计算机应用基础学期教学小结,《计算机应用基础》的教学总结及小结.docx
第第 PAGE 1 页 共 NUMPAGES 1 页《计算机应用基础》的教学总结及小结《计算机应用基础》的教学总结及小结 自参加工作以来,我一直严格要求自己,刻苦学习,努力工作,顺利地完成《计算机应用基础》课程的教育教学任务。在20xx-20xx学…

《极乐空间》特效制作与渲染
2019独角兽企业重金招聘Python工程师标准>>> 全景声版科幻动作片《极乐空间》由《第九区》导演尼尔布洛姆坎普掌镜。 影片耗资1.15亿美元,在北美上映时获得好评,赞誉集中体现在视觉特效方面。为了形象地描绘出两个差异巨大的世界,…

preparedStatement平台:
public class cs{ public static void main(String[] args){ try{ class.forName("com.mysql.jdbc.Driver");//注册驱动 Connection conn DriverManager.getConnection("jdbc:mysql:///cs","root","root");//获得链接 String sql&quo…

Go 分布式学习利器(8)-- Go的函数
文章目录1. Go语言的函数语法2. Go 函数中的可变长参数3. Go函数中的延迟函数 deffer1. Go语言的函数语法 先介绍一下Go语言的函数和其他语言 函数之间的差异,其中有一些已经在之前的总结中提到过。 函数在Go语言中是属于一等公民。 可以有多个返回值所有参数都是…

职称计算机证是继续教育的内容吗,豆腐网教你一分钟弄懂继续教育学时认定表及上传注意事项~...
原标题:豆腐网教你一分钟弄懂继续教育学时认定表及上传注意事项~大家好,我是豆腐网王老师,专注于南京工程师职称评审政策解读,关注我,让您轻松面对职称评审,少走弯路!!!南…

vim中如何按一个键就保存文件
可以用映射来做,把映射写在~/.vimrc里面,比如把map <F3> :w<CR>加入到~/.vim中之后,在每次编辑好后,按下F3就能保存下来。对于编译c程序,你可以加入这个映射:map <F6…

MVC项目下 Telerik Upload 的使用方法
1.右键项目然后选择管理NuGet程序包,点击联机 搜索 TelerikMvcExtensions 安装即可(或者点击程序包管理控制器 输入 Install-Package TelerikMvcExtensions) 2.安装成功后,在Content和Scripts 两个文件夹里面都会增加一个Telerik的…

分享下自己写的一个微信小程序请求远程数据加载到页面的代码
分享下自己写的一个微信小程序请求远程数据加载到页面的代码 1 思路整理 就是页面加载完毕的时候 请求远程接口,然后把数据赋值给页面的变量 ,然后列表循环 2 js相关代码 我是改的 onload函数 /*** 生命周期函数--监听页面加载*/onLoad: function (op…

Go 分布式学习利器(9)-- Go语言 结构体的行为定义和实现
文章目录1. Go语言的结构体 -- 数据成员的封装2. Go (函数成员)行为的定义和实现1. Go语言的结构体 – 数据成员的封装 Go语言官方给的描述是 既是面向对象语言,也不算面向对象语言。 不是面向对象语言 是因为 Go语言并不支持继承操作&#…

Spring学习笔记_IOC
Spring简介 1, 只用IOC spring.jar , jarkata-commons/commons-loggin.jar 2,IOC容器 实例化具体bean 动态装配 3,AOP支持 安全检查 管理transaction Spring配置 1,注入类型 setter(重要) 构造方法(可以忘记) 接口…

长治学院计算机在哪个校区,长治学院有几个校区及校区地址
最近有很多考生和家长咨询小编,长治学院有几个校区,今年新生会被分配到哪个校区?哪个校区好?等相关问题,下面小编统一回复一下考生们的问题。长治学院有2个校区,分别是南校区、北校区。长治学院校区及地址南校区:山西…

as3垃圾回收机制
as3垃圾回收机制 垃圾回收机制详解 能力越大责任越大,这对actionscript3.0来说一点没错。引入这些新控件带来一个副作用:垃圾收集器不再支持自动为你收集 垃圾等假设。也就是说Flash开发者转到actionscript3.0之后需要对关于垃圾收集如何工作以及如何编程…

opensuse安装nginx
opensuse安装nginx 安装步骤如下 1、sudo zypper install curl ca-certificates gpg2 2、sudo zypper addrepo --gpgcheck --type yum --refresh --check \ http://nginx.org/packages/sles/$releasever nginx-stable 3、sudo zypper addrepo --gpgcheck --type yum --refresh …

Go 分布式学习利器(10)-- Go语言的接口
文章目录1. 接口与依赖2. 自定义类型1. 接口与依赖 在上一节中我们讨论Go语言的面向对象特性的时候也说了,Go语言并不支持继承,能够进行对象的封装(包括数据成员和成员函数的封装),那么这里简单说一下Go语言接口之间的…

计算机输入输出有哪几种控制方式,计算机输入/输出的方式有哪几种?
计算机输入/输出的方式有:并行、串行这两种。1、并行并行是指一组程序按独立异步的速度执行,不等于时间上的重叠(同一个时刻发生)。并行也指8位数据同时通过并行线进行传送,这样数据传送速度大大提高,但并行传送的线路长度受到限制…

LoadRunner中log的使用总结
LoadRunner中log的使用总结 1、log的设置方式。在 runtime setting中可以设置log的生成方式:默认的log方式:Enable logging选中,log option是Send messages only when an error occurs.可以修改日志的方式:Always send messages&a…