Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
Al MWC Qualcomm annuncia una coalizione industriale per lanciare il 6G entro il 2029 e introduce agenti IA per la gestione autonoma della RAN. Ericsson, presente sul palco, conferma la direzione: le reti del futuro saranno IA-native fin dalla progettazione
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air è un ultraleggero da 1 kg con Ryzen 5 6600H, display 14" 16:10 e 16 GB LPDDR5. Offre buona portabilità, autonomia discreta e costruzione in alluminio, ma storage PCIe 3.0 e RAM saldata limitano l'espandibilità. A 549 euro sfida brand più noti nella stessa fascia di mercato.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-06-2005, 12:29   #1
Gica78R
Senior Member
 
L'Avatar di Gica78R
 
Iscritto dal: Mar 2005
Messaggi: 1653
[C] Socket, funzioni listen/accept e max numero di connessioni attive

Ciao...
Avrei bisogno di un aiutino in merito ai socket... anzi, sulle due funzioni listen/accept.
Dalle man page si legge che la funzione int listen(int sockfd, int backlog), invocata sul socket 'sockfd', pone lo stesso socket nello stato LISTEN, e predispone una coda per le connessioni in arrivo di dimensioni pari al valore di backlog. La funzione int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen), invece, estrae una connessione dalla coda (se questa e' non vuota) e ritorna il descrittore di un nuovo socket.
Il parametro backlog, quindi, pone un limite soltanto al numero delle connessioni in attesa di essere accettate, superato il quale il client riceve un errore di ECONNREFUSED. Tutto cio', pero', non mi permette di controllare quante sono le connessioni STABILITE ed ACCETTATE dal sistema e di porvi un limite. Esistono funzioni che mi permettono di farlo?
Perche' mi serve? Perche' in un server proxy http con funzione di caching delle pagine richieste, la dimensione della cache e' limitata e se si verifica il caso della presenza contemporanea di un numero di client (quindi di connessioni) maggiore della dim della cache, e tutti questi client richiedono pagine differenti, c'e' un overflow delle strutture dati che tengono traccia delle pagine da scaricare. Vorrei quindi controllare costantemente quante sono le connessioni in corso (pari al num di processi figli che le gestiscono), e nel caso arrivasse una nuova richiesta quando ce ne sono gia' un certo numero, vorrei fare in modo che venisse rifiutata.
Avete suggerimenti?
Se mi sono spiegato male, cosa altamente probabile, ditemelo...

Grazie,
Gica

___Precisazione___
In realta' la dimensione della cache non e' vincolante; vincolante (nel senso che devo dimensionarla opportunamente) e' una piccola tabella, condivisa tra i processi, in cui sono elencati gli url delle pagine richieste dai client, in fase di ricerca/download e non ancora inserite nella cache. Quindi se ho modo di sapere quanti sono i client connessi e di regolarne il numero (ad esempio rifiutando la connessione a quelli in eccesso), posso dimensionare la tabella di cui sopra.

PS: auguratevi che non diventi mai ingegnere informatico, senno' so' cavoli
__________________
gica78r@ncc-1701:~$ tar -c
tar: Codardamente mi rifiuto di creare un archivio vuoto

Ultima modifica di Gica78R : 09-06-2005 alle 17:29.
Gica78R è offline   Rispondi citando il messaggio o parte di esso
Old 09-06-2005, 17:35   #2
Marinelli
Senior Member
 
L'Avatar di Marinelli
 
Iscritto dal: Aug 1999
Città: Tolmezzo (UD) - Milano
Messaggi: 13744
Ora non ci ho pensato con molta attenzione, ma io gestirei il tutto con un semplice contatore... qualora tu stia servendo n client (dove n è il tuo MAX) il server non esegue altre accept, poi quando un client si disconnette tu aggiorni n e lo fai diventare n-1 in modo che venga accettata un'altra connessione.

Ciao
__________________
...to go where no one has gone before.
One ring to rule them all, one ring to find them, one ring to bring them all and in darkness bind them.
Caron, non ti crucciare: vuolsi così colà dove si puote ciò che si vuole, e più non dimandare.
Marinelli è offline   Rispondi citando il messaggio o parte di esso
Old 09-06-2005, 17:51   #3
Gica78R
Senior Member
 
L'Avatar di Gica78R
 
Iscritto dal: Mar 2005
Messaggi: 1653
Quindi dovrei usare i segnali, in qualche modo... Ci stavo pensando, ma poi mi sono trovato davanti ad un dubbio, che ora ho dimenticato
Poiche' ciascuna connessione con i client e' gestita da un figlio, il contatore deve essere mantenuto nel padre, ovviamente. Quindi potrei incrementare il contatore dopo ciascuna accept e decrementarlo nel momento in cui un figlio termina (evento riconoscibile con qualche segnale, credo). Ecco, il problema e' proprio questo: mettere in attesa il padre quando il contatore raggiunge il massimo e' semplice; sbloccare il padre (e decrementare di 1 il contatore) non appena termina un figlio e' semplice; ma decrementare il contatore per ogni figlio che termina, anche quando il padre non e' bloccato? Si tratta di eventi asincroni: con un gestore di segnale si puo'? I segnali non li ho studiati molto bene... mi sa che mi tocca riparare.

Grazie,
Gica
__________________
gica78r@ncc-1701:~$ tar -c
tar: Codardamente mi rifiuto di creare un archivio vuoto
Gica78R è offline   Rispondi citando il messaggio o parte di esso
Old 09-06-2005, 23:46   #4
Marinelli
Senior Member
 
L'Avatar di Marinelli
 
Iscritto dal: Aug 1999
Città: Tolmezzo (UD) - Milano
Messaggi: 13744
A quest'ora non mi viene in mente nulla di semplice, anche perché è un problema che all'università non abbiamo affrontato. L'unica cosa semplice che mi viene in mente è gestire il contatore non come variabile in memoria, ma come file su disco, accessibile da tutti i processi.
Altrimenti potresti provare ad allocare della memoria condivisa, ma non ci ho mai provato: le funzioni che ti servono dovrebbero essere shmget, shmat, shmdt e shmctl.

Ciao
__________________
...to go where no one has gone before.
One ring to rule them all, one ring to find them, one ring to bring them all and in darkness bind them.
Caron, non ti crucciare: vuolsi così colà dove si puote ciò che si vuole, e più non dimandare.
Marinelli è offline   Rispondi citando il messaggio o parte di esso
Old 10-06-2005, 09:01   #5
Gica78R
Senior Member
 
L'Avatar di Gica78R
 
Iscritto dal: Mar 2005
Messaggi: 1653
Quote:
Originariamente inviato da Marinelli
A quest'ora non mi viene in mente nulla di semplice, anche perché è un problema che all'università non abbiamo affrontato. L'unica cosa semplice che mi viene in mente è gestire il contatore non come variabile in memoria, ma come file su disco, accessibile da tutti i processi.
Altrimenti potresti provare ad allocare della memoria condivisa, ma non ci ho mai provato: le funzioni che ti servono dovrebbero essere shmget, shmat, shmdt e shmctl.

Ciao
Infatti... Penso che faro' cosi'! Usero' una variabile condivisa come contatore, ed un paio di semafori: uno per l'accesso mutuamente esclusivo al contatore, l'altro per bloccare il processo padre non appena il contatore raggiunge il valore massimo. Il contatore sara' incrementato e decrementato da ciascun figlio rispettivamente all'inizio e prima dell'uscita.
E con questi due, i semafori che utilizzo diventano 10 Voglio ridere quando mi tocchera' dimostrare al prof. la correttezza dell'algoritmo di sincronizzazione

Grazie,
Gica
__________________
gica78r@ncc-1701:~$ tar -c
tar: Codardamente mi rifiuto di creare un archivio vuoto
Gica78R è offline   Rispondi citando il messaggio o parte di esso
Old 10-06-2005, 09:21   #6
Marinelli
Senior Member
 
L'Avatar di Marinelli
 
Iscritto dal: Aug 1999
Città: Tolmezzo (UD) - Milano
Messaggi: 13744
Mai utilizzato un semaforo in vita mia... in bocca al lupo per il professore

Ciao
__________________
...to go where no one has gone before.
One ring to rule them all, one ring to find them, one ring to bring them all and in darkness bind them.
Caron, non ti crucciare: vuolsi così colà dove si puote ciò che si vuole, e più non dimandare.
Marinelli è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Roborock Saros 20: il robot preciso e molto sottile Roborock Saros 20: il robot preciso e molto sott...
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
TCL perde in tribunale: quei TV 'QLED' n...
NVIDIA: la scarsità di hardware c...
Nintendo fa causa al governo USA per i d...
iPhone 17 256GB a 899€, MacBook Air 16/2...
C'è l'IA dietro la tua canzone pr...
Rocket Lab ha posticipato il lancio del ...
Dalla missione Artemis IV il razzo spazi...
Una delle sonde europee di ESA Proba-3 h...
Un modder fa girare Linux su PS5: GTA V ...
MacBook Neo: nessuna sorpresa nei primi ...
La serie POCO X8 Pro è pronta al ...
Smartphone: 2026 difficile per il mercat...
Star Wars: Knights of the Old Republic R...
Huang, NVIDIA: OpenClaw ha realizzato in...
Annunciano il recupero di 4,8 milioni di...
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: 11:21.


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