U gotovo svakoj web aplikaciji koja koristi slike postoji potreba za kreiranjem malih kopija ovih slika, a često postoji nekoliko formata za dodatne slike.
Dodavanje novih dimenzija postojećoj aplikaciji također uzrokuje neke glavobolje. Otuda i zadatak:
Cilj
Označimo listu zahtjeva:
Generirajte dodatne slike bilo kojeg formata u hodu bez uvođenja dodatne funkcionalnosti u aplikaciju u bilo kojem trenutku tijekom postojanja aplikacije;
Dodatne slike ne moraju biti generirane na svaki zahtjev;
Onemogućite mogućnost generiranja dodatnih slika nespecificiranih formata.
Objasniću poslednju tačku, jer je malo u suprotnosti sa prvom tačkom. Ako generisanje bilo koje slike učinimo otvorenim, postoji mogućnost napada na sajt generisanjem velikog broja zahteva za promenu veličine slike u beskonačan broj formata, pa ovu ranjivost treba zatvoriti.
nginx instalacijska konfiguracija
Za rješavanje gore navedenih zahtjeva potreban nam je sljedeći set nginx modula:
Moduli ngx_http_image_filter_module и ngx_http_secure_link_module nisu instalirani prema zadanim postavkama, tako da moraju biti specificirani u fazi konfiguracije instalacije nginx:
Dodamo novi u našu konfiguraciju hosta lokacija i opći parametri keša:
...
proxy_cache_path /www/myprojects/cache levels=1:2 keys_zone=image-preview:10m;
...
server {
...
location ~ ^/preview/([cir])/(.+) {
# Тип операции
set $oper $1;
# Параметры изображения и путь к файлу
set $remn $2;
# Проксируем на отдельный хост
proxy_pass http://myproject.ru:81/$oper/$remn;
proxy_intercept_errors on;
error_page 404 = /preview/404;
# Кеширование
proxy_cache image-preview;
proxy_cache_key "$host$document_uri";
# 200 ответы кешируем на 1 день
proxy_cache_valid 200 1d;
# остальные ответы кешируем на 1 минуту
proxy_cache_valid any 1m;
}
Iako bih također preporučio izračunavanje veličina preview.
Rake
Prilikom brisanja originalne slike, pregledi, naravno, neće biti obrisani iz keša dok se keš ne poništi, au našem slučaju pregledi mogu postojati dan nakon brisanja, ali ovo je maksimalno vrijeme.