కొంతకాలంగా, కథనం ద్వారా ప్రేరణ పొందింది చిత్రం పరిమాణాన్ని ఉపయోగించి కాన్ఫిగర్ చేయబడింది మరియు ప్రతిదీ తప్పక పనిచేసింది. కానీ కొన్ని సేవలకు అప్లోడ్ చేయడానికి మేనేజర్ ఖచ్చితమైన కొలతలతో చిత్రాలను స్వీకరించాల్సిన అవసరం వచ్చినప్పుడు ఒక సమస్య తలెత్తింది, ఎందుకంటే... ఇవి వారి సాంకేతిక అవసరాలు. ఉదాహరణకు, మనకు పరిమాణం యొక్క అసలు చిత్రం ఉంటే 1200 × 1200, మరియు పరిమాణాన్ని మార్చేటప్పుడు మనం ఇలా వ్రాస్తాము ?పరిమాణం=600×400, అప్పుడు మేము చిన్న అంచు, పరిమాణంలో దామాషా ప్రకారం తగ్గిన చిత్రాన్ని పొందుతాము 400 × 400. అధిక రిజల్యూషన్ (అప్స్కేల్)తో చిత్రాన్ని పొందడం కూడా అసాధ్యం. ఆ. ?పరిమాణం=1500×1500 అదే చిత్రాన్ని తిరిగి ఇస్తుంది 1200 × 1200
ఈ కథనం రక్షించటానికి వచ్చింది Nginx లువాతో మరియు లువా కోసం లైబ్రరీతో ఎలా పనిచేస్తుందో అర్థం చేసుకోవడానికి - ఇమేజ్మ్యాజిక్కు లువా ప్యూర్-సి బైండింగ్లు. ఈ పరిష్కారం ఎందుకు ఎంచుకోబడింది మరియు పైథాన్లో ఏదో చెప్పలేదు - ఎందుకంటే ఇది వేగంగా మరియు సౌకర్యవంతంగా ఉంటుంది. మీరు ఏ ఫైల్లను కూడా సృష్టించాల్సిన అవసరం లేదు, ప్రతిదీ Nginx కాన్ఫిగరేషన్లో ఉంది (ఐచ్ఛికం).
కాబట్టి మనకు ఏమి కావాలి
డెబియన్ ఆధారంగా ఉదాహరణలు ఇవ్వబడతాయి.
nginx మరియు nginx-ఎక్స్ట్రాలను ఇన్స్టాల్ చేస్తోంది
apt-get update
apt-get install nginx-extrasLuaJITని ఇన్స్టాల్ చేస్తోంది
apt-get -y install lua5.1 luajit-5.1 libluajit-5.1-devఇమేజ్మ్యాజిక్ని ఇన్స్టాల్ చేస్తోంది
apt-get -y install imagemagickమరియు గ్రంథాలయాలు మంత్రదండం దానికి, వెర్షన్ 6 కోసం నా విషయంలో
apt-cache search libmagickwand
apt-get -y install libmagickwand-6.q16-3 libmagickwand-6.q16-devబిల్డింగ్ లువా-ఇమేజిక్
మేము రిపోజిటరీని క్లోన్ చేస్తాము (లేదా జిప్ తీసుకొని దాన్ని అన్ప్యాక్ చేయండి)
cd ~
git clone https://github.com/isage/lua-imagick.git
cd lua-imagick
mkdir build
cd build
cmake ..
make
make installప్రతిదీ సరిగ్గా జరిగితే, మీరు Nginxని కాన్ఫిగర్ చేయవచ్చు.
నేను బ్యాకెండ్ హోస్ట్ యొక్క కాన్ఫిగరేషన్కు ఒక ఉదాహరణ ఇస్తాను, వాస్తవానికి ఇది పునఃపరిమాణం చేయడానికి బాధ్యత వహిస్తుంది. ఇది ఫ్రంట్ సర్వర్ ద్వారా ప్రాక్సీ చేయబడుతుంది, Nginxతో కూడా, నిర్దిష్ట సమయం (రోజులు) మరియు ఇతర విషయాల కోసం కాషింగ్ జరుగుతుంది.
nginx బ్యాకెండ్ కాన్ఫిగరేషన్
# Backend image server
server {
listen 8082;
listen [::]:8082;
set $files_root /var/www/example.lh/frontend/web;
root $files_root;
access_log off;
expires 1d;
location /files {
# дефолтные значения ресайза
set $w 700;
set $h 700;
set $q 89;
#1-89 allowed
if ($arg_q ~ "^([1-9]|[1-8][0-9])$") {
set $q $arg_q;
}
if ($arg_resize ~ "([d-]+)x([d+!^]+)") {
set $w $1;
set $h $2;
rewrite ^(.*)$ /resize/$w/$h/$q$uri last;
}
rewrite ^(.*)$ /resize/$w/$h/$q$uri last;
}
location ~* ^/resize/([d]+)/([d+!^]+)/([d]+)/files/(.+)$ {
default_type 'text/plain';
set $w $1;
set $h $2;
set $q $3;
set $fname $4;
# Есть возможность вынести весь Lua код в отдельный файл
# content_by_lua_file /var/www/some.lua;
# lua_code_cache off; #dev
content_by_lua '
local magick = require "imagick"
local img = magick.open(ngx.var.files_root .. "/files/" .. ngx.var.fname)
if not img then ngx.exit(ngx.HTTP_NOT_FOUND) end
img:set_gravity(magick.gravity["CenterGravity"])
if string.match(ngx.var.h, "%d+%+") then
local h = string.gsub(ngx.var.h, "(%+)", "")
resize = ngx.var.w .. "x" .. h
-- для png с альфа каналом
img:set_bg_color(img:has_alphachannel() and "none" or img:get_bg_color())
img:smart_resize(resize)
img:extent(ngx.var.w, h)
else
img:smart_resize(ngx.var.w .. "x" .. ngx.var.h)
end
if ngx.var.arg_q then img:set_quality(ngx.var.q) end
ngx.say(img:blob())
';
}
}
# Upstream
upstream imageserver {
server localhost:8082;
}
server {
listen 80;
server_name examaple.lh;
# отправляем все jpg и png картинки на imageserver
location ~* ^/files/.+.(jpg|png) {
proxy_buffers 8 2m;
proxy_buffer_size 10m;
proxy_busy_buffers_size 10m;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://imageserver; # Backend image server
}
}
అవసరమైనది (చిత్రాన్ని అంచుల చుట్టూ విస్తరించడం) ఉపయోగించి జరుగుతుంది img:extent() మరియు పారామీటర్ ఉపయోగించి నిర్వచించబడింది resize ఒక సంకేతంతో + చివరలో.
కింది ఎంపికలు అందుబాటులో ఉన్నాయి:
- WxH (కారక నిష్పత్తిని ఉంచండి, అధిక కోణాన్ని ఉపయోగించండి)
- WxH^ (కారక నిష్పత్తిని ఉంచండి, తక్కువ పరిమాణం (పంట) ఉపయోగించండి)
- WxH! (కారక నిష్పత్తిని విస్మరించండి)
- WxH+ (కారక నిష్పత్తిని ఉంచండి, పక్క అంచులను జోడించండి)
పునఃపరిమాణం ఫలితాలతో సారాంశ పట్టిక
uri పరామితిని అభ్యర్థించండి
అవుట్పుట్ చిత్ర పరిమాణం
?పరిమాణం=400×200
200 × 200
?resize=400×200^
400 × 400
?పరిమాణం=400×200!
400×200 (అనుపాతంలో లేదు)
?పరిమాణం=400×200+
400×200 (అనుపాతంలో)

ఫలితం
ఈ విధానం యొక్క శక్తి మరియు సరళతను పరిగణనలోకి తీసుకుంటే, మీరు చాలా క్లిష్టమైన లాజిక్తో విషయాలను అమలు చేయవచ్చు, ఉదాహరణకు, వాటర్మార్క్లను జోడించడం లేదా పరిమిత ప్రాప్యతతో అధికారాన్ని అమలు చేయడం. చిత్రాలతో పని చేయడానికి API యొక్క సామర్థ్యాలను తెలుసుకోవడానికి, మీరు లైబ్రరీ డాక్యుమెంటేషన్ను చూడవచ్చు
మూలం: www.habr.com
