What's the best way to coordinate javascript clients to a single backend game?

前端 未结 3 1673
忘掉有多难
忘掉有多难 2021-01-21 17:44

What\'s the best method to use to notify javascript client\'s of changes that occur in a game asynchronously (i.e. moves made by other clients). As an example, assume a turn bas

相关标签:
3条回答
  • 2021-01-21 17:54

    Polling can easily stack up and consume a lot of resources (eg: bandwidth), no matter how lightweight your requests and responses are.

    http://ajaxpatterns.org/Periodic_Refresh

    You might want to try and use Comet/HTTP Streaming http://ajaxpatterns.org/HTTP_Streaming

    0 讨论(0)
  • 2021-01-21 17:55

    Unfortunately there are only a few options for this. All will involve having some sort of client on the server sending down notifications if you want to use push technology. Or else polling is the way to go.

    But just as a tangent here is a solution I played with years ago: http://www.spsolutionscorp.com/blog/2007/03/14/RealTimeUpdatesToWebPageUsingMacromediaFlash.aspx

    The gist of it was this: Sql Server with service broker turned on. .Net service on server that is using SqlDependency to listen for changes to query result (http://support.microsoft.com/kb/555893). Once change occurred the .net service looped through all connections that had been made from a flash client that I wrote about in the above blog article. Then the flash app could call out to the javascript on the page.

    It was a crazy idea and I never put into productions. But depending on your use it might be worth looking into and it was pretty easy to get going.

    But again this was a totally crazy idea and again one I never put into production so use at your own risk. Just thought I would share.

    0 讨论(0)
  • 2021-01-21 18:13

    Polling every second or so is one option, but you may want to consider long polling instead, to reduce the latency.

    Quoting Comet Daily: The Long-Polling Technique:

    The long-polling Comet technique is a technique that optimizes traditional polling to reduce latency.

    Traditional polling sends an XMLHttpRequest to the server in fixed intervals. For example, open a new XMLHttpRequest every 15 seconds, receive an immediate response, and close the connection.

    Long-polling sends a request to the server, but a response is not returned to the client until one is available. As soon as the connection is closed, either due to a response being received by the client or if a request times out, a new connection is initiated. The result is a significant reduction in latency because the server usually has a connection established when it is ready to return information to return to the client.

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