Caching and tuning fun for high scalability @ FrOSCon 2011
Upcoming SlideShare
Loading in...5
×

Like this? Share it with your network

Share

Caching and tuning fun for high scalability @ FrOSCon 2011

  • 2,927 views
Uploaded on

"Caching and tuning fun for high scalability" talk at FrOSCon 2011 ...

"Caching and tuning fun for high scalability" talk at FrOSCon 2011

Twitter : @wimgtr

More in: Technology
  • Full Name Full Name Comment goes here.
    Are you sure you want to
    Your message goes here
    Be the first to comment
No Downloads

Views

Total Views
2,927
On Slideshare
2,878
From Embeds
49
Number of Embeds
3

Actions

Shares
Downloads
79
Comments
0
Likes
2

Embeds 49

http://lanyrd.com 44
http://us-w1.rockmelt.com 3
https://twitter.com 2

Report content

Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
    No notes for slide

Transcript

  • 1. Caching and tuning fun for high scalability Wim Godden Cu.be Solutions
  • 2. Notes about this presentation
      This presentation was part of the FrOSCon 2011 program. It was designed to presented live and as a result many of the slides may seem odd without spoken explanation. The live benchmarks at the conference are ofcourse also not part of these slides.
  • 3. Who am I ?
    • Wim Godden (@wimgtr)
    • 4. Owner of Cu.be Solutions (http://cu.be)
    • 5. PHP developer since 1997
    • 6. Developer of OpenX
    • 7. Zend Certified Engineer
    • 8. Zend Framework Certified Engineer
    • 9. MySQL Certified Developer
  • 10. Who are you ?
    • Developers ?
    • 11. System/network engineers ?
    • 12. Managers ?
    • 13. Caching experience ?
  • 14. Caching and tuning fun for high scalability Wim Godden Cu.be Solutions
  • 15. Goals of this tutorial
    • Everything about caching and tuning
    • 16. A few techniques
    • -> Increase reliability, performance and scalability
    • 18. 5 visitors/day -> 5 million visitors/day
    • 19. (Don't expect miracle cure !)
  • 20. LAMP
  • 21. LAMP
  • 22. Architecture
  • 23. Our test site
  • 24. Our base benchmark
    • Apachebench = useful enough
    • 25. Result ?
  • 26. Caching
  • 27. What is caching ?
  • 28. What is caching ? select * from article join user on article.user_id = user.id order by created desc limit 10
  • 29. Caching goals
    • Source of information (db, file, webservice, …) :
      • Reduce # of request
      • 30. Reduce the load
    • Latency :
      • Reduce for visitor
      • 31. Reduce for Webserver load
    • Network :
      • Send less data to visitor
      • 32. Hey, that's frontend !
  • 33. Theory of caching DB
  • 34. Theory of caching DB
  • 35. Theory of caching if ($data == false) DB
  • 36. Caching techniques
      #1 : Store entire pages
    • Company Websites
    • 37. Blogs
    • 38. Full pages that don't change
    • 39. Render -> Store in cache -> retrieve from cache
  • 40. Caching techniques
      #1 : Store entire pages
  • 41. Caching techniques
      #2 : Store parts of a page
    • Most common technique
    • 42. Usually a small block in a page
    • 43. Best effect : reused on lots of pages
  • 44. Caching techniques
      #2 : Store parts of a page
  • 45. Caching techniques
      #3 : Store SQL queries
    • ↔ SQL query cache
        • Limited in size
  • 46. Caching techniques
      #3 : Store SQL queries
    • ↔ SQL query cache
        • Limited in size
        • 47. Resets on every insert/update/delete
        • 48. Server and connection overhead
    • Goal :
      • not to get rid of DB
      • 49. free up DB resources for more hits !
  • 50. Caching techniques
      #3 : Store SQL queries
  • 51. Caching techniques
      #4 : Store complex processing results
    • Not just calculations
    • 52. CPU intensive tasks :
      • Config file parsing
      • 53. XML file parsing
      • 54. Loading CSV in an array
    • Save resources -> more resources available
  • 55. Caching techniques
      #4 : Store complex processing results
  • 56. Caching techniques
      #xx : Your call Only limited by your imagination ! When you have data, think :
    • Creating time ?
    • 57. Modification frequency ?
    • 58. Retrieval frequency ?
  • 59. How to find cacheable data
    • New projects : start from 'cache everything'
    • 60. Existing projects :
      • Look at MySQL slow query log
      • 61. Make a complete query log (don't forget to turn it off !)
      • 62. Check page loading times
  • 63. Caching storage - MySQL query cache
    • Use it
    • 64. Don't rely on it
    • 65. Good if you have :
      • lots of reads
      • 66. few different queries
    • Bad if you have :
      • lots of insert/update/delete
      • 67. lots of different queries
  • 68. Caching storage - Disk
    • Data with few updates : good
    • 69. Caching SQL queries : preferably not
    • 70. DON'T use NFS or other network file systems
      • especially for sessions
      • 71. high latency
      • 72. locking issues !
  • 73. Caching storage - Disk / ramdisk
    • Overhead : filesystem access
    • 74. Limited number of files per directory
      • -> Subdirectories
    • Local
      • 5 Webservers -> 5 local caches
      • 75. -> Hard to scale
      • 76. How will you keep them synchronized ?
        • -> Don't say NFS or rsync !
  • 77. Caching storage - Memcache
    • Facebook, Twitter, Slashdot, … -> need we say more ?
    • 78. Distributed memory caching system
    • 79. Multiple machines ↔ 1 big memory-based hash-table
    • 80. Key-value storage system
      • Keys - max. 250bytes
      • 81. Values - max. 1Mbyte
  • 82. Caching storage - Memcache
    • Facebook, Twitter, Slashdot, … -> need we say more ?
    • 83. Distributed memory caching system
    • 84. Multiple machines ↔ 1 big memory-based hash-table
    • 85. Key-value storage system
      • Keys - max. 250bytes
      • 86. Values - max. 1Mbyte
    • Extremely fast... non-blocking, UDP (!)
  • 87. Memcache - where to install
  • 88. Memcache - where to install
  • 89. Memcache - installation & running it
    • Installation
      • Distribution package
      • 90. PECL
      • 91. Windows : binaries
    • Running
      • No config-files
      • 92. memcached -d -m <mem> -l <ip> -p <port>
      • 93. ex. : memcached -d -m 2048 -l 127.0.0.1 -p 11211
  • 94. Caching storage - Memcache - some notes
    • Not fault-tolerant
  • 98. Caching storage - Memcache - some notes
    • Not fault-tolerant
    • Different libraries
      • Original : libmemcache
      • 102. New : libmemcached (consistent hashing, UDP, binary protocol, …)
    • Firewall your Memcache port !
  • 103. Memcache in code <?php $memcache = new Memcache(); $memcache->addServer( '172.16.0.1' , 11211); $memcache->addServer( '172.16.0.2' , 11211); $myData = $memcache->get( 'myKey' ); if ($myData === false ) { $myData = GetMyDataFromDB(); // Put it in Memcache as 'myKey', without compression, with no expiration $memcache->set( 'myKey' , $myData, false , 0); } echo $myData;
  • 104. Let's give that a go ! /** * Retrieves the 10 highest rated articles * @return array List of highest rated articles */ static public function getTopRatedArticleList () { if ($articleList = $cache->load( 'topRatedArticleList' ) === false) { $articleList = self :: getTopRatedArticleListUncached (); $cache->save($articleList, 'topRatedArticleList' ); } return $articleList; }
  • 105. Where's the data ?
    • Memcache client decides (!)
    • 106. 2 hashing algorithms :
      • Traditional
        • Server failure -> all data must be rehashed
      • Consistent
        • Server failure -> 1/x of data must be rehashed (x = # of servers)
    • No replication !
  • 107. Memcache slabs
      (or why Memcache says it's full when it's not)
    • Multiple slabs of different sizes :
      • Slab 1 : 400 bytes
      • 108. Slab 2 : 480 bytes (400 * 1.2)
      • 109. Slab 3 : 576 bytes (480 * 1.2) (and so on...)
    • Multiplier (1.2 here) can be configured
    • 110. Each larger slab has room for fewer items (chunks)
    • 111. -> Store a lot of very large objects
    • 112. -> Large slabs might be full
    • 113. -> Rest of slabs might be free
    • 114. -> Try to store more -> eviction of data !
  • 115. Memcache - Is it working ?
    • Connect to it using telnet
      • &quot;stats&quot; command ->
      • 116. Use Cacti or other monitoring tools
    STAT pid 2941 STAT uptime 10878 STAT time 1296074240 STAT version 1.4.5 STAT pointer_size 64 STAT rusage_user 20.089945 STAT rusage_system 58.499106 STAT curr_connections 16 STAT total_connections 276950 STAT connection_structures 96 STAT cmd_get 276931 STAT cmd_set 584148 STAT cmd_flush 0 STAT get_hits 211106 STAT get_misses 65825 STAT delete_misses 101 STAT delete_hits 276829 STAT incr_misses 0 STAT incr_hits 0 STAT decr_misses 0 STAT decr_hits 0 STAT cas_misses 0 STAT cas_hits 0 STAT cas_badval 0 STAT auth_cmds 0 STAT auth_errors 0 STAT bytes_read 613193860 STAT bytes_written 553991373 STAT limit_maxbytes 268435456 STAT accepting_conns 1 STAT listen_disabled_num 0 STAT threads 4 STAT conn_yields 0 STAT bytes 20418140 STAT curr_items 65826 STAT total_items 553856 STAT evictions 0 STAT reclaimed 0
  • 117. Memcache - backing up
  • 118. Memcache - deleting <?php $memcache = new Memcache(); $memcache->delete( 'myKey' ); $myData = $memcache->get( 'myKey' ); // $myData === false
  • 119. Memcache - tip
      Page with multiple blocks ? -> use Memcached::getMulti() Warning : what if you get some hits and some misses ?
  • 120. Naming your keys
    • Key names must be unique
    • 121. Prefix / namespace your keys !
    • 122. Only letters, numbers and underscore
    • 123. md5() is useful
      • -> BUT : harder to debug
    • Use clear names
    • 124. Document your key names !
  • 125. Updating data
  • 126. Updating data
  • 127. Adding/updating data $memcache->delete( 'ArticleDetails__Toshiba_32C100U_32_Inch' ); $memcache->delete( 'Homepage_Popular_Product_List' );
  • 128. Adding/updating data
  • 129. Adding/updating data - Why it crashed
  • 130. Adding/updating data - Why it crashed
  • 131. Adding/updating data - Why it crashed
  • 132. Cache stampeding elePHPants
  • 133. Cache stampeding
  • 134. Memcache code ? DB
  • 135. Cache warmup scripts
    • Used to fill your cache when it's empty
    • 136. Run it before starting Webserver !
    • 137. 2 ways :
      • Visit all URLs
        • Error-prone
        • 138. Hard to maintain
      • Call all cache-updating methods
    • Make sure you have a warmup script !
  • 139. Cache stampeding - what about locking ?
      Seems like a nice idea, but...
    • Lock in place
    • 140. -> lots of new connections
    • 141. -> memory spike
    • 142. What if the process that created the lock fails ?
  • 143. Quick word about expiration
    • General rule : don't let things expire
    • 144. Exception to the rule : things that have an end date (calendar items)
  • 145. So...
      DON'T DELETE FROM CACHE (and don't expire unless usefull)
  • 146. LAMP...
      -> LAMMP -> LANMMP
  • 147. Nginx
  • 151. Nginx
    • No threads, event-driven
    • 152. Uses epoll / kqueue
    • 153. Low memory footprint
    • 154. 10000 active connections = normal
  • 155. Nginx - a true alternative to Apache ?
    • Not all Apache modules
    • Basic modules are available
    • 158. Some 3 rd party modules (needs recompilation !)
  • 159. Nginx - Installation
    • Packages
    • 160. Win32 binaries
    • 161. Build from source (./configure; make; make install)
  • 162. Nginx - Configuration server { listen 80; server_name www.domain.ext *.domain.ext; index index.html; root /home/domain.ext/www; } server { listen 80; server_name photo.domain.ext; index index.html; root /home/domain.ext/photo; }
  • 163. Nginx - phase 1
    • Move Apache to a different port (8080)
    • 164. Put Nginx at port 80
    • 165. Nginx serves all statics (images, css, js, …)
    • 166. Forward dynamic requests to Apache
  • 167. Nginx for static files only server { listen 80; server_name www.domain.ext; location ~* ^.*.(jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|doc|xls|pdf|ppt|txt|tar|rtf|js)$ { expires 30d; root /home/www.domain.ext; } location / { proxy_pass http://www.domain.ext:8080; proxy_pass_header Set-Cookie; proxy_set_header X-Real-IP $remote_addr; proxy_set_header Host $host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } }
  • 168. Nginx - let's give that a go !
  • 169. Nginx for PHP ?
      LANMMP to... LNMPP (ok, this is getting ridiculous)
  • 170. Nginx with PHP
    • In the past : spawn-fcgi (from Lighttpd)
    • 171. Now : PHP-FPM (in PHP 5.3 !)
    • 172. Runs on port 9000
    • 173. Nginx connects using fastcgi method
    location / { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; include fastcgi_params; fastcgi_param SCRIPT_NAME $fastcgi_script_name; fastcgi_param SCRIPT_FILENAME /home/www.phpbenelux.eu/$fastcgi_script_name; fastcgi_param SERVER_NAME $host; fastcgi_intercept_errors on; }
  • 174. Nginx + PHP-FPM features
    • Graceful upgrade
    • 175. Spawn new processes under high load
    • 176. Chroot
    • 177. Slow request log !
  • 178. Nginx + PHP-FPM features
    • Graceful upgrade
    • 179. Spawn new processed under high load
    • 180. Chroot
    • 181. Slow request log !
    • 182. fastcgi_finish_request() -> offline processing
  • 183. Nginx + PHP-FPM - performance ?
  • 184. Reverse proxy time...
  • 185. Varnish
    • Not just a load balancer
    • 186. Reverse proxy cache / http accelerator / …
    • 187. Caches (parts of) pages in memory
    • 188. Careful :
      • uses threads
      • 189. Nginx is faster and scales better (but doesn't have VCL)
  • 190. Varnish - Installation & configuration
    • Installation
      • Packages
      • 191. Source : ./configure && make && make install
    • Configuration
      • /etc/default/varnish
      • 192. /etc/varnish/*.vcl
  • 193. Varnish - backends + load balancing backend server1 { .host = &quot;192.168.0.10&quot;; } backend server2{ .host = &quot;192.168.0.11&quot;; } director example_director round-robin { { .backend = server1; } { .backend = server2; } }
  • 194. Varnish - backends + load balancing backend server1 { .host = &quot;192.168.0.10&quot;; .probe = { .url = &quot;/&quot;; .interval = 5s; .timeout = 1 s; .window = 5; .threshold = 3; } }
  • 195. Varnish - VCL
    • Varnish Configuration Language
    • 196. DSL (Domain Specific Language)
      • -> compiled to C
    • Hooks into each request
    • 197. Defines :
      • Backends (web servers)
      • 198. ACLs
      • 199. Load balancing strategy
    • Can be reloaded while running
  • 200. Varnish - whatever you want
    • Real-time statistics (varnishtop, varnishhist, ...)
    • 201. ESI
  • 202. Varnish - ESI
      Perfect for caching pages
    In your article page output : <esi:include src=&quot;/latest-news&quot;/>
  • 203. Varnish with ESI - hold on tight !
  • 204. Varnish - what can/can't be cached ?
    • Can :
      • Static pages
      • 205. Images, js, css
      • 206. Pages or parts of pages that don't change often (ESI)
    • Can't :
      • POST requests
      • 207. Requests with Set-Cookie
      • 208. Very large files (it's not a file server !)
      • 209. User-specific content
  • 210. ESI -> no caching on user-specific content ? Logged in as : Wim Godden 5 messages TTL = 5min TTL=1h TTL = 0s ?
  • 211. Coming to an Nginx near you soon... Logged in as : Wim Godden 5 messages <esim:include src=&quot;/news&quot; ttl=&quot;5m&quot; /> <esim:include src=&quot;/menu&quot; ttl=&quot;1h&quot; /> <esim:include src=&quot;/top&quot; usercookie=&quot;PHPSESS_ID&quot; ttl=&quot;1h&quot; />
  • 212. New message arrives...
    • Hash using page name and session
    • 213. Self-chosen key (i.e. 'mails_for_' followed by session)
    DB
  • 214. Advantages
    • No hits to backend anymore (except the first one) !
      • Not for user-specific content
      • 215. Not even for non-specific content
  • 216. Do we need TTLs ? Logged in as : Wim Godden 5 messages <esim:include src=&quot;/news&quot; ttl=&quot;5m&quot; /> <esim:include src=&quot;/menu&quot; ttl=&quot;1h&quot; /> <esim:include src=&quot;/top&quot; usercookie=&quot;PHPSESS_ID&quot; ttl=&quot;1h&quot; />
  • 217. Advantages
    • No hits to backend anymore (except the first one) !
      • Not for user-specific content
      • 218. Not even for non-specific content
        • No TTLs for non-specific content
        • 219. TTL for user-specific content is required (defaults to 5min)
    • No need to specify ESI parameters in configuration file
      • Only needs enabling
  • 220. How many Memcache requests ? Logged in as : Wim Godden 5 messages <esim:include src=&quot;/news&quot; ttl=&quot;5m&quot; /> <esim:include src=&quot;/menu&quot; ttl=&quot;1h&quot; /> <esim:include src=&quot;/top&quot; usercookie=&quot;PHPSESS_ID&quot; ttl=&quot;1h&quot; />
  • 221. Advantages
    • No hits to backend anymore (except the first one) !
      • Not for user-specific content
      • 222. Not even for non-specific content
        • No TTLs for non-specific content
        • 223. TTL for user-specific content is required (defaults to 5min)
    • No need to specify ESI parameters in configuration file
      • Only needs enabling
    • Memcache getMulti -> 1 Memcache request per page
  • 224. Under development
    • Feature set = unclear
    • 225. Performance = even more unclear
      • Debugging code makes it slow
    • Extends ESI standard, but doesn't follow it entirely
      • (what standard ?)
    • Release date ?
      • End 2011 ?
  • 226. Tuning
  • 227. Apache - tuning tips
    • Disable unused modules -> fixes 10% of performance issues
    • 228. Set AllowOverride to None
    • 229. Disable SymLinksIfOwnerMatch
      • Why ? Site in /var/www/domain.com/subdomain/html
    • MinSpareServers, MaxSpareServers, StartServers, MaxClients, MPM selection -> a whole session of its own ;-)
    • 230. Don't mod_proxy -> use Nginx or Varnish !
    • 231. High load on an SSL-site ? -> put SSL on a reverse proxy
  • 232. PHP speed - some tips
    • Upgrade PHP - every minor release has 5-15% speed gain !
    • 233. Use an opcode cache
  • 234. Caching storage - Opcode caching
  • 235. PHP speed - some tips
    • Upgrade PHP - every minor release has 5-15% speed gain !
    • 236. Use an opcode cache
    • 237. Profile your code
  • 239. KCachegrind is your friend
  • 240. PHP speed - some tips
    • Upgrade PHP - every minor release has 5-15% speed gain !
    • 241. Use an opcode cache
    • 242. Profile your code
    • But : turn off profilers on acceptance/production platforms !
    • 244. Let's see what difference opcode caching and profilers make...
  • 245. DB speed - some tips
    • Avoid NOW() -> use PHP date(&quot;Y-m-d&quot;) as a parameter
      • Why ? Query cache !
    • Index, index, index ! (where needed only)
    • 246. Use same types for joins
      • i.e. don't join decimal with int
    • RAND() is evil !
    • 247. count(*) is evil in InnoDB without a where clause !
      • (and there are other examples of specific things to avoid)
    • Select the right storage engine
    • 248. Persistent connect is not always good !
  • 249. Caching & Tuning @ frontend http://www.websiteoptimization.com/speed/tweak/average-web-page/
  • 250. Caching in the browser
    • HTTP 304 (Not modified)
    • 251. Expires/Cache-Control header
  • 252. HTTP 304 First request Next requests
  • 253. HTTP 304 with ETag First request Next requests
  • 254. Expires/Cache-control header
      Cache-Control
    First request Next requests No requests until item expires
      Expires
      • HTTP/1.0
      • 257. Date to expire on
      • 258. Used by old proxies
      • 259. Requires clock to be accurate !
  • 260. Pragma: no-cache = evil
    • &quot;Pragma: no cache&quot; doesn't make it uncacheable
    • 261. Don't want caching on a page ?
      • HTTP/1.0 : &quot;Expires : Fri, 30 Oct 1998 00:00:00 GMT&quot; (in the past)
      • 262. HTTP/1.1 : &quot;Cache-Control: no-store&quot;
  • 263. Frontend tuning
      1. You optimize backend 2. Frontend engineers messes up -> havoc on backend 3. Don't forget : frontend sends requests to backend ! SO...
    • Care about frontend
    • 264. Test frontend
    • 265. Check what requests frontend sends to backend
  • 266. Tuning frontend
    • Minimize requests
      • Combine CSS/JavaScript files
      • 267. Use inline images in CSS/XHTML (not supported on all browsers yet)
  • 268. Frontend tuning - inline CSS/XHTML images #navbar span { width: 31px; height: 31px; display: inline; float: left; margin-right: 4px; } .home { background-image: url(........MEl0nGVUC6tObNnPceSFBaQVMJAxC4lo3gNOrUaFnTHoAxNm3XVxPfRq139e8BEGAjWD5bgIALw287T8AcAXLly2kjOACdc17higXSIKDO/Lpv7Qq4bw7APgBq8eOzX69InrZ6xe3dbxZffyTGkb8tdx8F+b0Xn2sFsCSBAgTM5lp63RHYnoHUudZgRgkGOGCB+43nGk4OGcQTabKx5dyJKJ7ImoUNCaRRAZYN1ppsrT3Y2gIwyjSQBAtUpABml/0IJGYd6VjQUDH9uBFkGxGm5I8dPQaRUAQUMBdhhBV25ZYUJZBcSAtSJBddWZZ5UAGPOTXlgkNVOSZdBxEwIkYu7VhYnAol5GaadRqF0Uaz0TgXnX2umVFyGakJUUAAADs=); margin-left: 4px; } <img border=0 src=&quot;......Uaz0TgXnX2umVFyGakJUUAAADs=&quot;>
  • 269. Tuning frontend
    • Minimize requests
      • Combine CSS/JavaScript files
      • 270. Use inline images in CSS (not supported on all browsers yet)
      • 271. Use CSS Sprites
  • 272. CSS Sprites
  • 273. Tuning content - CSS sprites
  • 274. Tuning content - CSS sprites 11 images 11 HTTP requests 24KByte 1 images 1 HTTP requests 14KByte
  • 275. Tuning frontend
    • Minimize requests
      • Combine CSS/JavaScript files
      • 276. Use inline images in CSS (not supported on all browsers yet)
      • 277. Use CSS Sprites (horizontally if possible)
    • Put CSS at top
    • 278. Put JavaScript at bottom
      • Max. no connections
      • 279. Especially if JavaScript does Ajax (advertising-scripts, …) !
    • Avoid iFrames
      • Again : max no. of connections
    • Don't scale images in HTML
    • 280. Have a favicon.ico (don't 404 it !)
  • 281. Tuning frontend
    • Use GET for Ajax retrieval requests (and cache them !)
    • 282. Split requests across subdomains
    • 283. Put statics on a separate subdomain (without cookies !)
    www.whatever.com www.whatever.com images.whatever.com
  • 284. Tuning miscellaneous
    • Avoid DNS lookups
      • Frontend : don't use too many subdomains (2 = ideal)
      • 285. Backend :
        • Turn off DNS resolution in Apache : HostnameLookups Off
        • 286. If your app uses external data
          • Run a local DNS cache (timeout danger !)
          • 287. Make sure you can trust DNS servers (preferable run your own)
    • Compress non-binary content (GZIP)
      • mod_deflate in Apache
      • 288. HttpGzipModule in Nginx (HttpGzipStaticModule for pre-zipped statics !)
      • 289. No native support in Varnish
  • 290. What else can kill your site ?
    • Redirect loops
      • Multiple requests
        • More load on Webserver
        • 291. More PHP to process
      • Additional latency for visitor
      • 292. Try to avoid redirects anyway
      • 293. -> In ZF : use $this->_forward instead of $this->_redirect
    • Watch your logs, but equally important...
    • 294. Watch the logging process ->
    • 295. Logging = disk I/O -> can kill your site !
    • 296. Slashdot effect
  • 297. Above all else... be prepared !
    • Have a monitoring system
    • 298. Use a cache abstraction layer (disk -> Memcache)
    • 299. Don't install for the worst -> prepare for the worst
    • 300. Have a test-setup
    • 301. Have fallbacks
      • Turn off non-critical functionality
  • 302.
      Questions ?
  • 303.
      Questions ?
  • 304. Contact
    • Twitter @wimgtr
    • 305. Web http://techblog.wimgodden.be
    • 306. Slides http://www.slideshare.net/wimg
    • 307. E-mail [email_address]
  • 308. Please...
    • Rate my talk : http://tinyurl.com/cachetune
    • 309. Vote to see me talk at Confoo : http://www.confoo.ca
      • Caching and tuning fun for high scalability
      • 310. Keeping old code alive without non-stop hassle
      • 311. Beyond PHP : it's not (just) about the code !
      • 312. Who's in control of your PHP app ?
      • 313. Creating Fast, Dynamic ACLs in Zend Framework
  • 314.
      Thanks !
  • 315.