Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Xiaomi Pad 8 Pro adotta il potente Snapdragon 8 Elite all'interno di un corpo con spessore di soli 5,75 mm e pannello LCD a 144Hz flicker-free, per un tablet che può essere utilizzato con accessori dedicati di altissima qualità. Fra le caratteristiche esclusive, soprattutto per chi intende usarlo con la tastiera ufficiale, c'è la modalità Workstation di HyperOS 3, che trasforma Android in un sistema operativo con interfaccia a finestre
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-07-2011, 02:17   #1
kevinpirola
Member
 
Iscritto dal: Sep 2010
Messaggi: 102
[JAVA] Dubbi sul MulticastSocket e un po' di UDP

Ciao a tutti, sto provado ad implementare un piccolo giochetto, ho pensato, per velocizzare la comunicazione tra server e client (soprattutto sui movimenti) che il server potesse inviare i messaggi ai vari client in multicast tramite il socket MulticastSocket che è un estensione del DatagramSocket, questo invece di usare la normale classe Socket e ServerSocket per creare il collegamento client-server (o meglio, non solo). In questo modo nel server era presente un solo MulticastSocket che comunicava con tutti i client che mi interessavano.

Faccio un esempio pratico anche se esula un po' da quello che devo fare io ma è molto simile e poi vi pongo la domanda.

Classico tilemap based game MMORPG.
In ogni mappa ci sono X utenti, quando l'utente x1 si muove manda un messaggio al server (in tcp tramite Socket e ServerSocket), il server lo riceve, lo elabora e lo rigira a tutti i client connessi ad una lista (in questo caso tutti gli X utenti connessi a quella mappa, x1 compreso) in modo che tutti vedano il movimento.

Questo si può fare sia con una ArrayList<Socket> dei vari socket (o meglio ci sarà una classe SocketHandler, ma il concetto è quello) e inviare con un ciclo il messaggio one-to-one ad ogni client, oppure si può fare tramite MulticastSocket.

Sul primo sono abbastanza navigato, sul secondo molto meno.

però a me interesserebbe molto fare arrivare le informazioni ai vari client allo stesso tempo (o almeno tempi confrontabili).

Non sono sicuro però sull'implementazione, infatti, nel TCP normale avevo due classi diverse (ServerSocket e Socket) il Socket si connetteva al ServerSocket in ascolto. Il ServerSocket generava quindi un Socket che "linkava" al Socket del client stabilendo la comunicazione in andata e ritorno.

Con il MulticastSocket invece mi ritrovo una singola classe, perciò non c'è nessuno che fa da server rispetto ad un altro così ho fatto una prova di implementazione mooolto basilare e volevo avere la vostra opinione:

Codice:
public class Multicast{

	public static void main(String[] arg) {
		byte[] buffer = new byte[65535];
		try {
			int port = 5000;
			MulticastSocket sock = new MulticastSocket(5000);
			InetAddress addr = InetAddress.getByName("235.0.0.1");
			sock.joinGroup(addr);
			while (true) {
				DatagramPacket packet = new DatagramPacket(buffer, buffer.length, addr, port);
				sock.receive(packet);
				String address = packet.getAddress().toString();
				InetAddress client = packet.getAddress();
				int client_port = packet.getPort();
				System.out.println("Received : '" + new String(buffer).trim() + "' from " + address + "\n");
				// send information to the client, questa parte al momento non è utilizzata, i messaggi sono inviati dallo shooter
				//String message = "RECEIVED";
				//buffer = message.getBytes();
				//packet = new DatagramPacket(buffer, buffer.length, client, client_port);
				//sock.send(packet);
			}
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

	}
}
Codice:
public class MulticastMessageShooter {
	public static void main(String[] arg) {
		MulticastSocket s1;
		byte[] buffer = new byte[65535];
		try {
			s1 = new MulticastSocket(5000);
			int port = 5000;
			InetAddress addr = InetAddress.getByName("235.0.0.1");
			s1.joinGroup(addr);
			while (true) {
				DatagramPacket packet = new DatagramPacket(buffer, buffer.length, addr, port);
String(buffer).trim() + "' from " + address + "\n");
				String message = "RECEIVED";
				buffer = message.getBytes();
				packet = new DatagramPacket(buffer, buffer.length, addr, 5000);
				s1.send(packet);
			}
		} catch (IOException e) {
			// DONOTHING
		}


	}
}
Io lancio 3 o 4 istanze della prima classe e poi faccio andare per un tot la classe shooter che mi spara qualche messaggio Multicast. Se poi vado a leggere, tutte le istanze hanno ricevuto i messaggi.

Il fatto è che non ho differenze tra client e server, l'unica cosa che mi viene in mente è che magari il server invia e basta (perciò non implemento il ciclo in ascolto) e il client riceve e basta, le altre comunicazioni che dovrebbero avvenire singole (il client manda le coordinate al server e solo al server, poi il server le checka, se sono buone manda il comando di movimento alle gui e perciò anche alla gui di colui che ha inviato il messaggio, facendo muovere il personaggio, altrimenti non manda alcun messaggio (e il personaggio non si muove)) avvengono tramite ServerSocket e Socket in TCP.

Sono giusto con i ragionamenti? Mi sembra un po' troppo aperta la MulticastSocket, e poi quell'IP là che sta nel famoso range tra 224.0.0.0 e 239.255.255.255 come lo scelgo? non c'è possibilità che tra quegli ip ci sia qualcuno che invia messaggi? devo codificare ogni messaggio?


Attendo vs risposte di qualsiasi tipo, anche se sono critiche sul codice sono molto ben accette

Ultima modifica di kevinpirola : 26-07-2011 alle 02:21.
kevinpirola è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2011, 08:29   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Ciao, credo che questa trail potrebbe chiarire i tuoi dubbi.
In particolare la terza parte, quella titolata "Broadcasting to Multiple Recipients".

Edit:
Poi non so se fa al caso tuo, ma potresti valutare l'uso di canali non bloccanti tra i client e il server.
Su questo forum c'è un eccellente tutorial in merito, ecco il link
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 26-07-2011 alle 13:07. Motivo: orrore grammaticale
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2011, 13:19   #3
kevinpirola
Member
 
Iscritto dal: Sep 2010
Messaggi: 102
Ti ringrazio, la lettura sui Socket non bloccanti è stata veramente piacevole inoltre è fatta veramente bene, fossero tutte così le lezioni dell'università

Quello che innanzitutto mi viene da pensare riguardo al socket non bloccante (che l'autore consiglia perchè ottimizza le prestazioni e minimizza i tempi morti sui singoli thread) è che la mole di informazioni che avrò io è diversa, perciò il singolo thread non è proprio sprecato, nel senso, come minimo in ingresso dal singolo client avrò circa 3/4 messaggi al secondo dovuti allo spostamento sulla mappa, aggiungici la chat, le azioni e le interazioni del gioco... il tutto diventa abbastanza pesante, per tale motivo mi trovo un po' scettico sull'utilizzo di un singolo thread e un singolo serversocket...

Per quanto riguarda invece il Multicasting UDP mi fa paura la frase:
Quote:
A datagram is an independent, self-contained message sent over the network whose arrival, arrival time, and content are not guaranteed.
Cioè non so se arriva nè quando nè se quello che contiene è giusto?.. stica....

Nel senso, se la differenza di arrivo tra due messaggi è minima posso anche accettarlo, ma se sono tempi discreti potrebbe essere un problema, immaginate, prima lo sprite del giocatore si muove di tre caselle in avanti poi da solo torna 2 caselle indietro perchè riceve il messaggio vecchio.....lol
kevinpirola è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2011, 14:08   #4
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Ti ringrazio, la lettura sui Socket non bloccanti è stata veramente piacevole inoltre è fatta veramente bene, fossero tutte così le lezioni dell'università
Vero? Secondo me PGI ha un talento naturale, spiega benissimo, e si fa leggere volentieri.

Beh, partiamo considerando il fatto che, tra tutti i tipi di giochi che si possono programmare i MMORPG, come tipologia, sono forse i più complessi in assoluto (leggi: bagno di sangue).

Solo la questione del networking nei giochi (TCP vs UDP) merita un discorso a parte. Se per te tutto quest'ambito è nuovo, forse è il caso che ti prendi un po' di tempo per setacciare informzioni in giro e capire con cosa avrai a che fare.
Se sei curioso, leggiti questo:
[The Internet Sucks: Or, What I Learned Coding X-Wing vs. TIE Fighter -- By Peter Lincroft]
Anche questa discussione potrebbe interessarti:
[UDP vs TCP/IP - Java]

Poi, ti segnalo questo forum come ottima fonte di info riguardo al fare giochi in Java, al fatto di voler fare un MMORPG, e a TCP/UDP per i giochi (visita la sezione "Networking and Multiplayer"):
Java-Gaming.org
Ti assicuro che il tempo la speso non sarà buttato via

Per finire:
Quote:
Cioè non so se arriva nè quando nè se quello che contiene è giusto?.. stica....
Esatto, sì, ma è il protocollo UDP ad essere così: nessuna garanzia ne sul fatto che i pacchetti arrivino a destinazione ne sul fatto che arrivino in ordine. Ci sono pro e contro. Se invece vuoi dette garanzie, c'è il protocollo TCP. Anche qua: pro e contro, bisogna conoscerli.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 26-07-2011 alle 14:27.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2011, 17:46   #5
kevinpirola
Member
 
Iscritto dal: Sep 2010
Messaggi: 102
Ti dirò, l'idea del gioco è veramente molto più complessa di quanto io possa immaginare, perchè l'idea non è solo di fare un normale mmorpg ma implementare molte altre funzionalità come ad esempio il gioco con il mouse e tante tante altre cose.

Sto partendo dalla parte però principale ovviamente, al momento di scritto ho solo interfacce e poco più, perchè voglio assolutamente delineare le cose come si deve.

Sul networking non sono nuovo, ho avuto moltissimo a che fare con il TCP e il famoso Socket e ServerSocket (sto sviluppando con l'università un grosso progetto di un programma peertopeer di cui gestisco il server IRC distribuito al momento), di UDP avevo studiato la teoria (*poca*) ma mai implementato. Sono a digiuno di networking applicato al gaming, quello si, ma sono proprio qui per informarmi, io sono molto dell'idea -> poche prove tanti libri, ed è quello che sto facendo, ho trovato anche un libro (mi sfugge il titolo ma l'ho tra i preferiti e sarà il prossimo acquisto) dedicato alla programmazione di giochi in java.

Ti ringrazio veramente moltissimo per il materiale che hai fornito, quello però al momento non posso (non devo, domani ho un esame, devo concentrarmi sul VHDL!) leggerlo, lo guarderò domani con calma.


L'idea però è di mettere su un team di sviluppatori che lavori su features separate in modo da diluire il lavoro e meno si fa, in teoria, lo si dovrebbe far meglio. Il fatto è che io sarò il responsabile del progetto, e secondo il mio punto di vista se uno deve essere il responsabile le cose deve sapersele fare tutte da solo, per poi delegare, ed eventualmente controllare che tutto vada bene alla fine...

Al momento ho messo al lavoro un grafico per le ambientazioni e ho "prenotato" un programmatore per settembre. In settembre però vorrei già uscire con la prima alpha di prova con le funzionalità minimali... speriamo bene
kevinpirola è offline   Rispondi citando il messaggio o parte di esso
Old 30-07-2011, 14:23   #6
kevinpirola
Member
 
Iscritto dal: Sep 2010
Messaggi: 102
ho letto i vari articoli che mi sono stati consigliati, non sono però riuscito ancora a tirare fuori una conclusione, alla fine si va a gusti, a prove e a culo?

l'idea mia era

il giocatore invia un messaggio tcp al server che riceve elabora e multicasta un messaggio udp a tutti quelli della mappa

altre comunicazioni invece sempre tramite tcp che non hanno bisogno di gran realtime
kevinpirola è offline   Rispondi citando il messaggio o parte di esso
Old 31-07-2011, 12:46   #7
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Ciao, ti ho postato i link perchè è il massimo che potevo fare per aiutarti, io non mi sono mai cimentato direttamente con la realizzazione di un gioco che faccia uso dei socket, quindi di più non so dirti, anche se, credo come al solito, la scelta tra tcp o udp e con che strategia implementativa dipende dai dettagli della tua applicazione.

Certo consigli e indiciazioni da chi ha esperienza di prima mano in questo campo sarebbero di aiuto... comunque il forum linkato ti potrà servire, proprio in tal senso, è frequentato da gente in gamba.

L'unica "massima" che ho letto era una del tipo "vai con tcp all'inizio e se poi non funziona passa a udp".
Magari nel tuo caso la tua strategia è già un filo più raffinata, comunque ti resta il "problema" di gestire l'eventuale drop dei pacchetti udp... una strategia naive potrebbe essere quella che ogni datagramma spedito contiene anche quello spedito precedentemente, però bisogna vedere se è adatta al tuo caso.

Alla fine saranno le prove sul campo che dimostreranno la validità di una soluzione piuttosto che un'altra.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 01-08-2011, 16:00   #8
kevinpirola
Member
 
Iscritto dal: Sep 2010
Messaggi: 102
si può essere una idea, ti ringrazio molto per l'aiuto, ora sto scrivendo fogli su fogli di idee, schemi, prove... prima o poi comincerò anche a buttar giù codice .D
kevinpirola è offline   Rispondi citando il messaggio o parte di esso
Old 01-08-2011, 16:39   #9
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da kevinpirola Guarda i messaggi
si può essere una idea, ti ringrazio molto per l'aiuto, ora sto scrivendo fogli su fogli di idee, schemi, prove... prima o poi comincerò anche a buttar giù codice .D
Se hai 10 minuti, leggiti il seguente link (è breve), ti può dare uno spunto eccellente (non che devi usare quell'approccio, ma che conoscendo il proprio sistema/engine/applicativo e con un po' di "insight" si può trovare la soluzione giusta, magari confrontandosi anche con altri che hanno avuto esperienze simili):
http://trac.bookofhook.com/bookofhoo...ake3Networking
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Ecovacs presenta la gamma 2026: paviment...
Efficienza energetica fino a 2.000 volte...
Lenovo 360: il programma di canale dell'...
Appena 10.000 qubit per rompere la critt...
Analisi dei transistor durante il funzio...
Attacco informatico a Booking.com: espos...
A quattro mesi dal divieto dei social ne...
NVIDIA GeForce RTX 5060 e 5060 Ti: in ar...
Rebellions, Arm e SK Telecom, nuova alle...
Modernizzazione delle app: Red Hat OpenS...
Nel mirino di Google c'è il back ...
PRAGMATA in bundle con GeForce RTX 5000:...
Le novità MOVA per il 2026: robot e impi...
Windows, stop all'attivazione telefonica...
ASUS porta la serie TUF nel formato Mini...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 02:25.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v