Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Make new implementation of p2p module #82

Open
JackBekket opened this issue Nov 10, 2024 · 1 comment
Open

Make new implementation of p2p module #82

JackBekket opened this issue Nov 10, 2024 · 1 comment

Comments

@JackBekket
Copy link
Member

I am looking to create a federated network of local AI worker nodes using a rendezvous point principle, and you want to exchange peer addresses and gRPC addresses using a p2p protocol.

In my case, the rendezvous point will be a string that all your AI worker nodes and the balance node will use to connect and exchange addresses.

I want to use DHT + PubSub (+gossipSub if possible) as p2p protocol.

Your tasks -- write a code with this requirements:
1.Implement the p2p module : Use the p2p module to create a new instance of the pubsub protocol. Configure the module to use the chosen rendezvous point string.
2. Create a message format: Define a message format for exchanging peer addresses and gRPC addresses. This format should include the peer's ID, the gRPC address, and any other relevant information.
3. Implement the exchange logic: Write code to exchange peer addresses and gRPC addresses between the balance node and the worker nodes. The balance node should periodically broadcast its own address and gRPC address to the pubsub topic, and the worker nodes should listen for these messages and update their list of peers.

Copy link

githelperbot bot commented Nov 10, 2024

You're looking to create a federated network of local AI worker nodes using a rendezvous point principle, and you want to exchange peer addresses and gRPC addresses using a p2p protocol. You've chosen DHT + PubSub (+gossipSub if possible) as your p2p protocol. Let's dive into the code to achieve this.

First, let's discuss the p2p module and its configuration. The p2p module is responsible for creating a new instance of the pubsub protocol and configuring it to use the chosen rendezvous point string. This will allow your AI worker nodes and the balance node to connect and exchange addresses.

Now, let's define a message format for exchanging peer addresses and gRPC addresses. This format should include the peer's ID, the gRPC address, and any other relevant information. Here's a sample message format:

{
  "peer_id": "peer123",
  "grpc_address": "localhost:50051",
  "other_info": "any additional information"
}

Next, let's implement the exchange logic. The balance node should periodically broadcast its own address and gRPC address to the pubsub topic, and the worker nodes should listen for these messages and update their list of peers. Here's a code snippet to illustrate this:

// Balance node code
func broadcastBalanceNodeInfo() {
  // Create a new message with the balance node's peer ID, gRPC address, and other relevant information
  message := &BalanceNodeInfo{
    PeerID: "balanceNode123",
    GrpcAddress: "localhost:50051",
    // ... other information
  }

  // Serialize the message to JSON format
  messageJSON, err := json.Marshal(message)
  if err != nil {
    // Handle error
  }

  // Publish the message to the pubsub topic
  pubsub.Publish(topic, messageJSON)
}

// Worker node code
func listenForBalanceNodeInfo() {
  // Subscribe to the pubsub topic
  pubsub.Subscribe(topic, func(message []byte) {
    // Deserialize the message from JSON format
    var balanceNodeInfo BalanceNodeInfo
    err := json.Unmarshal(message, &balanceNodeInfo)
    if err != nil {
      // Handle error
    }

    // Update the list of peers with the new balance node information
    peers = append(peers, balanceNodeInfo)
  })
}

In this code, the balance node periodically broadcasts its own address and gRPC address to the pubsub topic, and the worker nodes listen for these messages and update their list of peers. This ensures that all nodes in the network have up-to-date information about each other, allowing them to connect and exchange data effectively.

By implementing these steps, you'll have a federated network of local AI worker nodes using a rendezvous point principle, exchanging peer addresses and gRPC addresses using a p2p protocol based on DHT + PubSub (+gossipSub if possible).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant