t-io Java构建p2p网络
Java 构建p2p网络
这篇文章是一篇关于pbft算法实现的一篇补充文章,但是在这里不会涉及pbft的算法方面,所以可以当做一篇单独的文章食用。如果想查看关于区块链或者PBFT算法的文章,可以参考一下我的文章。
文章实现范围
这篇文章是构建一个p2p网络,需要拥有独立的ip地址(当然如果是在局域网内使用就无所谓了),不会涉及到内网穿透的一些实现方法,也就是说如果你是把自己电脑构建了一个p2p结点,则其他人的电脑是无法链接你电脑的结点的。
预备知识
p2p网络中,一个结点既是客户端也是服务端,可以实现任意时刻的双向的通信。因此在每个结点中,会维护一张客户端的表和一张服务端的表。我们可以从代码的方面来理解一下这个东西,如下图所示:

两个被方框圈住的表则是需要维护的表,如果在代码中的话,我们就可以使用List去保存这张表
客户端的表我们可以用来发送消息,而服务端的表我们可以用来控制群发。
这里我们可以解释和理解一下何为p2p。举例:
结点1想与结点2进行通信时:A1跑出来说,我有到结点2的通道,然后向结点2发出request,结点2的服务端接收到结点1(A1)发出来的消息的时,进行response。
这个时候,可能就会有人问:为什么不是结点1的服务端向结点2发出request呢,然后结点2再向服务端返回response?yes,这个是可以的,并且能够成功。那是不是意味着客户端的表实际上可以不要?当然不是!!!首先我们从哲学的角度理解这个东西,request理所当然应该是client发出来的,response也应当是response发出来的。当然,这个完全是扯蛋。在两个结点中,一个当做server一个当做client,这样确实不会出现问题,当时如果是3个节点呢?这样做能不能实现两两单独发送呢?很抱歉,不能。(注意,在这里是两个结点直接进行request和response,而不借助其他结点)。
下面这种模式是一个结点只为Server,另外的几个也只为Client。在这种模式中,C1和其他的结点无法独自进行两两通信,必须借助Server来进行通信。

OK,说了这么多,那么现在让我们来进行构建P2P网络
Java构建项目
在这里,我将使用maven构建项目,下面是需要使用的工具类:
- t-io:进行Socket通信。当然,t-io不是必须的,使用websocket或者netty都是可以的
项目地址:github
代码其实没什么好讲的,主要是不熟悉tio的使用,这里,emm,吐槽一下tio,妈耶,文档也太贵了吧(╮(╯▽╰)╭,学生优惠没有了,哭唧唧)。

代码解释
代码其实很简单,就是开上几个server,然后client连接Server就行了。
主要代码如下所示(实际上使用什么框架都行,自己喜欢就行,把思路弄好就可以了):
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
String ip = "127.0.0.1";
// 服务端开始
System.out.println("请输入服务端初始化端口:");
int port = in.nextInt();
// 处理消息handler
ServerAioHandler handler = new P2PServerAioHandler();
// 监听
ServerAioListener listener = new ServerListener();
// 配置
ServerTioConfig config = new ServerTioConfig("服务端", handler, listener);
// 设置timeout
config.setHeartbeatTimeout(Const.TIMEOUT *2);
TioServer tioServer = new TioServer(config);
try {
// 启动
tioServer.start(ip, port);
} catch (IOException e) {
System.out.println("启动错误:" + e.getMessage());
}
// client开始
ClientChannelContext[] contexts = new ClientChannelContext[3];
for (int i = 0; i < 3; i++) {
// client的handler
ClientAioHandler clientAioHandler = new P2pClientAioHandler();
// client 的配置
ClientTioConfig clientTioConfig = new ClientTioConfig(clientAioHandler, new P2PClientLinstener(),new ReconnConf(Const.TIMEOUT));
clientTioConfig.setHeartbeatTimeout(Const.TIMEOUT);
ClientChannelContext context;
try {
TioClient client = new TioClient(clientTioConfig);
System.out.println("输入端口:");
int serverPort = in.nextInt();
context = client.connect(new Node(ip, serverPort), Const.TIMEOUT);
contexts[i] = context;
} catch (Exception e) {
System.out.println("客户端启动错误:" + e.getMessage());
}
}
while (true) {
System.out.println("请输入发送的服务端的index");
int index = in.nextInt();
System.out.println("请输入发送的内容");
String body = in.next();
try {
MsgPacket msgPacket = new MsgPacket();
msgPacket.setBody("测试数据".getBytes(MsgPacket.CHARSET));
Tio.send(contexts[index], msgPacket);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}
}
思路:
思路还是蛮简单的,先进行server创建,并对他进行配置(配置它的消息处理方式和一些超时属性等等),在tio中,server会在后台(也就是P2PServerAioHandler这个类)接受并处理消息。然后是配置client,同样配置一些Handler和timeout等等。在这里我使用了ClientChannelContext[] contexts = new ClientChannelContext[3]来保存client。ClientChannelContext可以理解为client到server的一根管道,通过他我们可以来控制消息的发送。
项目地址:GitHub
t-io Java构建p2p网络的更多相关文章
- IT增值服务-客户案例(三):合肥薪火科技,Java和P2P网络借贷系统开发指导
客户整体情况: 合肥薪火科技,是安徽合肥一家主营微信开发和运营的中小企业,http://weimarket.cn/. 这家公司筹备.创立.曲折创业的经历,我一直有关注.因为2个老板,都是我的同学校友, ...
- AIO 开始不定时的抛异常: java.io.IOException: 指定的网络名不再可用
一天里会抛出几个这样的错误,但发现服务还在正常的运行. java.io.IOException: 指定的网络名不再可用. at sun.nio.ch.Iocp.translateErrorToIOEx ...
- Java学习之网络编程实例
转自:http://www.cnblogs.com/springcsc/archive/2009/12/03/1616413.html 多谢分享 网络编程 网络编程对于很多的初学者来说,都是很向往的一 ...
- Java进阶之网络编程
网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能,但是很多的初学者却因为很长一段时间无法进入网络编程的大门而放弃了对于该部分技术的学习. 在 学习网络编程以前,很多初学者可能觉得网络编 ...
- 使用Go语言编写区块链P2P网络(译)(转)
转自:https://mp.weixin.qq.com/s/2daFH9Ej5fVlWmpsN5HZzw 外文链接: https://medium.com/coinmonks/code-a-simpl ...
- 第78节:Java中的网络编程(上)
第78节:Java中的网络编程(上) 前言 网络编程涉及ip,端口,协议,tcp和udp的了解,和对socket通信的网络细节. 网络编程 OSI开放系统互连 网络编程指IO加网络 TCP/IP模型: ...
- 20165324 Java实验五 网络编程与安全
20165324 Java实验五 网络编程与安全 一.实验报告封面 课程:Java程序设计 班级:1653班 姓名:何春江 学号:20165324 指导教师:娄嘉鹏 实验日期:2018年5月28日 实 ...
- JXTA 2: 具有高性能、海量伸缩性的 P2P 网络
这是来自developerWorks的一篇文章,地址是 https://www.ibm.com/developerworks/cn/java/j-jxta2/ ———————————————————— ...
- 2018-2019-2-20175323 java实验五 网络编程与安全
20175323 java实验五 网络编程与安全 任务一 ①编写MyBC.java实现中缀表达式转后缀表达式的功能 ②编写MyDC.java实现从上面功能中获取的表达式中实现后缀表达式求值的功能 基本 ...
随机推荐
- 图解leetcode279 —— 完全平方数
每道题附带动态示意图,提供java.python两种语言答案,力求提供leetcode最优解. 描述: 给定正整数 n,找到若干个完全平方数(比如 1, 4, 9, 16, ...)使得它们的和等于 ...
- javascript数组大全(一张图列出数组的所有方法)
把所有数组的方法列在了一张图上,为了自己温故一下,也为了以后忘记时好查阅. 如果大家在上面查阅方法,可以找到对应的方法名,看前面简单的注释,还是不能明白的话,可以看一下官网说明,地址给大家列出来,MD ...
- 菜鸟学习Fabric源码学习 — Endorser背书节点
Fabric 1.4 源码分析 Endorser背书节点 本文档主要介绍fabric背书节点的主要功能及其实现. 1. 简介 Endorser节点是peer节点所扮演的一种角色,在peer启动时会创建 ...
- 性能数据的准备-Jmeter
性能测试的一般流程: 收集性能需求——>编写性能脚本——>执行性能测试——>分析测试报告——>系统性能调优 在收集性能需求后,我们会思考: 负载测试时并发时需要多少数据?例:登 ...
- Django之表高级操作
目录 一.如何开启自己的测试脚本? 二.对表数据的添加.更新.删除 1.create() 2.update() 3.delete() 4.查看执行的sql语句 三. 单表查询13个操作 返回Query ...
- OAuth2.0概念以及实现思路简介
一.什么是OAuth? OAuth是一个授权规范,可以使A应用在受限的情况下访问B应用中用户的资源(前提是经过了该用户的授权,而A应用并不需要也无法知道用户在B应用中的账号和密码),资源通常以REST ...
- BFS小记
题目:求从S走到G点所需步数 #S######.#......#..#.#.##.##.#.#........##.##.####....#....#.#######.#....#......#### ...
- MapGIS文件如何压缩存盘
经过多次编辑修改的MapGIS数据,含有大量逻辑上已删除的节点或图元,数据冗余复杂, 在转换过程前应注意一定要采用压缩存盘方式处理,目的是确保编辑状态已删除的数据真正从物理存储层删除,以确保数据的精简 ...
- Epplus Excel 导入 MSSQL 数据库
效果: 下载EXE 源码
- springboot2 + grpc
项目情况: springboot: 2.2.2 grpc-spring-boot-starter: 2.6.1.RELEASE 项目目录: mypro: - person - grpc服务端 - l ...