利用ZooKeeper开发分布式应用系统案例--服务端与客户端实现

本文主要是介绍利用ZooKeeper开发分布式应用系统案例--服务端与客户端实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

利用ZooKeeper开发分布式应用系统案例--服务端与客户端实现

服务端代码:

package cn.edu360.zk.distributesystem;import java.io.IOException;import org.apache.zookeeper.CreateMode;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZooDefs.Ids;
import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.data.Stat;public class TimeQueryServer {ZooKeeper zk = null;//启动zk客户端连接public void connectZK() throws Exception {zk = new ZooKeeper("hadoop1:2181,hadoop2:2181,hadoop3:2181", 2000, null);}//注册服务器信息public void registerServerInfo(String hostname,String port) throws Exception, InterruptedException {/** 先判断注册节点是否存在,如果不存在,则创建*/Stat stat = zk.exists("/servers", false);if(stat == null) {zk.create("/servers", null, Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);}//注册服务器数据到zk的约定注册节点下String create = zk.create("/servers/server", (hostname + ":" + port).getBytes(), Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL_SEQUENTIAL);System.out.println(hostname + "服务器向zk注册信息成功,注册的节点为:" + create);}//启动业务线程开始处理业务public static void main(String[] args) throws Exception, Exception {TimeQueryServer timeQueryServer = new TimeQueryServer();//启动zk客户端连接timeQueryServer.connectZK();//注册服务器信息timeQueryServer.registerServerInfo(args[0], args[1]);//启动业务线程开始处理业务new TimeQueryService(Integer.parseInt(args[1])).start();}}

服务端线程代码:

package cn.edu360.zk.distributesystem;import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.Date;public class TimeQueryService extends Thread{int port = 0;public TimeQueryService(int port) {this.port = port;}@Overridepublic void run() {try {ServerSocket ss = new ServerSocket(port);System.out.println("业务线程已绑定端口"+ port + "准备接受消费端请求了...");while(true) {Socket sc = ss.accept();InputStream inputStream = sc.getInputStream();OutputStream outputStream = sc.getOutputStream();outputStream.write(new Date().toString().getBytes());}} catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace();}}}

客户端代码:

package cn.edu360.zk.distributesystem;import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.Watcher.Event.EventType;
import org.apache.zookeeper.Watcher.Event.KeeperState;
import org.apache.zookeeper.ZooKeeper;public class Consumer {//定义一个list用于存放最新的在线服务器列表private volatile ArrayList<String> onlineServers = new ArrayList<String>();//构造zk连接对象ZooKeeper zk = null;public void connectZK() throws Exception {zk = new ZooKeeper("hadoop1:2181,hadoop2:2181,hadoop3:2181", 2000, new Watcher() {@Overridepublic void process(WatchedEvent event) {if(event.getState() == KeeperState.SyncConnected && event.getType() == EventType.NodeChildrenChanged) {try {//事件回调逻辑中,再次查询zk上的在线服务器节点即可,查询逻辑中又再次注册子节点事件监听。getOnlineServers();} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}}});}//查询在线服务器列表public void getOnlineServers() throws Exception, InterruptedException {List<String> children = zk.getChildren("/servers", true);ArrayList<String> list = new ArrayList<String>();for (String child : children) {byte[] data = zk.getData("/servers/"+child, false, null);String serverInfo = new String(data);list.add(serverInfo);}onlineServers = list;System.out.println("查询了一次zk,当前在线的服务器有:"+list);}public void sendRequest() throws Exception {Random random = new Random();while(true) {try {//挑选一台当前在线的服务器	int nextInt = random.nextInt(onlineServers.size());String server = onlineServers.get(nextInt);String hostname = server.split(":")[0];int port = Integer.parseInt(server.split(":")[1]);System.out.println("本次请求挑选的服务器为:" + server);Socket socket = new Socket(hostname, port);OutputStream outputStream = socket.getOutputStream();outputStream.write("haha".getBytes());outputStream.flush();InputStream inputStream = socket.getInputStream();byte[] buf = new byte[256];int read = inputStream.read(buf);System.out.println("服务器相应的时间为" + new String(buf,0,read));outputStream.close();inputStream.close();socket.close();Thread.sleep(2000);}catch(Exception e) {e.printStackTrace();}}}public static void main(String[] args) throws Exception {Consumer consumer = new Consumer();//构造zk连接对象consumer.connectZK();//查询在线服务器列表consumer.getOnlineServers();//处理业务(向一台服务器发送时间查询请求)consumer.sendRequest();}}

这篇关于利用ZooKeeper开发分布式应用系统案例--服务端与客户端实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/176901

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设