Умное кэширование в rails
TRANSCRIPT
![Page 1: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/1.jpg)
Умное кэширование в Rails
![Page 2: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/2.jpg)
?
![Page 3: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/3.jpg)
«Premature optimizationis the root of all evil»
Donald Knuth
![Page 4: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/4.jpg)
Два вида кэширования:
![Page 5: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/5.jpg)
Вредное
![Page 6: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/6.jpg)
Жизненно необходимое
![Page 7: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/7.jpg)
Когда нужно кэшировать?
![Page 8: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/8.jpg)
Если за время жизникэш будет прочтен
более 1 раза
![Page 9: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/9.jpg)
Если работа с кэшем экономит
ресурсы сервера
![Page 10: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/10.jpg)
Что кэшировать?
![Page 11: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/11.jpg)
«Горячие» данные
![Page 12: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/12.jpg)
Результаты сложныхили долгих операций
![Page 13: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/13.jpg)
Части ответа сервера
![Page 14: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/14.jpg)
Ответ сервера целиком
![Page 15: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/15.jpg)
Где хранить кэш?
![Page 16: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/16.jpg)
Память приложения
● «Горячие» данные● Результаты операций
![Page 17: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/17.jpg)
Memcached
● «Горячие» данные● Результаты операций● Фрагменты ответа
![Page 18: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/18.jpg)
База данных :)
● «Горячие» данные● Результаты операций
![Page 19: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/19.jpg)
Redis
● «Горячие» данные● Результаты операций
![Page 20: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/20.jpg)
Файловая система
● Результаты операций● Фрагменты ответа● Ответ целиком
![Page 21: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/21.jpg)
Кэширующий proxy-сервер
● Фрагменты ответа● Ответ целиком
![Page 22: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/22.jpg)
Например...
![Page 23: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/23.jpg)
«Горячие» данные
![Page 24: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/24.jpg)
Muuviz
![Page 25: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/25.jpg)
Ответы пользователей
Статистика
Вопросы пользователям
![Page 26: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/26.jpg)
~ 10.000 записей
SQL — 300msRedis — 20ms
Переменная — 0ms
![Page 27: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/27.jpg)
~ 10.000 записей
SQL — 300msRedis — 20ms
Переменная — 0ms
![Page 28: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/28.jpg)
Результаты операций
![Page 29: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/29.jpg)
Railorz RPG Engine
![Page 30: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/30.jpg)
Character Inventory Item
Item Attack DefenceSword 3Bow 2Shield 1Armor 3
5 4
![Page 31: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/31.jpg)
На каждого игрока:
В среднем — 10 предметов
Максимум (сейчас) — 128
![Page 32: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/32.jpg)
Считать каждый раз — безумно дорого и долго
![Page 33: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/33.jpg)
Выход:
serialize :inventory_effects
![Page 34: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/34.jpg)
или
class InventoryEffect < AR::Bbelongs_to :character
end
![Page 35: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/35.jpg)
Лучший выбор:
Зависит от задачи
![Page 36: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/36.jpg)
Фрагменты ответа
![Page 37: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/37.jpg)
<% cache 'disisdakey' do %> ...неприлично медленная
операция...<% end %>
![Page 38: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/38.jpg)
Лучший выбор:memcached
![Page 39: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/39.jpg)
@user.cache_key
![Page 40: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/40.jpg)
'users/9-20101027173032'
![Page 41: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/41.jpg)
@user.save!
![Page 42: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/42.jpg)
'users/9-20101027198122'
![Page 43: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/43.jpg)
Кэш «протухает» автоматически
![Page 44: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/44.jpg)
Не только для моделей
![Page 45: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/45.jpg)
def daily_cache_key 'my_key/%s' % Time.now.end_of_day.to_i
end
![Page 46: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/46.jpg)
cache(daily_cache_key)
![Page 47: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/47.jpg)
Ответ целиком
![Page 48: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/48.jpg)
class MyController < AC::B caches_page :show
end
![Page 49: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/49.jpg)
Nginx
location / { try_files $uri @passenger;
} location @passenger { passenger_enabled on;
}
![Page 50: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/50.jpg)
Проблемы
![Page 51: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/51.jpg)
Выбор хранилища
![Page 52: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/52.jpg)
Нет «серебрянной пули»
![Page 53: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/53.jpg)
Контентные проекты:
● memcached● База данных● Файловая система
![Page 54: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/54.jpg)
Игровые приложения:
● memcached● Redis● Память приложения
![Page 55: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/55.jpg)
«Протухание» кэша
![Page 56: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/56.jpg)
« There are only two hard things in Computer Science: cache invalidation and naming things »
Phil Karlton
![Page 57: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/57.jpg)
«Протухание» кэша
![Page 58: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/58.jpg)
Память приложения
![Page 59: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/59.jpg)
![Page 60: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/60.jpg)
База данных
![Page 61: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/61.jpg)
before_save :update_cache
def update_cache self.cache = {…}
end
![Page 62: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/62.jpg)
Memcached
![Page 63: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/63.jpg)
Автоматическое «протухание»
![Page 64: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/64.jpg)
Можем удалять только зная ключ
![Page 65: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/65.jpg)
Redis
![Page 66: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/66.jpg)
Redis — это не кэш!
Это хранилище данных
![Page 67: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/67.jpg)
Удаление ключей по маске
![Page 68: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/68.jpg)
Файловая система
![Page 69: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/69.jpg)
Observer
![Page 70: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/70.jpg)
Удаление по маске
![Page 71: Умное кэширование в Rails](https://reader031.vdocuments.site/reader031/viewer/2022022203/58780e401a28ab971e8b66ff/html5/thumbnails/71.jpg)
Страшные истории