开发者

Communication between multiple servers

开发者 https://www.devze.com 2022-12-30 01:32 出处:网络
How could a network of servers communicate with each other? For example, if Client A connects to Serve开发者_运维百科r A, how would the other servers be informed of this? I\'m guessing you would need

How could a network of servers communicate with each other?

For example, if Client A connects to Serve开发者_运维百科r A, how would the other servers be informed of this? I'm guessing you would need a "central" server, but how would it be implemented?

I'm really dumbfounded on this, so any help would be nice :)


One of the points of distributed systems is that the servers don't need to be aware of each other's doings. Server A and Server B could be front end servers even sharing the same database and still be able to work independently. The "central server" you're referring to would be the database which could physically be on a third machine or either Server A or Server B.


You might be interested to read this paper on An Analysis of the Skype Protocol for an example of how very large numbers of machines can communicate without all talking continuously to a central server or database. (A central login server is used when the user first logs in only.)


Other servers wouldn't be aware of this communication unless they specifically ask either client1 or server1 about it - if the servers ask each other for a current list of clients from time to time. If all the servers share the same database, then perhaps they can look there to see current activity, but they normally wouldn't be aware of communication that doesn't involve them.

What are you looking to accomplish, or are you just curious?


If the servers are on the same subnet and you're using IPv4, maybe you could put the ethernet cards in promiscuous mode? They would see the traffic to and from clientA/serverA. But that's opening up a whole can of worms you probably don't want to open (security, privacy, etc.) Probably a more viable solution would be to have them share a common database. Each server would update the database when they are handling a connection, and would periodically poll the database to see what other connections are being handled.

0

精彩评论

暂无评论...
验证码 换一张
取 消