2009 Spalio 15
Tinklaraščių spartos optimizavimas
Povilas Balzaravičius
T*nklas, 2009
2 | 2009 Spalio 15 | Povilas Balzaravičius
Ką sužinosim?
 Optimizavimas

Techninė įranga (hardware)

Kliento pusė (fron...
| 2009 Spalio 15 | Povilas Balzaravičius3
Pradedam
4 | 2009 Spalio 15 | Povilas Balzaravičius
Techninė įranga
 Priemonės

Įdėkim daugiau RAM

Atnaujinkim procesorių

Nup...
5 | 2009 Spalio 15 | Povilas Balzaravičius
Vartotojo pusės optimizavimas
 80% generavimo laiko sugaištama vartotojo pusėj...
6 | 2009 Spalio 15 | Povilas Balzaravičius
HTTP užklausos
 1 elementas == 1 užklausa
 Užklausos mažina tinklapio krovimo...
7 | 2009 Spalio 15 | Povilas Balzaravičius
DNS užklausos (DNS lookups)
 DNS sieja domenus su IP adresais
 Naršyklė siunč...
8 | 2009 Spalio 15 | Povilas Balzaravičius
CSS ir JavaScript
 Kešuojama informacija
 Talpinti TIK išoriniuose failuose
...
9 | 2009 Spalio 15 | Povilas Balzaravičius
Serverio pusės optimizavimas
 Duomenų bazės neoptimizuosim
 Kodo netvarkysim
...
10 | 2009 Spalio 15 | Povilas Balzaravičius
Turinio kešavimas
 WP Super Cache
http://ocaoimh.ie/wp-super-cache/
 Saugo p...
11 | 2009 Spalio 15 | Povilas Balzaravičius
O kaip mano tinklaraštis?
 Paveiksliukus, JS, CSS ir kitą turinį talpinti ser...
| 2009 Spalio 15 | Povilas Balzaravičius12
Įrankiai
13 | 2009 Spalio 15 | Povilas Balzaravičius
Firebug
 Firefox priedas
 Analizuoja užklausas
14 | 2009 Spalio 15 | Povilas Balzaravičius
Firebug
 Pateikia detalią užklausų statistiką
15 | 2009 Spalio 15 | Povilas Balzaravičius
Google PageSpeed
 Analizuoja tinklapio turinį ir pateikia išvadas
16 | 2009 Spalio 15 | Povilas Balzaravičius
Yahoo YSlow
 Taip pat analizuoja turinį
17 | 2009 Spalio 15 | Povilas Balzaravičius
Yahoo YSlow statistika
18 | 2009 Spalio 15 | Povilas Balzaravičius
Yahoo YSlow įrankiai
19 | 2009 Spalio 15 | Povilas Balzaravičius
Resursai
 Best Practices for Speeding Up Your Web Site
http://developer.yahoo...
| 2009 Spalio 15 | Povilas Balzaravičius20
Klausimai?
21 | 2009 Spalio 15 | Povilas Balzaravičius
Kontaktai
 Povilas Balzaravičius
 http://pawka.linija.net/
 el. paštas: pov...
2009 Spalio 15
Ačiū!
Upcoming SlideShare
Loading in …5
×

Povilas Balzaravičius: Tinklaraščių spartos optimizavimas

1,066 views

Published on

Pristatymas skaitytas 2009 metais vykusios techninės tinklaraščių (ne)konferencijos metu.

Published in: Technology
0 Comments
0 Likes
Statistics
Notes
  • Be the first to comment

  • Be the first to like this

No Downloads
Views
Total views
1,066
On SlideShare
0
From Embeds
0
Number of Embeds
175
Actions
Shares
0
Downloads
3
Comments
0
Likes
0
Embeds 0
No embeds

No notes for slide
  • Kas yra frontendas?
    Kas yra backendas?
  • Techninės įrangos atnaujinimas paspartintų darbą serverio pusėje, bet (žr. diagramą).
    Serverio pusėje darbas atliekamas greitai. PHP ir MySQL rezultatus pateikia sparčiai.
    Duomenų siuntimas, apdorojimas ir palaipsninis jų atvaizdavimas, JavaScript vykdymas sunaudoja 80% laiko.
    40-60% Lankytojų užsuka pirmą kartą. Kalbant apie tinklaraščių lankytojus, šis procentas dar didesnis (60-80%). Jie neturi užkešintų duomenų ir naršyklės priverstos siųstis visą informaciją.
  • Kas vyksta naršyklėje atsidarius tinklapį?
    Siunčiamas turinys.
    Elementams naudojamos HTTP užklausos.
    Kuo paprastesnis dizainas, tuo mažiau elementų.
    Kai norisi dizaino, optimizuojam turinį.
  • Mažinam informacijos gavimą iš skirtingų serverių.
    Nuotraukas talpinam pas save, o ne kokiam imageshack.us.
    Nededam nereikalingų išorinių widgetų: mybloglog, skaitliukų ir pan. Jie įdomūs tik blogo autoriui, tačiau ne lankytojams.
    Jei reikia statistikos – naudojam vieną sistemą.
    Nenaudojam išorinių CSS ir JavaScript failų.
  • Kombinavimas:
    Pluginų ir wordpresso CSS failus galima sudėti į vieną failą. Taip bus sumažintas HTTP užklausų kiekis. Žinoma, tai pavyks, jei pagrindinis temos CSS failas nėra generuojamas automatiškai ar išvedamas PHP skripto. Tačiau netgi tokiu atveju, galima visus pluginų CSS'us talpinti į atskirą failą. Mačiau, lyg yra kažkokių WP įskiepių.
    YUI Compressor'ius berods nešalina komentarų.
  • Informaciją kešuojantys įskiepiai
    Reikia rinktis įskiepius, kurie turi kešavimo galimybę (gravatar, twitter, rss skaitytuvai ir t.t.)
    Vietoj išorinių servisų, dažnai paremtų JavaScript įterpimu į tinklapį, geriau naudoti vidinius įskiepus. Taip bus sumažintas HTTP užklausų kiekis.
  • Papasakoti apie Digg sindromą.
    Digg sindromas Lietuvoje nelabai aktualus, nebent per blogatoną :-)
  • Išoriniai JS widgetai stabdo tinklapio krovimą (tai matosi jei widgeto serveris ilgai negrąžina atsakymo – tinklapį sustoja renderint toje vietoje)
  • „Net“ tabas pateikia informaciją apie užklausas.
    Jas galima filtruoti pagal tipą.
    Matoma kokia tvarka, iš kur ir kiek laiko buvo kraunami elementai.
  • Analizuoja turinį ir pateikia rezultatus.
    Galima susikurti savo taisykles, nurodant į kokius dalykus kreipti dėmesį. Pvz. Blogams tikrai nereikalingi CDN.
  • Povilas Balzaravičius: Tinklaraščių spartos optimizavimas

    1. 1. 2009 Spalio 15 Tinklaraščių spartos optimizavimas Povilas Balzaravičius T*nklas, 2009
    2. 2. 2 | 2009 Spalio 15 | Povilas Balzaravičius Ką sužinosim?  Optimizavimas  Techninė įranga (hardware)  Kliento pusė (frontend)  Serverio pusė (backend)  Įrankiai
    3. 3. | 2009 Spalio 15 | Povilas Balzaravičius3 Pradedam
    4. 4. 4 | 2009 Spalio 15 | Povilas Balzaravičius Techninė įranga  Priemonės  Įdėkim daugiau RAM  Atnaujinkim procesorių  Nupirkim naują serverį  Tačiau...  Kainuoja $  Ne visada galime tai atlikti  Išspręs ne visas problemas
    5. 5. 5 | 2009 Spalio 15 | Povilas Balzaravičius Vartotojo pusės optimizavimas  80% generavimo laiko sugaištama vartotojo pusėje!  40-60% lankytojų užsuka tuščiu kešu.  Pirmas įspūdis formuoja nuomonę!  Atidžiai rinkitės tinklaraščio temą (išvaizdą).
    6. 6. 6 | 2009 Spalio 15 | Povilas Balzaravičius HTTP užklausos  1 elementas == 1 užklausa  Užklausos mažina tinklapio krovimo spartą  Mažinam užklausų kiekį!  Ką galime nuveikti?  Supaprastinti dizainą  Optimizuoti turinį
    7. 7. 7 | 2009 Spalio 15 | Povilas Balzaravičius DNS užklausos (DNS lookups)  DNS sieja domenus su IP adresais  Naršyklė siunčia užklausą serverio IP adresui gauti  Užklausa trunka 20-120 ms  Naršyklė negali siųsti kitos informacijos  DNS rezultatai kešuojami  Minimizuojam informacijos siuntimą iš skirtingų serverių!
    8. 8. 8 | 2009 Spalio 15 | Povilas Balzaravičius CSS ir JavaScript  Kešuojama informacija  Talpinti TIK išoriniuose failuose  Failų kombinavimas  Mažiau failų – mažiau užklausų  Kodo minifikavimas  Šalinami komentarai  Šalinami tarpai  YUI Compressor: http://developer.yahoo.com/yui/compressor/ Tinka JS ir CSS
    9. 9. 9 | 2009 Spalio 15 | Povilas Balzaravičius Serverio pusės optimizavimas  Duomenų bazės neoptimizuosim  Kodo netvarkysim  Informaciją kešuosim!  Informaciją kešuojantys įskiepiai  Tinklapio turinio kešavimas
    10. 10. 10 | 2009 Spalio 15 | Povilas Balzaravičius Turinio kešavimas  WP Super Cache http://ocaoimh.ie/wp-super-cache/  Saugo puslapio HTML versiją  Įskiepių informacijos kešavimo galimybė  Apsauga nuo „Digg sindromo“
    11. 11. 11 | 2009 Spalio 15 | Povilas Balzaravičius O kaip mano tinklaraštis?  Paveiksliukus, JS, CSS ir kitą turinį talpinti serveryje kartu su tinklaraščiu  Naudoti tik reikalingus įskiepius  Stengtis nenaudoti išorinių tarnybų, paremtų JavaScript ar <iframe> (Twitter, Last.fm, whois.among.us, Feedburner, ...)  Pasirinkti „lengvesnę“ tinklaraščio temą  WP Įskiepiai  Tag „performance“ - 35  Tag „caching“ - 15
    12. 12. | 2009 Spalio 15 | Povilas Balzaravičius12 Įrankiai
    13. 13. 13 | 2009 Spalio 15 | Povilas Balzaravičius Firebug  Firefox priedas  Analizuoja užklausas
    14. 14. 14 | 2009 Spalio 15 | Povilas Balzaravičius Firebug  Pateikia detalią užklausų statistiką
    15. 15. 15 | 2009 Spalio 15 | Povilas Balzaravičius Google PageSpeed  Analizuoja tinklapio turinį ir pateikia išvadas
    16. 16. 16 | 2009 Spalio 15 | Povilas Balzaravičius Yahoo YSlow  Taip pat analizuoja turinį
    17. 17. 17 | 2009 Spalio 15 | Povilas Balzaravičius Yahoo YSlow statistika
    18. 18. 18 | 2009 Spalio 15 | Povilas Balzaravičius Yahoo YSlow įrankiai
    19. 19. 19 | 2009 Spalio 15 | Povilas Balzaravičius Resursai  Best Practices for Speeding Up Your Web Site http://developer.yahoo.com/performance/rules.html  Yahoo YSlow http://developer.yahoo.com/yslow/  Google Page Speed http://code.google.com/speed/page-speed/  Firebug http://getfirebug.com/
    20. 20. | 2009 Spalio 15 | Povilas Balzaravičius20 Klausimai?
    21. 21. 21 | 2009 Spalio 15 | Povilas Balzaravičius Kontaktai  Povilas Balzaravičius  http://pawka.linija.net/  el. paštas: povilas.balzaravicius@gmail.com  Jabber: povilas.balzaravicius@gmail.com  IRC: Pawka @ Aitvaras / Freenode
    22. 22. 2009 Spalio 15 Ačiū!

    ×