![]() |
![]() ![]() |
![]() |
![]() ![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 367 Pomógł: 10 Dołączył: 20.05.2005 Ostrzeżenie: (0%) ![]() ![]() |
Chciałbym abyście podzielili się doświadczeniami pisania systemu cache.
Ja swój system rozwiązałem w ten sposób: 1. Podczas inicjowania klasy automatyczne skanowanie i usuwanie plikow ktorych czas wygasl. 2. Mozna tworzyc grupy i je konfigurowac(kodowanie,serializowanie,kompresja) 3. Dodawac mozna do grupy, lub trafia do grupy domyslnej 4. Usuwanie automatyczne lub manualne (calosc, grupa, kilka plikow, jeden plik) I teraz mam dylemat jak zrobic usuwanie przy zmianie tresci. jak narazie przy robieniu jakiegos update elementu daje funkcje do usuwania pliku cache jesli istnieje. W jaki sposob zrobic ze podczas szukania czy istnieje cache sprawdzac czy zawartosc elemntu zrodlowego nie zmienila sie? Jest to mozliwe jesli sie wygeneruje element i porowna z cache ale to mija sie z celem bo cache jest po to zeby ponownie sie nie generowalo. Druga sprawa to dane cache prywatne. Czy stosowac czy nie? Np. user dodaje newsa do ktorego mozna dolaczyc kilka zdjec, i teraz czy generowac za pomoca tego samego systemu cache, czyli jako nazwa dac id_sesji_zdjecie1,2,3 itd.. czy robic base64 i trzymac obrazek w zmiennej sesyjnej a potem go odczytac. Jak narazie moj system sprawuje sie dobrze. Np 1 pobranie z mysql 40 000 rekordow trwa 4,2s a kolejne dzieki systemu cache trwa 0,9 s Czyli w pliku cache trzyma 40 000 elementowa tablice i dla kazdego elementu dodatkowo po 3 wartosci (3 kolumny) i to wszystko odczytuje w 0,9 sec wiec chyba jest ok. Nie wiem jak to bedzie przy np 100 lub wiecej plikach cache z 10 grupami, jesli za kazdym wywolaniem strony bedzie robil skana zeby usuwac stare itd... Jak wy rozwiazaliscie ten problem? Pozdro |
|
|
![]()
Post
#2
|
|
![]() Grupa: Zarejestrowani Postów: 216 Pomógł: 0 Dołączył: 9.08.2003 Skąd: Warszawa Ostrzeżenie: (0%) ![]() ![]() |
Mam do ciebie pytanie, czy w praktyce bedziesz uzywal tablic 40 000 rzędowych? Myślę że nie. Np 5 ostatnich newsow... będziesz to cachował? Opłaca się? Ile na tym zaoszczędzisz czasu? Do news'a masz powiedzmy 1000 zdjęć... To i tak myśle, że użytkownik docelowy zobaczy 10-20 zdjęć + link do następnej strony...
![]() Poza tym popatrz jak to konkurenci rozwiązują. np spojz na eZ components, tam jest biblioteka z Cache - może ci coś podsunie na myśl. |
|
|
![]()
Post
#3
|
|
![]() Grupa: Moderatorzy Postów: 36 557 Pomógł: 6315 Dołączył: 27.12.2004 ![]() |
To i ja sie wypowiem, wkoncu Cache napisalem
![]() ad1) niepotrzebna operacja. Lepszym rozwiązaniem jest sprawdzanie waznosci cache podczas pobierania obiektu ad2) grupy to dobry pomysl. mam tak samo ad3) No popatrz, mam tak samo ad4) i usuwanie full, usuwanie grup, usuwanie konkretnych obiektow tez mam i to sa dobre metody. Choc pewnie usuwanie konkretnych obiektow (plikow) rzadko będzie sie zdazac Co do czyszczenia cache przy zmianie tresci. Jesli jako admin zmieniasz tresc, to usuwasz danych obiekt z cache i juz. Nie widze problemu. Pozatym jesli tworzysz cache z plikow, np. z xml, to czy sa zmiany mozesz sprawdzac po dacie utworzenia pliku. jego zawartosci nie trzeba sprawdzac. -------------------- "Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista "Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer |
|
|
![]()
Post
#4
|
|
Grupa: Zarejestrowani Postów: 367 Pomógł: 10 Dołączył: 20.05.2005 Ostrzeżenie: (0%) ![]() ![]() |
Co do zdjęć chodzilo mi dokladnie o formularz. Jest sytuacja że dodajemy newsa w panelu admina (w aplikacji jednoczesnie moze byc zalogowanych kilka adminow). Formularz ma pola: tytul,tresc itp + pole dodaj zdjecie, zdjecia dodaje sie kolejno ale newsa dodamy do bazy jak skonczymy wybierac zdjecia, i te zdjecia musze gdzies magazynowac a potem przy dodaniu dopiero je odczytuje i przenosze we wlasciwe miejsce. I chodzi o to czy uzywac do tego systemu cache czy trzymac w sesji zdjecia (zrobic bbase64) tylko ze nie wiem jaki jest limit mb dla sesji i czy to nie spowolni.
Hmm ale skanowanie i tak trzeba zrobic np zeby poszukac pliku cache, ja zrobilem tak ze podczas skanowania usuwam wygasniete elementy i zapisuje do tablicy te ktore sa aktywne, a potem na tablicach robie szukanie, wczytywanie itp Wiec jakies skanowanie w poszukiwaniu elementu musi byc a ja dodatkowo usuwam to co stare. Nie wiem jak ty to rozwiazales nospor |
|
|
![]()
Post
#5
|
|
![]() Grupa: Moderatorzy Postów: 36 557 Pomógł: 6315 Dołączył: 27.12.2004 ![]() |
No ale nie musisz skanowac w poszukiwaniu czegokolwiek. Cache z zalozenia ma byc szybki, a ty przeszukujesz od razy wszystko, a moze sie okazac ze skrypt bedzie chcial pobrac tylko jeden obiekt z cache. Moim zdaniem jest to bez sensu i nieoptymalne.
Skrypt mowi: chce obiekt X, to ty lecisz i bierzesz obiekt X. Oczywiscie najpierw sprawdzasz czy ten obiekt istnieje i czy jest nadal wazny. A jak ja to rozwiązalem to mozesz podejrzec. W mym podpisie masz wszystko co ci do tego potrzeba ![]() -------------------- "Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista "Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer |
|
|
![]()
Post
#6
|
|
Grupa: Zarejestrowani Postów: 367 Pomógł: 10 Dołączył: 20.05.2005 Ostrzeżenie: (0%) ![]() ![]() |
fakt nie, nie widziałem co to glob()" title="Zobacz w manualu php" target="_manual teraz wszystko się usprawni
![]() |
|
|
![]()
Post
#7
|
|
![]() Grupa: Moderatorzy Postów: 36 557 Pomógł: 6315 Dołączył: 27.12.2004 ![]() |
ale poco ci glob? Glob moze byc przydatne, gdy dany obiekt zalezy od kilku plikow. W innych przypadkach jest zbedne.
-------------------- "Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista "Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer |
|
|
![]()
Post
#8
|
|
Grupa: Zarejestrowani Postów: 367 Pomógł: 10 Dołączył: 20.05.2005 Ostrzeżenie: (0%) ![]() ![]() |
Ja wczesniej robilem opendir->readdir-> a pliki cache maja postrac nazwa,timeout.cache
przy szukaniu plikow znam jedynie nazwe a timeoutu nie znam. dzieki glob robie 'nazwa,*.cache' i mam juz pliczek a wczesniej robilem na piechote. Zastanawiam sie czy nie lepiej zrobic nazwa.cache pobierac czas utworzenia zpliku cache a timeout bezposrednio z grupy. Moze to jest lepsze rozwiazanie.... hmmm. |
|
|
![]()
Post
#9
|
|
![]() Grupa: Zarejestrowani Postów: 6 Pomógł: 0 Dołączył: 15.09.2002 Skąd: Nisko Ostrzeżenie: (0%) ![]() ![]() |
Ja mam taka krotka uwage co do sprawdzania timeoutu i usuwania wygaslych plikow. Kiedy ja robilem u siebie (o wiele prostszy, bez grup etc) system cachowania, usuwanie zrobilem na zasadzie cron'a. Jesli na serwerze jest dostep do crona, zwyczajnie wylaczasz w systemie calkowicie to usuwanie, zeby system nie musial za kazdym uruchomieniem sprawdzac czy pliki mu juz wyglasly, czy nie - co jest oczywiscie czasochlonne. Raz na jakis czas automatycznie odpalal sie skrypt w cronie, ktory przeszukiwal cala baze cache w poszukiwaniu wygaslych plikow i je usuwal. Chyba, ze mamy do czynienia z plikami o na prawde krotkiej waznosci, ale wtedy jaki sens stosowania cache?
Natomiast, jesli nie ma sie dostepu do crona, mozna zrobic rowniez tak, ze sprawdzanie wygasania zostanie odpalone jedynie np. przy pierwszej wizycie danego dnia (zakladajac, ze twoje cache'owane pliki maja waznosc dluzsza, niz doba), czy w danej godzinie. Wtedy kasujesz wszystko co przestarzale (nie powinno zabierac wiele czasu), a kolejne zcache'owanie tych plikow nastapi przy kolejnej probie ich odczytu. Nie jestem pewny czy to optymalne rozwiazanie, ale tak to sobie swego czasu wymyslilem, wiec przedstawiam moj pomysl na to ![]() -------------------- :: Przyb.net ::|:: Przyborowski.info ::
|
|
|
![]()
Post
#10
|
|
Grupa: Zarejestrowani Postów: 367 Pomógł: 10 Dołączył: 20.05.2005 Ostrzeżenie: (0%) ![]() ![]() |
Tak tylko ze tutaj operacje sa na sekundach wiec zeby wszystko bylo okej to co 1 sekunde musial byc uruchamiac Crona co przy duzej ilosci plikow cache moze obciazyc serwer, a tak jak nospor powiedzial cache ma byc szybki i ma odciazac serwer a nie go obciazac.
|
|
|
![]()
Post
#11
|
|
![]() Grupa: Zarejestrowani Postów: 67 Pomógł: 0 Dołączył: 13.09.2004 Ostrzeżenie: (0%) ![]() ![]() |
Ale mnie dawno nie było...
![]() Grupy to bardzo dobra rzecz w cache, szczególnie jak przyjdzie nim zarządzać. U mnie nie usuwam plików z cache, jako że jest on obiektem z metodą isValid(), potem sobie po prostu i ifie go uaktualniam. Mniejsze problemy dla systemów plików, w szczególności jeżeli system plików mamy inny niż reiserfs. Do usuwania etc. ogółem administracji są statyczne metody w CacheAdministrator. A grupowanie też mam chyba egzotycznie: obiekt jest zestawem zmiennych, zaś te zestawy też sobie grupuję tzn. mam cache co całego artykułu czy co tam będę chciał sobie cache'ować, zaś te wszystkie zestawy są w grupie articles/group/ gdzie group będzie grupą artykułów. Potem łatwo to się usuwa i administuje (CacheAdministrator::deleteGroup('articles'); albo CacheAdministrator::flushGroup() Kiedyś zamieściłem tutaj na for jakąś wczesną wersję tego cache... Ten post edytował Neotion 24.10.2006, 11:43:14 -------------------- current: nexcite cms (0.2.5) running on top of netsource framework (0.5.3)
workbench: nsapi | php 5.1.2 | mysql 5.0.18 | phpmyadmin 2.9 rc1 | zend studio 5.2.0 | apache/2.2.0 (linux/suse) |
|
|
![]()
Post
#12
|
|
![]() Grupa: Developerzy Postów: 823 Pomógł: 12 Dołączył: 18.12.2005 Ostrzeżenie: (0%) ![]() ![]() |
Powiem szczeże że dziwnie to zrobiłeś... ja mam po prostu:
(użycie podam przy publikacji okumentacji mojego frameworka)
-------------------- Portfolio: Vgroup.pl | athlan.pl | Test.php.pl - sprawdź się z wiedzy o PHP i ułóż własne pytania!
Pomogłem? Kliknij |
|
|
![]() ![]()
Post
#13
|
|
![]() Grupa: Zarejestrowani Postów: 569 Pomógł: 0 Dołączył: 17.08.2003 Skąd: Dąbrowa Górnicza Ostrzeżenie: (0%) ![]() ![]() |
a mam pytanie czy ktos probował robic cache na sqlite albo na memcache ?
-------------------- Warsztat: Linux: PHP, MySQL, Apache, NetBeans, C++, Qt-Creator
Użytkownik, słowo którego specjaliści IT używają, gdy chcą powiedzieć idiota Zarządzaj swoim budżetem domowym |
|
|
![]() ![]() |
![]() |
Wersja Lo-Fi | Aktualny czas: 13.08.2025 - 22:17 |