在Node.js中创建p2p应用程序的最佳方法是什么?

时间:2018-01-04 19:59:37

标签: node.js p2p

我想知道如何创建p2p应用。只有1种方式或多种方式。我希望每个用户都需要创建服务器和连接,或者多个连接到多个对等体。这是准确的还是我需要做一些不同的事情?

下面是我制作的一些代码,最终版本将首先创建服务器,然后请求连接的对等端口:host。我想知道的是有一种方法我可以使用net.createConnection()或其他更简单的方法创建一个p2p应用程序吗?或者每个用户都必须是他们自己的服务器吗?

const net = require('net')
const readline = require('readline')

const host = 'localhost'
const port = 3000

const rl = readline.createInterface({
    input: process.stdin,
    output: process.stdout
})

rl.on('line', (line) => {
    if(line == 'server') {
        const server = net.createServer((connection) => {
            console.log('peer connected')
            /**/
            connection.on('data', (data) => {
                console.log(data.toString())
            })
            /**/
            rl.on('line', (line) => {
                connection.write('server: ' + line)
            })
            rl.prompt()
            /**/
        }).listen(port)
    }
    else if(line == 'client') {
        const client = net.createConnection(port, host, () => {
            console.log('connected to peer')
            /**/
            client.on('data', (data) => {
                console.log(data.toString())
            })
            /**/
            rl.on('line', (line) => {
                client.write('client: ' + line)
            })
            rl.prompt()
            /**/
        })
    }
}).on('close', () => {
    process.exit(0);
})

1 个答案:

答案 0 :(得分:3)

您的代码在两个客户端方案中工作,但您可能已经注意到,对于更多客户端而言,这并不容易。

那是因为你需要多个图层/工具:

  • 具有地址空间的覆盖网络协议,因此每个客户端都可以获得 它自己的地址。这些地址将转换为IP地址 通过路由表,这就是它被称为覆盖网络的原因 协议。例如,如果您有3位地址空间,则可以有8位 独特的客户。我更喜欢客户端的广泛地址范围 随机生成自己的ID。 Kademlia就是一个很好的例子。

  • 现在您已经解决了下一期的寻址和路由问题 如果网络完全是p2p,那么客户端如何获得初始化 路由表和连接。要解决此问题,您需要一些节点 具有静态IP和高可用性,称为bootstrappers。

    当两个客户端找到每个客户端时,您的代码会完成其余的聊天工作 另外,他们在应用地址空间中的唯一地址。通常你 需要加密和一对公钥/私钥。你可以 公钥的哈希值作为客户端唯一ID。