Network discovery in Java using multicasting

前端 未结 4 747
挽巷
挽巷 2020-12-08 11:52

I\'m trying to make a client/server Java App. Both client and server will be running on the same wi-fi network. Server will be running on a specific port that client is awar

相关标签:
4条回答
  • 2020-12-08 12:00

    (1)server listens on a pre-arranged port

    DatagramSocket s = new DatagramSocket(8888);
    s.receive  //(1)
    s.send     //(2)
    

    (3)client sends a message to the port, on the broadcast IP, 255.255.255.255

    DatagramSocket c = new DatagramSocket();
    c.send(255.255.255.255:8888,msg)     //(3)
    c.receive  //(4)
    

    the client binds to a port too. we didn't specify it, so it's random chosen for us.

    (3) will broadcast the message to all local machines, server at (1) receives message, with the client IP:port.

    (2) server sends response message to client IP:port

    (4) client gets the reponse message from server.

    0 讨论(0)
  • 2020-12-08 12:05

    You can try using java.net.MulticastSocket (available since Java 1.1). If you don't need the rich feature sets of libs like jgroups, hazelcast etc. that plain Java API might serve you well enough.

    See also example pages here and here.

    0 讨论(0)
  • 2020-12-08 12:14

    You could try using SSDP. It's what UPnP devices use to discover each other. It's multicast on port 1900 and just uses really simple packets to send around IPs and service information.

    Cling is a UPnP lib you can pull from. Note I'm not recommending you move to UPnP - just the discovery protocol used.

    0 讨论(0)
  • 2020-12-08 12:21

    I would strongly recommend using JGroups. It has a lot of features and it will do all the UDP stuff. JBoss uses it for their clustering.

    0 讨论(0)
提交回复
热议问题