当前位置: 首页 > 编程日记 > 正文

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. 安装java brew 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 运行环境配置

  1. zoo.cfg 配置
    zookeeper服务运行的时候需要加载zoo.cfg 文件,这个文件默认是没有的,但是zoo_sample.cfg 文件存储在下载好的源码目录中:zookeeper/conf
    可以cp zoo_sample.cfg zoo.cfg,可以直接用默认的配置即可(测试也只是本地运行,非集群模式)

  2. zookeeper 的编译运行配置
    zk的运行需要通过主类 org.apache.zookeeper.server.ZooKeeperServerMain 启动
    在这里插入图片描述
    编辑 run configuration
    在这里插入图片描述
    在这里插入图片描述

  3. 将主类信息,zoo.cfg绝对路径,你的zookeeper主目录添加进去
    如下:
    在这里插入图片描述

  4. 运行
    在这里插入图片描述
    点击运行,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 configuration command + option + r
    在这里插入图片描述
    添加路径:
    -Dlog4j.configuration=file:/Users/xxxxx/IdeaProjects/zookeeper/conf/log4j.propertiesVM options选项中即可
    在这里插入图片描述
    再次运行 即zk sever 已经正常启动,并输出日志:
    在这里插入图片描述

  5. 链接测试
    再用终端的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 /* 思路清晰&#xff1a; 1.状态 2.转移方程&#xff1a;哪些状态相互影响/记忆化搜索思想 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}} 测试函数&#xff1a; func Te…

如何用计算机求锐角三角比,9.3用计算器求锐角三角比教学案

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

详解设计模式在Spring中的应用

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

二级域名session 共享方案

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

idea中文乱码问题

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

Go 分布式学习利器(6)-- Map

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

Javascript 拖拽的一些高级的应用——逐行分析代码,让你轻松了解拖拽的原理...

我们看看之前的拖拽在周围有东西的时候会出现什么问题&#xff1f; 在高级浏览器中不会有啥问题&#xff0c;我们放到IE7下面测试一下&#xff0c;问题就出来了。如图 我们可以很清楚的看到&#xff0c;文字都已经被选中了。那这个用户体验很不好&#xff0c;用起来也不方便。顺…

计算机用英语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中的字符串类型与其他编译型语言的主要差异如下&#xff1a; string 是数据类型&#xff0c;不是指针或 引…

Python学习笔记十一:面向对象

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

计算机应用基础学期教学小结,《计算机应用基础》的教学总结及小结.docx

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

《极乐空间》特效制作与渲染

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

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语言的函数和其他语言 函数之间的差异&#xff0c;其中有一些已经在之前的总结中提到过。 函数在Go语言中是属于一等公民。 可以有多个返回值所有参数都是…

职称计算机证是继续教育的内容吗,豆腐网教你一分钟弄懂继续教育学时认定表及上传注意事项~...

原标题&#xff1a;豆腐网教你一分钟弄懂继续教育学时认定表及上传注意事项~大家好&#xff0c;我是豆腐网王老师&#xff0c;专注于南京工程师职称评审政策解读&#xff0c;关注我&#xff0c;让您轻松面对职称评审&#xff0c;少走弯路&#xff01;&#xff01;&#xff01;南…

vim中如何按一个键就保存文件

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

MVC项目下 Telerik Upload 的使用方法

1.右键项目然后选择管理NuGet程序包&#xff0c;点击联机 搜索 TelerikMvcExtensions 安装即可&#xff08;或者点击程序包管理控制器 输入 Install-Package TelerikMvcExtensions&#xff09; 2.安装成功后&#xff0c;在Content和Scripts 两个文件夹里面都会增加一个Telerik的…

分享下自己写的一个微信小程序请求远程数据加载到页面的代码

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

Go 分布式学习利器(9)-- Go语言 结构体的行为定义和实现

文章目录1. Go语言的结构体 -- 数据成员的封装2. Go &#xff08;函数成员&#xff09;行为的定义和实现1. Go语言的结构体 – 数据成员的封装 Go语言官方给的描述是 既是面向对象语言&#xff0c;也不算面向对象语言。 不是面向对象语言 是因为 Go语言并不支持继承操作&#…

Spring学习笔记_IOC

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

长治学院计算机在哪个校区,长治学院有几个校区及校区地址

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

as3垃圾回收机制

as3垃圾回收机制 垃圾回收机制详解 能力越大责任越大&#xff0c;这对actionscript3.0来说一点没错。引入这些新控件带来一个副作用&#xff1a;垃圾收集器不再支持自动为你收集 垃圾等假设。也就是说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语言的面向对象特性的时候也说了&#xff0c;Go语言并不支持继承&#xff0c;能够进行对象的封装&#xff08;包括数据成员和成员函数的封装&#xff09;&#xff0c;那么这里简单说一下Go语言接口之间的…

计算机输入输出有哪几种控制方式,计算机输入/输出的方式有哪几种?

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

LoadRunner中log的使用总结

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