Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-10-2002, 19:48   #1
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
[C/C++]Thread e socket in ascolto...

Sto programmando un serverino TCP sotto Windows...
Ho seguito la tecnica che su Unix si chiama prefork...cioè mi creo un pool di N thread che dovranno gestire ognuno un client (per poter gestire contemporaneamente N client)...

Ovviamente tutti i thread devono stare in ascolto sulla stessa porta...

Ora volevo sapere se va bene il metodo che ho seguito :

socket
bind
listen
Creo il pool di thread...e passo ad ognuno il socket dopo la listen come argomento...
Nei vari thread resto in attesa di una connessione con la accept...

Preciso che funziona tutto...ma secondo voi è meglio fare così o è meglio fare una accept centralizzata e poi svegliare un thread passandogli il socket ritornato dalla accept ?

Grazie...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 23-10-2002, 21:14   #2
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
MOLTO meglio usare un thread per il server socket e lanciare un thread specifico per ogni connessione.
Lanciare n accept sullo stesso socket può causare 2^n-1 problemi
Poi perchè dei creare un pool di thread? Puoi crearne a mano a mano che sono richiesti, è molto più efficiente (non ci vuole molto a creare un thread)
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2002, 08:48   #3
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da ilsensine
[b]MOLTO meglio usare un thread per il server socket e lanciare un thread specifico per ogni connessione.
Lanciare n accept sullo stesso socket può causare 2^n-1 problemi
Poi perchè dei creare un pool di thread? Puoi crearne a mano a mano che sono richiesti, è molto più efficiente (non ci vuole molto a creare un thread)
Dici che non ci vuole molto a creare un thread ? Non lo so questo...certo ci vuole meno che a creare un processo (motivo per cui il metodo della prefork era stato creato)...

La prefork dovrebbe essere usata anche da Apache quando non si compila con i pthread...

E se invece provassi a fare un meccanismo produttore-consumatore ?

Un bel vettore di socket...i vari thread restano in attesa su questa coda...e con due semafori mi gestisco (e limito) l'ingresso sulla coda...
Questo può avere anche la duplice funzione di bloccarmi ulteriori accept quando non posso gestirli con il pool di thread...

Un'ulteriore domandina che succede se supero il numero di connessioni specificate nella listen ?

Ciao e grazie
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2002, 09:18   #4
Tassadar
Senior Member
 
L'Avatar di Tassadar
 
Iscritto dal: Oct 2001
Città: Scorzè (VE)
Messaggi: 853
Secondo me la tecnica dei thread è la tecnica + pulita e com meno sprechi di memoria / tempo CPU, magari utilizzi un thread aggiuntivo manager che controlla la vita dei thread associati ad ogni cliente
__________________
Mr. T.
Tassadar è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2002, 09:21   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da Tassadar
[b]magari utilizzi un thread aggiuntivo manager che controlla la vita dei thread associati ad ogni cliente
Già fatto
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2002, 09:29   #6
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
E se invece provassi a fare un meccanismo produttore-consumatore ?

Un bel vettore di socket...i vari thread restano in attesa su questa coda...e con due semafori mi gestisco (e limito) l'ingresso sulla coda...
L'unica cosa che non mi piace in questo approccio è che crei in via preventiva un gran numero di thread. Per me ha senso solo se il tempo di risposta è un fattore più importante delle prestazioni a "regime" (ammesso che con i semafori non introduci ulteriori latenze).

Quote:
Un'ulteriore domandina che succede se supero il numero di connessioni specificate nella listen ?
Lo standard prescrive che il numero di connessioni che passi in listen non è il massimo numero di connessioni stabilite, ma il massimo numero di connessioni in coda in attesa della accept.
Il massimo numero di connessioni stabilite devi controllarlo manualmente, ad es. effettuando uno shutdown() del server socket quando il massimo numero di connessioni è stato raggiunto, e ripartire con la listen quando qualche connessione viene chiusa. Non ho mai usato lo shutdown() in questo modo, ma dovrebbe funzionare.
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2002, 09:41   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da ilsensine
[b]L'unica cosa che non mi piace in questo approccio è che crei in via preventiva un gran numero di thread. Per me ha senso solo se il tempo di risposta è un fattore più importante delle prestazioni a "regime" (ammesso che con i semafori non introduci ulteriori latenze).
Provvederò a fare qualche prova...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2002, 11:21   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Mi sono fatto una coda che tiene N socket...
I thread si bloccano in attesa che ci sia un socket disponibile...
Un altro thread fa la accept sulla porta in ascolto e mette il socket che riceve dalla accept nella coda...

Sembra funzionare molto bene...

Altro domandina... Di cosa mi devo preoccupare per rendere il server sicuro...cioè come faccio ad evitare buffer overflow e attacchi OOB (questi ho già settato il socket per non riceverli insieme ai dati normali, va bene ?)...

Altra cosa come faccio ad evitare che mi facciano dei semplici attacchi di tipo DOS (ad esempio...se io ho N thread e mi vengono lanciateN+1 connessioni dallo stesso host mi hanno già fatto un bel DOS)... Per ora ho messo un timeout sulla select in attesa della ricezione dei dati...

Ultima cosa...come faccio ad avere l'indirizzo IP di chi si connette al mio server ? Mettendo il buffer sulla accept mi fallsice sempre (mi ricordo che me lo faceva anche in FreeBSD)...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2002, 11:30   #9
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Altro domandina... Di cosa mi devo preoccupare per rendere il server sicuro...cioè come faccio ad evitare buffer overflow e attacchi OOB (questi ho già settato il socket per non riceverli insieme ai dati normali, va bene ?)...
Di default OOB dovrebbe essere disabilitato.

Quote:
Altra cosa come faccio ad evitare che mi facciano dei semplici attacchi di tipo DOS (ad esempio...se io ho N thread e mi vengono lanciateN+1 connessioni dallo stesso host mi hanno già fatto un bel DOS)... Per ora ho messo un timeout sulla select in attesa della ricezione dei dati...
Sarebbe interessante limitare il numero di connessioni provenienti da un solo indirizzo, oltre a mettere timeout e controlli sul formato dei dati ricevuti.

Quote:
Ultima cosa...come faccio ad avere l'indirizzo IP di chi si connette al mio server ? Mettendo il buffer sulla accept mi fallsice sempre (mi ricordo che me lo faceva anche in FreeBSD)...
Codice:
struct sockaddr_in clientname;
int size;

size = sizeof(struct sockaddr_in);
newsock = accept(fd, (struct sockaddr *) &clientname, &size);
fprintf(stderr, "connessione da %s porta %hd\n",
          inet_ntoa(clientname.sin_addr), ntohs(clientname.sin_port));
Per sistemi unix devi cambiare int size con size_t size.
__________________
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
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2002, 13:16   #10
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Non avevo messo la dimensione Credevo che quel paramentro la ricevesse la dimensione...

Vabbè...perfetto...

Riguardo al controllo sull'ip...avevo chiesto come vedere l'ip proprio per fare questo controllo...

Procedo al controllo sull'ip...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2002, 23:06   #11
Cimmo
Senior Member
 
L'Avatar di Cimmo
 
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
Fico sto facendo un programmino del tutto simile anche io, addirittura io devo creare un client/server che sia capace sia di accettare connessioni che di farne. Sto usando i semafori, infatti come penso tu abbia visto ho aperto il mega thread sulle "domandine semplici in C"...adesso ho un problema, l'ho appena postato, magari tu ne sai qualcosa non e' che potresti darci un'occhiata?

Thanx

Cimmo
Cimmo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
La cometa interstellare 3I/ATLAS e le nu...
Blue Origin presenta TeraWave, una nuova...
Compra una GeForce RTX 5080 venduta e sp...
Telescopio spaziale James Webb: osservat...
L'IA non ha portato quasi nessun benefic...
Sony LinkBuds Clip, gli auricolari open ...
La fibra è sempre più diff...
Arriva Vertiv CoolPhase PAM: raffreddame...
Chiamate cristalline e ANC evoluto a pre...
Adobe aggiorna Premiere e After Effects:...
AI Bundle, la novità dei driver A...
La roadster elettrica supportata da Xiao...
Netflix rivede l'offerta per Warner Bros...
Satya Nadella avverte: senza benefici co...
Anche secondo Andy Jassy, CEO di Amazon,...
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: 21:24.


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