|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Senior Member
Iscritto dal: Sep 2001
Città: Poppi (AR)
Messaggi: 764
|
php e sezione critica
ho un problema di sezione critica in php: voorei cioè evitare che la stessa parte di codice sia eseguita contemporaneamente da più utenti.
ho implementato la cosa in modo molto grossolano, atraverso un file di lock che "blocca" eventuali utenti in coda: while(file_exists(dirname(__FILE__) . "/lock1")); //lock file if (!file_exists(dirname(__FILE__) . "/lock1")) { touch(dirname(__FILE__) . "/lock1"); //**********SEZIONE PROTETTA************** } unlink(dirname(__FILE__) . "/lock1"); //releasing lock file volevo sapere se esiste qualche funzioncina php che evita il ricorso a un file di lock. inoltre la mia preoccupazione è questa: e se per sbaglio un utente interrompe la richiesta nella sezione protetta? non verrebbe eseguita la cancellazione del file, e gli utenti successivi si metterebbero a ciclare mel while appesantendo tra l'altro il server. è una preoccupazione infondata? c'è un modo per evitare il problema?
__________________
PaintedHomepage.com - Cicoandcico company la vera forza non sta nel non cadere mai, ma nel risollevarsi dopo una caduta. |
![]() |
![]() |
![]() |
#2 |
Senior Member
Iscritto dal: Sep 2001
Città: Poppi (AR)
Messaggi: 764
|
up
![]()
__________________
PaintedHomepage.com - Cicoandcico company la vera forza non sta nel non cadere mai, ma nel risollevarsi dopo una caduta. |
![]() |
![]() |
![]() |
#3 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Prova con questo: http://it.php.net/manual/en/function.sem-get.php
Altrimenti se hai a disposizione un DB MySQL puoi usare le funzioni di lock di MySQL (soluzione un po' brutta, ma sicura)... |
![]() |
![]() |
![]() |
#4 |
Senior Member
Iscritto dal: Sep 2001
Città: Poppi (AR)
Messaggi: 764
|
no, non posso usare mysql.
ai semafori avevo già pensato, ma dovrei ricompilare php... io lo posso anche fare ma gli utenti che useranno lo script no. inoltre mi sa che funzionerebbe solo sui server non MS, e se per me va benissimo, non so se si potrebbe dire altrettanto degli altri utenti.
__________________
PaintedHomepage.com - Cicoandcico company la vera forza non sta nel non cadere mai, ma nel risollevarsi dopo una caduta. |
![]() |
![]() |
![]() |
#5 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Infatti su Windows non è utilizzabile...
|
![]() |
![]() |
![]() |
#6 |
Senior Member
Iscritto dal: Sep 2001
Città: Poppi (AR)
Messaggi: 764
|
quindi come posso fare?
il mio come metodo funziona ma è grossolano, non elegante e pericoloso. e soprattutto (lo sto testando e sembra di no) secondo voi c'è il pericolo che il file di lock per qualche ragione non venga cancellato?
__________________
PaintedHomepage.com - Cicoandcico company la vera forza non sta nel non cadere mai, ma nel risollevarsi dopo una caduta. |
![]() |
![]() |
![]() |
#7 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Sinceramente non lo so...sicuramente il pericolo che non venga rimosso c'è...basta ad esempio che il server venga riavviato...
|
![]() |
![]() |
![]() |
#8 |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Infatti nel file di lock dovrebbe essere scritto il pid di chi lo ha creato. Chi vuole acquisire il lock, controlla che il pid esista (kill -0 <pid>); se non esiste, lo rimuove.
Un pò di codice in più ma tanta sicurezza in più; ho usato queste tecniche in programmi in c.
__________________
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: Sep 2001
Città: Poppi (AR)
Messaggi: 764
|
ok per il pid, ma si torna sempre lì: sui server windows come faccio per il pid?
accidenta a chi usa win 2003 e derivati: ma che se ne fanno? danno solo problemi agli sviluppatori!
__________________
PaintedHomepage.com - Cicoandcico company la vera forza non sta nel non cadere mai, ma nel risollevarsi dopo una caduta. |
![]() |
![]() |
![]() |
#10 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
DWORD GetCurrentThreadId(VOID);
Ma potresti anche scrivere l'HANDLE: HANDLE GetCurrentThread(VOID); |
![]() |
![]() |
![]() |
#11 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Ah ovviamente dovresti trovare il modo di usare le API...
|
![]() |
![]() |
![]() |
#12 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Altra idea...perchè non ci scrivi il SESSIONID ?!?!?
Ultima modifica di cionci : 08-10-2004 alle 18:14. |
![]() |
![]() |
![]() |
#13 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Altra idea: http://it.php.net/manual/en/function.flock.php
|
![]() |
![]() |
![]() |
#14 |
Senior Member
Iscritto dal: Sep 2001
Città: Poppi (AR)
Messaggi: 764
|
flock lo uso già ed è cosa buonissima, ma serve solo per la sezione critica nell'accesso a file. io, invece, voglio che sia protetta proprio una parte di codice.
il session_id invece mi sembra una buona idea, però come faccio a controllare che l'id esista? l'idea, infatti, sarebbe di controllare che l'id non sia registrato; e in questo caso eliminare il file di lock (vuol dire che il processo che ha creato il lock è terminato senza eliminarlo). in pratica, ci vorrebbe un equivalente php a kill -0. inoltre, il trucco funzionerebbe solo con utenti diversi: uno stesso utente (solito id) potrebbe comunque disturbare la sez critica! comunque, per la vostra curiosità, lo script che sto sviluppando è un contatore php free (www.cicoandcico.com/products.php). potete vederne un demo qui: www.cicoandcico.com/cccounter .
__________________
PaintedHomepage.com - Cicoandcico company la vera forza non sta nel non cadere mai, ma nel risollevarsi dopo una caduta. |
![]() |
![]() |
![]() |
#15 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Scusa, ma flock serve anche per evitare che due utenti entrino nella stessa sezione critica... Se il tentativo di fare flock riesce allora il programma entra in sezione critica, se fallisce non entra nella sezione critica, ma attende di entrarci...
Ah...studiala bene eprchè ci potrebbe essere starvation... |
![]() |
![]() |
![]() |
#16 |
Senior Member
Iscritto dal: Sep 2001
Città: Poppi (AR)
Messaggi: 764
|
come, non serve solo per i file?
eppure qui dice che: "flock() operates on handle which must be an open file pointer" ![]()
__________________
PaintedHomepage.com - Cicoandcico company la vera forza non sta nel non cadere mai, ma nel risollevarsi dopo una caduta. |
![]() |
![]() |
![]() |
#17 |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Sì usi un file convenzionale come "scusa" per effettuare il lock. Buona idea.
__________________
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 |
![]() |
![]() |
![]() |
#18 |
Senior Member
Iscritto dal: Sep 2001
Città: Poppi (AR)
Messaggi: 764
|
credo di non avere capito... cioè, io ho capito che mi proponete questo:
$file = fopen("lock", "w"); //puntatore a file flock ($file, LOCK_EX); //prende il lock <codice critico> flock($file, LOCK_UN); //rilascia il lock fclose($file); unlink($file); se ho capito bene, però, non sono sicuro che funzioni... non dovrebbe essere protetto solo l'accesso al file? cioè, se nella sez. critica ci fosse una print, questa non sarebbe protetta...?
__________________
PaintedHomepage.com - Cicoandcico company la vera forza non sta nel non cadere mai, ma nel risollevarsi dopo una caduta. |
![]() |
![]() |
![]() |
#19 |
Senior Member
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
|
Il punto non è cosa c'è nella sezione critica. Il punto è che due processi non possono prendere il lock contemporaneamente. Tu sfrutti questa cosa per creare una specie di "mutex", in modo da avere al massimo un unico processo nella sezione critica.
__________________
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 |
![]() |
![]() |
![]() |
#20 |
Senior Member
Iscritto dal: Sep 2001
Città: Poppi (AR)
Messaggi: 764
|
ahhhh...
quindi il codice che ho riportato sopra va bene?
__________________
PaintedHomepage.com - Cicoandcico company la vera forza non sta nel non cadere mai, ma nel risollevarsi dopo una caduta. |
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 20:57.