abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 17:44 | IT novinky

    Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) vydal Zprávu o stavu kybernetické bezpečnosti ČR za rok 2024 (pdf). V loňském roce NÚKIB evidoval dosud nejvíce kybernetických bezpečnostních incidentů s celkovým počtem 268. Oproti roku 2023 se však jedná pouze o drobný nárůst a závažnost dopadů evidovaných incidentů klesá již třetím rokem v řadě. V minulém roce NÚKIB evidoval pouze jeden velmi významný incident a významných incidentů bylo zaznamenáno 18, což oproti roku 2023 představuje pokles o více než polovinu.

    Ladislav Hagara | Komentářů: 0
    dnes 13:55 | Komunita

    Byl publikován aktuální přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie). Servo mimo jiné nově zvládne animované obrázky APNG a WebP.

    Ladislav Hagara | Komentářů: 0
    dnes 13:11 | IT novinky

    Na chytré telefony a počítačové tablety v Rusku bude od začátku příštího měsíce povinné předinstalovávat státem podporovanou komunikační aplikaci MAX, která konkuruje aplikaci WhatsApp americké společnosti Meta Platforms. Oznámila to dnes ruská vláda. Ta by podle kritiků mohla aplikaci MAX používat ke sledování uživatelů. Ruská státní média obvinění ze špehování pomocí aplikace MAX popírají. Tvrdí, že MAX má méně oprávnění k přístupu k údajům o uživatelích než konkurenční aplikace WhatsApp a Telegram.

    Ladislav Hagara | Komentářů: 18
    dnes 04:22 | IT novinky

    Společnost PINE64 stojící za telefony PinePhone nebo notebooky Pinebook publikovala na svém blogu srpnový souhrn novinek. Kvůli nedostatečnému zájmu byla ukončena výroba telefonů PinePhone Pro.

    Ladislav Hagara | Komentářů: 1
    včera 22:22 | Nová verze

    Po pěti měsících vývoje byla vydána nová verze 0.15.1 programovacího jazyka Zig (GitHub, Wikipedie). Verze 0.15.0 byla přeskočena. Přispělo 162 vývojářů. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 21:55 | Komunita

    Před sedmi lety společnost Valve představila fork projektu Wine s názvem Proton umožňující v Linuxu přímo ze Steamu hrát počítačové hry do té doby běžící pouze ve Windows. Aktuální přehled podporovaných her na stránkách ProtonDB

    Ladislav Hagara | Komentářů: 0
    včera 14:55 | IT novinky

    Společnost DuckDuckGo rozšířila svůj AI chat Duck.ai o GPT-5 mini (𝕏). Duck.ai umožňuje anonymní přístup bez vytváření účtů k několika modelům umělé inteligence. Aktuálně k GPT-4o mini, GPT-5 mini, Llama 4 Scout, Claude Haiku 3.5 a Mistral Small 3.

    Ladislav Hagara | Komentářů: 5
    včera 12:44 | Bezpečnostní upozornění

    Marek Tóth v příspěvku DOM-based Extension Clickjacking: Data ve správcích hesel v ohrožení na svém blogu popsal novou clickjacking techniku s několika variantami útoků a otestoval ji proti 11 správcům hesel. Výsledkem bylo nalezení několika 0-day zranitelností, které mohly ovlivnit uložená data desítek milionů uživatelů. Jedno kliknutí kdekoliv na webové stránce kontrolované útočníkem umožňovalo ukrást uživatelská data ze

    … více »
    Ladislav Hagara | Komentářů: 1
    20.8. 21:11 | IT novinky

    Na dnešní akci Made by Google 2025 (YouTube) byly představeny telefony Pixel 10 s novým čipem Google Tensor G5 a novými AI funkcemi, hodinky Pixel Watch 4 a sluchátka Pixel Buds 2a.

    Ladislav Hagara | Komentářů: 25
    20.8. 14:11 | Nová verze

    The Document Foundation oznámila vydání nové major verze 25.8 svobodného kancelářského balíku LibreOffice. Podrobný přehled nových vlastností i s náhledy v poznámkách k vydání (cs) a také na Youtube a PeerTube.

    Ladislav Hagara | Komentářů: 17
    Pro otevření více webových stránek ve webovém prohlížečí používám
     (74%)
     (11%)
     (4%)
     (4%)
     (6%)
     (0%)
    Celkem 47 hlasů
     Komentářů: 6, poslední včera 13:35
    Rozcestník

    Optimalizácia výkonu šablónovacieho systému django

    4.11.2012 19:52 | Přečteno: 1561× | Programovanie | Výběrový blog | poslední úprava: 4.11.2012 19:51

    Na internete je možné nájsť množstvo syntetických benchmarkov šablónovacích systémov. Tieto výsledky môžu byť relevantné v prípade generovania veľkých výstupov. Väčšinou nás však bude zaujímať celková priepustnosť aplikácie. V dnešnom blogu si teda ukážeme vplyv rôznych metód optimalizácie od cachovania po zmenu interpreta pythonu na celkovú priepustnosť reálnej webovej aplikácie.

    Na začiatok než sa pustíme do samotného benchmarkovania môžme nahliadnuť na syntetické benchmarky. Vzhľadom na to, že ostatné testované šablónovacie systémy sú aspoň čiastočne napísané v C sú rozdiely oproti djangu priepastné. Rozdiel vo výkone medzi natívnou aplikáciou a aplikáciou v pythone je stále veľký aj pri použití JIT, preto budú mať ostatné šabĺónovacie systémy lepšiu priepustnosť aj napriek maximálnej snahe o zrýchlenie šablón django.

    Webová aplikácia

    Pri testoch som používal skutočnú webovú aplikáciu. Do nej bola importovaná databáza, ktorej dump mal veľkosť ~130MB. Ako databázový server som použil PostgreSQL 9.1. Celé to beží na stroji s procesorom T5250, 2GB RAM a pomalým diskom hitachi (thinkpad) pod gentoo.

    Spôsob merania výkonu

    Webová aplikácia bola spúšťaná pomocou vstavaného webového serveru na porte 8000 (django-admin.py runserver 0.0.0.0:8000). Benchmarky boli vykonávané programom ab2 (Apache HTTP server benchmarking tool). Testy sa vykonávali príkazom ab2 -n 1000 -c 1 'http://localhost:8000/', kde n je počet opakovaní (v testoch bolo použitých vždy 1000 opakovaní) a c je počet súčasných požiadaviek (server beží v jedinom vlákne, preto nemá zmysel použiť viacej súčasných požiadaviek).

    Pred vykonaním testov pod CPythonom bolo vykonaných 20 požiadaviek, aby sa ustálili hodnoty (kvôli naplneniu cache). Testy vykonávané pod PyPy boli spustené až po 2000 požiadavkách, pretože JIT kompilátor potrebuje dosť času na optimalizáciu.

    Celková odozva aplikácie a čas strávený renderovaním

    Nástroj používaný pri renderovaní (ab2) neumožňuje rozlíšiť čas renderovania šablóny od réžie samotného djanga a jeho ORM. Preto som najskôr vykonal benchmarky, kde som namiesto renderovania šablóny vrátil prázdnu odpoveď. Namerané priemerné časy pre vykonanie požiadavky sú v nasledujúcej tabuľke.

    Réžia djanga (v ms)

    Vypnuté cachovanie modelu Zapnuté cachovanie modelu
    CPython PyPy CPython PyPy
    56,037 52,127 8,927 6,402
    Rozdelenie časov odpovede na požiadavku

    Čistý čas renderovania šablóny sa vypočíta odčítaním tejto hodnoty od nameranej celkovej hodnoty požiadavky.

    Žiadna optimalizácia

    Bez akejkoľvek optimalizácie sú šablóny skutočne veľmi pomalé. Hlavným dôvodom je fakt, že šablóny sa pri každej požiadavke parsujú. Pre náš testovací projekt je čas 210,161 ms (4,76 požiadavky/s) pre CPython, alebo 128,281 ms (7,80 požiadavky/s) pre PyPy.

    Zapnuté cachovanie modelu

    Cachovaním modelu je možné dosiahnuť situáciu, keď django nepotrebuje vôbec, alebo takmer vôbec spojenie s databázou. Na testovacom projekte bol pred zapnutím cachovania vykonaný SQL dotaz 10x pre jedinú požiadavku. Po zapnutí sa spojenie s databázou nepoužívalo vôbec (0 SQL dotazov). Zapnutím cachovania modelov sa aplikácia priemerne zrýchlila o 47,442 ms v CPythone, alebo 47,649 ms v PyPy.

    Zapnuté cachovanie šablón

    Po zapnutí cachovania šablón sa budú parsované šablóny uchovávať v RAM. Štandardne je táto možnosť vypnutá, pretože zmena šablón si v takom prípade vyžaduje reštart webovej aplikácie. Zapnúť sa dá v settings.py nasledujúcim kódom:

    TEMPLATE_LOADERS = ...
    ...
    TEMPLATE_LOADERS = (
        ('django.template.loaders.cached.Loader', TEMPLATE_LOADERS),
    )
    

    Táto metóda zrýchlila renderovanie o 76,006 ms pre CPython, alebo 39,551 ms pre PyPy.

    Kompilované šablóny

    Slovo „kompilované“ v nadpise je tak trochu zavádzajúce pretože v skutočnosti som skúmal len spracovanie šablón do takého tvaru, aby sa rýchlejšie renderovali (ide teda vlastne len o preprocessing napriek tomu, že dokumentácia modulu django-template-preprocessor hovorí o kompilácii). Spracovanie šablón modulom django-template-preprocessor odstráni zo šablón niektoré direktívy ako extends a nahradí ich kódom z pôvodnej šablóny, odstráni whitespace, zoskupí direktívy load … Výsledkom je šablóna, ktorú by malo django spracovať rýchlejšie než pôvodnú šablónu. Po nainštalovaní sa dá preprocesor aktivovať nasledujúcim kódom v settings.py:

    INSTALLED_APPS += ('template_preprocessor',)
    TEMPLATE_LOADERS = (
        ('template_preprocessor.template.loaders.PreprocessedLoader',
            TEMPLATE_LOADERS
        ),
    )
    

    Následne sa musia šablóny spracovať príkazom python manage.py compile_templates.

    Zrýchlenie pri tejto metóde je 107,347 ms v CPythone, alebo 38,883 ms v PyPy.

    Dvojfázové renderovanie

    Pri tejto metóde sa šablóna renderuje 2x. Prvý krát sa vyrenderujú časti, ktoré sú spoločné pre všetkých návšetevníkov webu. Dynamické prvky sa ponechajú v pôvodnom stave. Vyrenderovaná šablóna sa uloží do cache a bude sa používať pre všetkých návštevníkov. Počas spracovania šablóny sa už vyrenderujú len časti, ktoré sú dynamicky generované pre konkrétneho návštevníka.

    Pre CPython bolo s touto metódou namerané zrýchlenie o 151,776 ms a pre PyPy 65,859 ms.

    Porovnanie

    V nasledujúcich tabuľkách je porovnanie metód optimalizácie a ich kombinácie.

    Celkový čas

    Porovnanie celkového času spracovania požiadavky

    Porovnanie priemerných časov načítania (v ms)

    Metóda Vypnuté cachovanie modelu Zapnuté cachovanie modelu
    CPython PyPy CPython PyPy
    Žiadna optimalizácia 210,161 128,281 163,768 82,805
    Zapnuté cachovanie 134,733 90,234 87,185 41,750
    Kompilované šablóny 103,501 91,491 55,735 41,829
    Dvojfázové renderovanie 59,219 63,172 11,159 16,197

    Renderovanie šablóny

    Porovnanie času renderovania šablóny

    Porovnanie časov renderovania šablóny (v ms)

    Metóda Vypnuté cachovanie modelu Zapnuté cachovanie modelu
    CPython PyPy CPython PyPy
    Žiadna optimalizácia 154,124 76,154 154,841 76,403
    Zapnuté cachovanie 78,696 38,107 78,258 35,348
    Kompilované šablóny 47,464 39,364 46,808 35,427
    Dvojfázové renderovanie 3,182 11,045 2,232 9,795

    Šablónovací systém v django, alebo iný?

    Renderovanie šablóny môže podstatne ovplyvniť rýchlosť webovej aplikácie. V prípade jednoduchých šablón bude bude čas renderovania s veľkou pravdepodobnosťou zanedbateľný. U komplexných webov bude podiel renderovania šablóny na celkovom čase vyšší.

    Pri malých weboch programátor ťažko narazí na problém s pomalosťou šablón. U stredne veľkých webov je možné použiť niektorý zo spôsobov optimalizácie a stále mať výhody integrovaného šablónovacieho systému (administrátorské rozhranie, dobrá integrácia s ďalšími aplikáciami …). U veľkých webov s vysokou záťažou, kde záleží na každom takte procesora bude pravdepodobne jedinou schodnou cestou použitie iného šablónovacieho systému.

           

    Hodnocení: 100 %

            špatnédobré        

    Obrázky

    Optimalizácia výkonu šablónovacieho systému django, obrázek 1 Optimalizácia výkonu šablónovacieho systému django, obrázek 2

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    limit_false avatar 4.11.2012 22:45 limit_false | skóre: 23 | blog: limit_false
    Rozbalit Rozbalit vše Re: Optimalizácia výkonu šablónovacieho systému django
    Pamatuju si, že výkon Django šablonovacího rendereru byl v 0.9x a 1.0x celkem nevýrazný, vypadá to, že se to moc nezměnilo.

    Dva tipy pro ladění Django aplikací:
    1. Django Debug Toolbar (pozor ale, samotné použití toolbaru ovlivňuje měření "násobící konstantou")
    2. cProfile/hotshot + pyprof2calltree + kcachegrind, sample callgraph screenshot (bohužel už nemám to měření šablonovacího systému)
    Jedna rychlejší alternativa byl Teng (neumím teď vygooglit ne-obsolete stránku) i když nebyl až tak "pěkný/mocný". S trochou štěstí snad už nikdy nebudu muset psát žádné weby :-)
    When people want prime order group, give them prime order group.
    mirec avatar 5.11.2012 07:33 mirec | skóre: 32 | blog: mirecove_dristy | Poprad
    Rozbalit Rozbalit vše Re: Optimalizácia výkonu šablónovacieho systému django

    V roku 2011 som videl na šablóny GSoC projekt, ale zrejme sa to nijako ďalej nepohlo.

    LinuxOS.sk | USE="-fotak -zbytocnosti -farebne_lcd +vydrz +odolnost +java" emerge telefon
    5.11.2012 08:57 rocky
    Rozbalit Rozbalit vše Re: Optimalizácia výkonu šablónovacieho systému django
    Here is another benchmark: http://mindref.blogspot.com/2012/10/python-templates-benchmark.html
    5.11.2012 09:01 rocky
    Rozbalit Rozbalit vše Re: Optimalizácia výkonu šablónovacieho systému django
    Few more: reverse-urls and routing, caching.
    5.11.2012 10:52 vincentk
    Rozbalit Rozbalit vše Re: Optimalizácia výkonu šablónovacieho systému django
    Ten system vie predpovedat buducnost? Ako to ze zacal prudko narastat testne pred koncom?
    mirec avatar 5.11.2012 10:57 mirec | skóre: 32 | blog: mirecove_dristy | Poprad
    Rozbalit Rozbalit vše Re: Optimalizácia výkonu šablónovacieho systému django
    Nie je to nárast, je to rozdelenie. Ak sa pozriem napr. na hodnotu 900 tak 900‰ požiadaviek sa vojde pod túto hodnotu. Akurát spline vyhladzovanie trochu vpravo **** krivku čo som si nevšimol.
    LinuxOS.sk | USE="-fotak -zbytocnosti -farebne_lcd +vydrz +odolnost +java" emerge telefon
    8.11.2012 19:52 yad
    Rozbalit Rozbalit vše Re: Optimalizácia výkonu šablónovacieho systému django
    To dvojfázové renderovanie vyzerá veľmi dobre.

    Zo zvedavosti: ako funguje to dvojfázové renderovanie?
    mirec avatar 8.11.2012 21:01 mirec | skóre: 32 | blog: mirecove_dristy | Poprad
    Rozbalit Rozbalit vše Re: Optimalizácia výkonu šablónovacieho systému django

    Existuje na to niekoľko modulov, o ich kvalite moc neviem. Implementovať sa to dá aj vlastnoručne a nie je to zložité. Pre pohodlnosť sa budem hrať na to, že django obsahuje tag raw (existuje jednoduchá implementácia).

    V podstate sa celá časť, ktorá je spoločná pre všetkých užívateľov vyrenderuje normálne. Časti ktoré sú rozdielne ako napr. odkaz na profil sa uzatvoria do tagu {% raw %}. Táto šablóna sa uloží do cache a používa pre všetkých užívateľov. Pre konkrétneho užívateľa sa bude renderovať už len predpripravená šablóna.

    LinuxOS.sk | USE="-fotak -zbytocnosti -farebne_lcd +vydrz +odolnost +java" emerge telefon
    9.11.2012 20:23 yad
    Rozbalit Rozbalit vše Re: Optimalizácia výkonu šablónovacieho systému django
    Zaujímavé riešenie. Pre LinuxOS ako šíte na mieru :). Skvelá práca.

    Ale štve ma, že to je pre mňa nepoužíteľné.
    11.11.2012 13:12 suic
    Rozbalit Rozbalit vše Re: Optimalizácia výkonu šablónovacieho systému django

    OT:

    Ake vim pluginy pouzivas?

    Vdaka

    mirec avatar 11.11.2012 21:26 mirec | skóre: 32 | blog: mirecove_dristy | Poprad
    Rozbalit Rozbalit vše Re: Optimalizácia výkonu šablónovacieho systému django
    git://github.com/tpope/vim-pathogen.git
    git://github.com/MarcWeber/vim-addon-mw-utils.git
    git://github.com/vim-scripts/tlib.git
    git://github.com/vim-scripts/project.tar.gz.git
    git://github.com/vim-scripts/Align.git
    git://github.com/mjbrownie/pythoncomplete.vim.git
    git://github.com/Rip-Rip/clang_complete.git
    git://github.com/vim-scripts/errormarker.vim.git
    git://github.com/tpope/vim-fugitive.git
    git://github.com/kevinw/pyflakes-vim.git
    git://github.com/Lokaltog/vim-powerline.git
    git://github.com/mattn/zencoding-vim.git
    git://github.com/MarcWeber/vim-addon-local-vimrc.git
    git://github.com/sjl/gundo.vim.git
    git://github.com/shawncplus/phpcomplete.vim.git
    git://github.com/majutsushi/tagbar.git
    git://github.com/vim-scripts/a.vim.git
    git://github.com/SirVer/ultisnips.git
    git://github.com/vim-scripts/bufferlist.vim.git
    

    Hádam som na nič nezabudol ;)

    LinuxOS.sk | USE="-fotak -zbytocnosti -farebne_lcd +vydrz +odolnost +java" emerge telefon

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.