# 第三阶段-模块二 **Repository Path**: bggl1/stage-3---module-2 ## Basic Information - **Project Name**: 第三阶段-模块二 - **Description**: No description available - **Primary Language**: Unknown - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-12-03 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # 第三阶段 模块二 ### 编程题一: 在基于Netty的自定义RPC的案例基础上,进行改造。基于Zookeeper实现简易版服务的注册与发现机制 要求完成改造版本: 1. 启动2个服务端,可以将IP及端口信息自动注册到Zookeeper 2. 客户端启动时,从Zookeeper中获取所有服务提供端节点信息,客户端与每一个服务端都建立连接 3. 某个服务端下线后,Zookeeper注册列表会自动剔除下线的服务端节点,客户端与下线的服务端断开连接 4. 服务端重新上线,客户端能感知到,并且与重新上线的服务端重新建立连接 编程题二: 基于作业一的基础上,实现基于Zookeeper的简易版负载均衡策略 要求完成改造版本: 1. Zookeeper记录每个服务端的最后一次响应时间,有效时间为5秒,5s内如果该服务端没有新的请求,响应时间清零或失效。(提示见图) 2. 当客户端发起调用,每次都选择最后一次响应时间短的服务端进行服务调用,如果时间一致,随机选取一个服务端进行调用,从而实现负载均衡 编程题三: 基于Zookeeper实现简易版配置中心 要求实现以下功能: 1. 创建一个Web项目,将数据库连接信息交给Zookeeper配置中心管理,即:当项目Web项目启动时,从Zookeeper进行MySQL配置参数的拉取 2. 要求项目通过数据库连接池访问MySQL(连接池可以自由选择熟悉的) 3. 当Zookeeper配置信息变化后Web项目自动感知,正确释放之前连接池,创建新的连接池 ------------------------------------------------------------------------- 作业资料说明: 1、提供资料:3个代码工程、验证及讲解视频。(仓库中只有本次作业内容) 2、讲解内容包含:题目分析、实现思路、代码讲解。 3、效果视频验证: 3.1 作业1:服务端的上线与下线,客户端能动态感知,并能重新构成负载均衡。 3.2 作业2:作业完成情况下,选择性能好的服务器处理(响应时间短的服务器即为性能好)。Zookeeper记录客户端响应有效时间为5s,超时判定该客户端失效。 3.3 作业3:Zookeeper配置中心,web访问数据库需要从Zookeeper获取连接资源。当Zookeeper配置发生改变,web自动切换到新的连接资源,保持正常访问。