Post
#1
|
|
|
Grupa: Zarejestrowani Postów: 338 Pomógł: 2 Dołączył: 4.03.2006 Skąd: Łódź Ostrzeżenie: (0%)
|
Dawno mnie tu nie było (IMG:style_emoticons/default/smile.gif)
Forumowicze, problem z kolejką w PHP. System, który tworzę przetwarza dane co minutę (z CRONa). Niestety uruchomienie pojedynczego procesu np, przetwarzaj.php nie kończy się w 1 minucie, ponieważ przetwarzanie danych może trwać np. 2 mninuty dla pojedynczego rekordu bazy danych, a rekordów jest np. 20. Teoretycznie szeregowe uruchomienie przetwarzania zajmie więc 40 min. Każdy przetwarzaj.pho bierze z bazy zatem 1 rekord i tylko taki mieli. Moje pytanie: w jaki sposób napisać kolejkę, która poprawnie przetworzy takie dane? Wywołać z crona 20x ten sam przetwarzaj.php? Zanim proces zacznie wykonywać swoją pracę, ustawia na rekordzie bazy, że jest on przetwarzany, więc inny proces weźmie kolejne dane. Spotkaliście się z podobnym problemem, macie pomysły? |
|
|
|
![]() |
Post
#2
|
|
|
Grupa: Zarejestrowani Postów: 320 Pomógł: 29 Dołączył: 3.04.2010 Ostrzeżenie: (20%)
|
Nie zjedziemy, acz wytkniemy błąd.
Ten skrypt to tylko semafor zapobiegający uruchomieniu dwóch instancji tego skryptu. Autor natomiast chciałby równloegle przetwarzać te rekordy, rozłożyć je na kilka wątków (serwer jak autor pisał 16-rdzeniowy), dzięki czemu zadania będą się wykonywały równolegle. |
|
|
|
Prph Kolejka w PHP, 23.05.2012, 05:35:28
Crozin Podstawowe pytanie: czy przetworzenie kilku, np. m... 23.05.2012, 06:21:21
Prph Tak, przecież zostaną wykonane równolegle. Wykonaj... 23.05.2012, 06:39:57 
!*! Cytat(Prph @ 23.05.2012, 07:39:57 ) T... 23.05.2012, 07:01:57
hind Zły tok rozumowania... równoległe uruchomienie spw... 23.05.2012, 07:05:05
Prph No bez przesady. 16 rdzeni przetworzy szybciej 16 ... 23.05.2012, 07:17:50
Crozin To może inaczej, co jest powodem tak długiego prze... 23.05.2012, 07:23:40
Prph No to jest odpowiedź na wysokim poziomie
Proces ... 23.05.2012, 18:51:59
Crozin CytatProces nie obciąża procesora. Długo wykonuje ... 23.05.2012, 19:12:56
Niktoś Php z natury nie jest wielowątkowe(czyt.threading)... 23.05.2012, 19:14:15
Prph Zrobione za pomocą forkowania. Aż miło patrzeć jak... 24.05.2012, 06:19:42
Crozin Aż mnie coś wzięło, żeby zobaczyć jak można zrobić... 27.05.2012, 00:21:13
cezet Witajcie,
Pewnie mnie teraz zjedziecie, bo jak śm... 30.05.2012, 13:10:15
Crozin Cytat[...] procesy nie mogły działać równolegle.A ... 30.05.2012, 13:49:20
cezet Zwracam honor 30.05.2012, 14:12:33 ![]() ![]() |
|
Aktualny czas: 24.12.2025 - 04:59 |