|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Dec 2001
Città: Partinico(PA)-Torino
Messaggi: 2885
|
problema C socket
salve ragazzi!
Ho un problemino con una applicazione client-server in C. In pratica, facendo girare client e server sullo stesso PC non ho nessun problema e tutto gira alla perfezione; se lancio invece client e server su 2 pc della mia lan ho dei problemi con i comandi, nel senso che i comandi è come se arrivassero in ritardo e non sincronizzati al server. Si tratta di 2 semplici giochini che funzionano sul server. Sono stati compilati sotto linux ovviamente. Se potete farmi il favore di darci un occhiata...e dirmi cosa potrebbe essere che non va...scusate per il codice C.Grazie. li allego
__________________
Main: Barton 2500@3200+ Asus A7N8X-dlx 2*512 DDRPowercolor 9800Pro Maxtor 80GB sATA + Seagate 160GB pATA LCD Acer AL1721 Epson C62 Antec T.P. 430w Tin.it ADSL Muletto: Pentium4 1800 Notebook: Idea Progress P4 Auto e moto d'epoca
|
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Dec 2001
Città: Partinico(PA)-Torino
Messaggi: 2885
|
Nessuno ci ha capito niente?
Potreste almeno farmi il favore di provarli su 2 PC? Non capisco perchè su un singolo PC tutto funziona alla perfezione, ma su 2 spuntano problemi di sincronizzazione client-server. Grazie
__________________
Main: Barton 2500@3200+ Asus A7N8X-dlx 2*512 DDRPowercolor 9800Pro Maxtor 80GB sATA + Seagate 160GB pATA LCD Acer AL1721 Epson C62 Antec T.P. 430w Tin.it ADSL Muletto: Pentium4 1800 Notebook: Idea Progress P4 Auto e moto d'epoca
|
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
E' un errore frequente.
La recv ritorna i byte nel buffer di ricezione, fino al massimo che tu indichi. La rete è libera di spezzettare i pacchetti come vuole. In locale la mtu è molto grande (16kb), quindi non osservi il problema. Ma la mtu ethernet è circa 1500, questo vuol dire che i pacchetti di 4kb vengono sicuramente frammentati e quello che ti accade è che stai leggendo il primo pacchetto mentre il secondo è ancora in ricezione. Puoi sincerarti di questo controllando il valore ritornato dalla recv (che è il numero di byte effettivamente letti) e puoi verificare come risulta <4096 quando noti il disallineamento.
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12 |
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Dec 2001
Città: Partinico(PA)-Torino
Messaggi: 2885
|
Ho capito perfettamente la tua risposta, anche perchè sto studiando reti e ho appena fatto la frammentazione dei datagram su ethernet
Ma non ci dovrebbe essere dopo la frammentazione un riassemblaggio all'host? Sei un grande! Adesso mi chiedo: c'è un modo per risolvere il fastidioso problema?dovrei per forza di cose ridurre il buffer? o c'è un altra soluzione? Grazie ancora
__________________
Main: Barton 2500@3200+ Asus A7N8X-dlx 2*512 DDRPowercolor 9800Pro Maxtor 80GB sATA + Seagate 160GB pATA LCD Acer AL1721 Epson C62 Antec T.P. 430w Tin.it ADSL Muletto: Pentium4 1800 Notebook: Idea Progress P4 Auto e moto d'epoca
|
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Dec 2001
Città: Partinico(PA)-Torino
Messaggi: 2885
|
Ho provato a visualizzare il valore ritornato dalla recv e mi restituisce sempre 0
__________________
Main: Barton 2500@3200+ Asus A7N8X-dlx 2*512 DDRPowercolor 9800Pro Maxtor 80GB sATA + Seagate 160GB pATA LCD Acer AL1721 Epson C62 Antec T.P. 430w Tin.it ADSL Muletto: Pentium4 1800 Notebook: Idea Progress P4 Auto e moto d'epoca
|
|
|
|
|
|
#6 |
|
Senior Member
Iscritto dal: Dec 2001
Città: Partinico(PA)-Torino
Messaggi: 2885
|
ho diminuito il buffer a 1400 è tutto sembra funzionare
Spero di non avere altri problemi! Grazie mille PS: ma non c'è un'altra soluzione per risolvere il problema?
__________________
Main: Barton 2500@3200+ Asus A7N8X-dlx 2*512 DDRPowercolor 9800Pro Maxtor 80GB sATA + Seagate 160GB pATA LCD Acer AL1721 Epson C62 Antec T.P. 430w Tin.it ADSL Muletto: Pentium4 1800 Notebook: Idea Progress P4 Auto e moto d'epoca
|
|
|
|
|
|
#7 | |
|
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Quote:
L'udp funziona in maniera differente, tantè che mentre puoi leggere un byte alla volta su uno stream tcp senza perdere nessun dato, se leggi solo un byte da un socket udp il resto dei dati del datagramma viene buttato!
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12 |
|
|
|
|
|
|
#8 | ||
|
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Quote:
Quote:
Codice:
int recv_block(int fd, char *buf, int sz) {
while (sz>0) {
int dim = recv(fd, buf, sz, MSG_NOSIGNAL);
if(!dim) break; /* EOF=disconnessione del peer */
else if(dim==-1) {
if(errno==EINTR) continue; /* il programma ha ricevuto un segnale */
break;
}
buf += dim;
sz -= dim;
}
return sz==0 ? 0 : -1;
}
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12 |
||
|
|
|
|
|
#9 |
|
Senior Member
Iscritto dal: Dec 2001
Città: Partinico(PA)-Torino
Messaggi: 2885
|
Ma se provo a visualizzare il valore ritornato da recv come mai è sempre zero?
Non so esattamente quanto leggere perchè di volta in volta passo delle stringhe di lunghezza sempre diversa,altrimenti dovrei imporre un massimo di lettura? non sarebbe sempre limitativo? edit: ho appena visto che in C la funzione recv ritorna 0 oppure -1 in caso di errore.
__________________
Main: Barton 2500@3200+ Asus A7N8X-dlx 2*512 DDRPowercolor 9800Pro Maxtor 80GB sATA + Seagate 160GB pATA LCD Acer AL1721 Epson C62 Antec T.P. 430w Tin.it ADSL Muletto: Pentium4 1800 Notebook: Idea Progress P4 Auto e moto d'epoca
Ultima modifica di marcus81 : 23-09-2005 alle 19:28. |
|
|
|
|
|
#10 | |||
|
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Quote:
Quote:
Hai varie soluzioni; dal prependere alla stringa la sua dimensione, al leggere un byte alla volta finché non incontri '\0', al riempire un certo buffer e rintracciare lì dentro con calma le stringhe complete. Inventati qualcosa, la soluzione non è unica. Quote:
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12 |
|||
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 09:54.










Main: Barton 2500@3200+ Asus A7N8X-dlx 2*512 DDRPowercolor 9800Pro Maxtor 80GB sATA + Seagate 160GB pATA LCD Acer AL1721 Epson C62 Antec T.P. 430w Tin.it ADSL Muletto: Pentium4 1800 Notebook: Idea Progress P4 








