Java-Gaming.org
Play Revenge of the Titans! The situation is critical. We need fancy commanders to defend Earth, the moon, Mars!
Featured games (78)
games approved by the League of Dukes
Games in Showcase (408)
games submitted by our members
Games in WIP (293)
games currently in development
News: Read the Java Gaming Resources, or peek at the official Java tutorials
 
    Home     Help   Search   Login   Register   
Pages: [1]
  ignore  |  Print  
  socketChannel vs datagramsocket (UDP)  (Read 1444 times)
0 Members and 1 Guest are viewing this topic.
Offline lesto

Senior Newbie





« Posted 2012-03-05 22:56:11 »

Hi
my friend have written a basic server and client using socket, an the again a server and a client using a socketchannel, using UDP
The client connect to server, send a packet containing the result of System.nanoTime(), the server echo this packet, then client receive the echo and find the delta between the packet time and the actual time (something like a PING)

The results are very strange: it has run on the same machine (linux system).
real ping say:
1  
2  
3  
ping 127.0.0.1
PING 127.0.0.1 (127.0.0.1) 56(84) bytes of data.
64 bytes from 127.0.0.1: icmp_req=1 ttl=64 time=0.018 ms


Socket say it has taken 0.5ms (500000ns)
Socketchannel say it has taken 2ms (2000000ns)

how this is possible? Socketchannel should be faster, no? also 2ms are really too much lag!
UDP doesn't have Nagle's algorithm, what can cause this big delay?

thanks for response, i'll add the code tomorrow if i meet my friend, but writing it from scratch should not take more than 30 minute.
Offline sproingie
« Reply #1 - Posted 2012-03-06 00:32:30 »

If 2ms ping is too much lag, then you should be working in high frequency trading, because you're going to have to deal with more than that in anything like real world gaming.  As for the discrepancy, are your client and server also communicating over loopback?

Offline lesto

Senior Newbie





« Reply #2 - Posted 2012-03-07 01:15:08 »

i know there are a lot of lag out there, that's why i'm trying to cut it off at least where i can.

yes, client and server are on the same machine using loopback (127.0.0.1)
Games published by our own members! Check 'em out!
Legends of Yore - The Casual Retro Roguelike
Online lhkbob

JGO Knight


Medals: 32



« Reply #3 - Posted 2012-03-07 03:35:41 »

UDP doesn't have Nagle's algorithm, what can cause this big delay?

Random happenstance?  Did you do send multiple packets and average them?  Testing against localhost is pretty meaningless when it comes to performance since the algorithms benefits and costs really only show up when traveling through a real network (where you can expect anywhere between 20ms and 150ms to be playable).

Pages: [1]
  ignore  |  Print  
 
 
You cannot reply to this message, because it is very, very old.

Play Revenge of the Titans! The situation is critical. We need fancy commanders to defend Earth, the moon, Mars!
 
Get high quality music tracks for your game!

Add your game by posting it in the WIP section,
or publish it in Showcase.

The first screenshot will be displayed as a thumbnail.

The invasion has landed! On Mars! And you're there to beat 'em!
cubemaster21 (143 views)
2013-05-17 21:29:12

alaslipknot (151 views)
2013-05-16 21:24:48

gouessej (182 views)
2013-05-16 00:53:38

gouessej (175 views)
2013-05-16 00:17:58

theagentd (186 views)
2013-05-15 15:01:13

theagentd (171 views)
2013-05-15 15:00:54

StreetDoggy (214 views)
2013-05-14 15:56:26

kutucuk (239 views)
2013-05-12 17:10:36

kutucuk (237 views)
2013-05-12 15:36:09

UnluckyDevil (243 views)
2013-05-12 05:09:57
Complex number cookbook
by Roquen
2013-04-24 12:47:31

2D Dynamic Lighting
by Oskuro
2013-04-17 16:46:12

2D Dynamic Lighting
by Oskuro
2013-04-17 16:45:57

2D Dynamic Lighting
by Oskuro
2013-04-17 16:23:20

Noise (bandpassed white)
by Roquen
2013-04-05 17:36:01

Noise (bandpassed white)
by Roquen
2013-04-03 16:17:38

Java Data structures
by Roquen
2013-03-29 13:21:12

Topic Request
by kutucuk
2013-03-22 21:42:01
Powered by MySQL Powered by PHP Powered by SMF 1.1.18 | SMF © 2013, Simple Machines | Managed by Enhanced Four Valid XHTML 1.0! Valid CSS!
Page created in 0.101 seconds with 20 queries.