首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用UDP广播在Kubernetes中发现荚/对等点

使用UDP广播在Kubernetes中发现荚/对等点
EN

Stack Overflow用户
提问于 2019-12-27 04:38:50
回答 1查看 2K关注 0票数 0

我需要使用UDP广播来进行对等发现。

环境:

  • 具有单节点Kubernetes簇的docker-desktop

我的代码如下:

代码语言:javascript
复制
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class MainApp {

    public static void main(String[] args) throws ExecutionException, InterruptedException {
        int inPort = Integer.parseInt(System.getenv("IN_PORT"));
        int outPort = Integer.parseInt(System.getenv("OUT_PORT"));
        String name = System.getenv("NAME");
        Client client = new Client(name, outPort);
        Server server = new Server(name, inPort);

        ExecutorService service = Executors.newFixedThreadPool(2);
        service.submit(client);
        service.submit(server).get();
    }


    static class Client implements Runnable {
        final String name;
        final int port;

        Client(String name, int port) {
            this.name = name;
            this.port = port;
        }

        @Override
        public void run() {
            System.out.println(name + " client started, port = " + port);
            try (DatagramSocket socket = new DatagramSocket()) {
                socket.setBroadcast(true);
                while (!Thread.currentThread().isInterrupted()) {
                    byte[] buffer = (name + ": hi").getBytes();

                    DatagramPacket packet = new DatagramPacket(buffer, buffer.length,
                            InetAddress.getByName("255.255.255.255"), port);
                    socket.send(packet);
                    Thread.sleep(1000);
                    System.out.println("packet sent");
                }
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        }
    }


    static class Server implements Runnable {
        final String name;
        final int port;

        Server(String name, int port) {
            this.name = name;
            this.port = port;
        }

        @Override
        public void run() {

            System.out.println(name + " server started, port = " + port);

            try (DatagramSocket socket = new DatagramSocket(port)) {

                byte[] buf = new byte[256];
                while (!Thread.currentThread().isInterrupted()) {
                    DatagramPacket packet = new DatagramPacket(buf, buf.length);
                    socket.receive(packet);
                    String received = new String(packet.getData(), 0, packet.getLength());

                    System.out.println(String.format(name + " received '%s' from %s:%d", received,
                            packet.getAddress().toString(),
                            packet.getPort()));
                }
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        }

    }

}

Kubernetes吊舱设置:

对于peer-1

代码语言:javascript
复制
    spec:
      containers:
        - name: p2p
          image: p2p:1.0-SNAPSHOT
          env:
          - name: NAME
            value: "peer-1"
          - name: IN_PORT
            value: "9996"
          - name: OUT_PORT
            value: "9997"

对于peer-2

代码语言:javascript
复制
    spec:
      containers:
        - name: p2p-2
          image: p2p:1.0-SNAPSHOT
          env:
          - name: NAME
            value: "peer-2"
          - name: IN_PORT
            value: "9997"
          - name: OUT_PORT
            value: "9996"

为了简单起见,我使用了不同的入/出端口。实际上,它应该是同一个端口,例如: 9999

我看到每个荚都有一个唯一的IP地址

代码语言:javascript
复制
kubectl get pods -o wide

NAME                                READY   STATUS    RESTARTS   AGE     IP          NODE             NOMINATED NODE   READINESS GATES
p2p-deployment-2-59bb89f9d6-ghclv   1/1     Running   0          2m26s   10.1.0.38   docker-desktop   <none>           <none>
p2p-deployment-567bb5bd77-5cnsl     1/1     Running   0          2m29s   10.1.0.37   docker-desktop   <none>           <none>

来自peer-1的日志

代码语言:javascript
复制
peer-1 received 'peer-2: hi' from /10.1.0.1:57565

来自peer-2的日志

代码语言:javascript
复制
peer-2 received 'peer-1: hi' from /10.1.0.1:44777

问:为什么peer-110.1.0.1而不是10.1.0.37接收UDP数据包?

如果我登录到peer-2容器:kubectl exec -it p2p-deployment-2-59bb89f9d6-ghclv -- /bin/bash

然后

代码语言:javascript
复制
socat - UDP-DATAGRAM:255.255.255.255:9996,broadcast
test
test
...

peer-1日志中,我看到了peer-1 received 'test' from /10.1.0.1:43144。再次说明为什么网络地址是10.1.0.1而不是10.1.0.37

你能告诉我我做错了什么吗?

注意:当使用同一个端口发送/接收UDP数据包时,一些对等方可以从自己的IP地址接收数据包。换句话说,一个对等点只能发现它自己的IP地址,但是对于从其他对等点/端口接收到的数据包,总是可以获取10.1.0.1

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-12-28 03:53:47

由于某些原因,UDP 在Kubernetes基础设施中不能像预期的那样工作,但是多播工作正常。

谢谢罗恩·莫平的建议多播。

这里您可以找到java代码+ kube

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59496034

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档