nginx图片处理笔记(http-image-filter-module、lua)
实验环境:CentOS 6.10
目标:1.使用http-image-filter-module进行图片变换;2.使用lua进行格式转换;
安装EPEL
https://fedoraproject.org/wiki/EPELyum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm
# or RHEL/CentOS 7
# yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
由于lua-nginx-module声称(2018-12-06)测试的最新nginx稳定版本是1.12.x(参考:https://github.com/openresty/lua-nginx-module#nginx-compatibility),所以选择安装nginx版本为1.13.6
curl -O http://nginx.org/download/nginx-1.12.2.tar.gz
yum install -y gcc g++ gcc-c++ zlib zlib-devel openssl openssl-devel pcre pcre-devel
yum install -y nginx-1.12.2
yum install -y libjpeg-turbo-devel libpng-devel freetype-devel libtiff-devel libXpm-devel libwebp-devel fontconfig-devel
libimagequant && libgd && add http-image-filter-module
https://github.com/libgd/libgd
https://github.com/ImageOptim/libimagequantcd libimagequant-2.12.2
./configure --prefix=/usr
make libimagequant.so
make install
> install -d /usr/lib
> install -d /usr/lib/pkgconfig
> install -d /usr/include
> install -m 644 libimagequant.a /usr/lib/libimagequant.a
> install -m 644 libimagequant.so.0 /usr/lib/libimagequant.so.0
> ln -sf libimagequant.so.0 /usr/lib/libimagequant.so
> install -m 644 imagequant.pc /usr/lib/pkgconfig/imagequant.pc
> install -m 644 libimagequant.h /usr/include/libimagequant.h
#
cd ../libgd-2.2.5
./configure --with-liq=/opt/src/libimagequant-2.12.2
make
make install
gdlib-config --all
> gdlib-config: warning: this script is deprecated; please use the pkg-config file instead.
> GD library 2.2.5
> includedir: /usr/local/include
> cflags: -I/usr/local/include
> ldflags:
> libs: -lm -lz -lpng12 -lfreetype -lfontconfig -ljpeg -limagequant -fopenmp > -lXpm -lX11 -ltiff -lwebp
> libdir: /usr/local/lib
> features: GD_GIF GD_GIFANIM GD_OPENPOLYGON GD_ZLIB GD_PNG GD_FREETYPE GD_FONTCONFIG GD_JPEG GD_LIQ GD_XPM GD_TIFF GD_WEBP
ln -s /usr/local/lib/libgd.so.3.0.5 /usr/lib64/libgd.so
ln -s /usr/local/lib/libgd.so.3.0.5 /usr/lib64/libgd.so.3
ln -s /usr/lib/libimagequant.so.0 /usr/lib64/libimagequant.so.0
#
cd nginx-1.12.2
# 已经安装 yum install -y nginx-1.12.2,所以通过nginx -V获取原编译参数,再加上--with-http_image_filter_module重新编译
nginx -V
./configure --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib64/nginx/modules --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx.pid --lock-path=/var/run/nginx.lock --http-client-body-temp-path=/var/cache/nginx/client_temp --http-proxy-temp-path=/var/cache/nginx/proxy_temp --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp --http-scgi-temp-path=/var/cache/nginx/scgi_temp --user=nginx --group=nginx --with-compat --with-file-aio --with-threads --with-http_addition_module --with-http_auth_request_module --with-http_dav_module --with-http_flv_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_mp4_module --with-http_random_index_module --with-http_realip_module --with-http_secure_link_module --with-http_slice_module --with-http_ssl_module --with-http_stub_status_module --with-http_sub_module --with-http_v2_module --with-mail --with-mail_ssl_module --with-stream --with-stream_realip_module --with-stream_ssl_module --with-stream_ssl_preread_module --with-cc-opt='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic -fPIC' --with-ld-opt='-Wl,-z,relro -Wl,-z,now -pie' --with-http_image_filter_module
> ...
> checking for GD library ... found
> checking for GD WebP support ... found
> ...
make
cd objs
cp /usr/sbin/nginx /usr/sbin/nginx.old.20181206
/cp nginx /usr/sbin/nginx -f
nginx -V
测试nginx
location ~* ^/img/.*_(\d+)x(\d+)\.(jpg|JPG|gif|GIF|png|PNG)$ {
set $img_width $1;
set $img_height $2;
rewrite ^(.*)_(\d+)x(\d+)\.(jpg|JPG|gif|GIF|png|PNG)$ $1.$4 break;
image_filter resize $img_width $img_height;
image_filter_buffer 10M;
}
测试image_filter是否支持webp
yum install -y libwebp-tools
cwebp xxx.jpg -o xxx.webp
curl -I http://192.168.178.130/img/288822bcfbcbdea89eaa9b84cc42f562_500x500.webp
测试image_filter + proxy_pass
location ~* ^/oss/(.*)_(\d+)x(\d+)\.(jpg|JPG|jpeg|JPEG|gif|GIF|png|PNG|webp|WEBP)$ {
set $img_width $2;
set $img_height $3;
image_filter resize $img_width $img_height;
image_filter_buffer 10M;
resolver 114.114.114.114;
proxy_pass http://image-demo.oss-cn-hangzhou.aliyuncs.com/$1.$4;
# 借用oss的示例图片 https://help.aliyun.com/document_detail/44688.html
}
LUAJIT
# http://luajit.org/download.html
curl -O http://luajit.org/download/LuaJIT-2.0.5.tar.gz
tar -zxvf LuaJIT-2.0.5.tar.gz
cd LuaJIT-2.0.5
make PREFIX=/usr/local/luajit
make install PREFIX=/usr/local/luajit
vi /etc/profile
>> export LUAJIT_LIB=/usr/local/luajit/lib
>> export LUAJIT_INC=/usr/local/luajit/include/luajit-2.0
source /etc/profile
ngx_devel_kit (NDK) && lua-nginx-module
# https://github.com/openresty/lua-nginx-module/releases
tar -zxvf lua-nginx-module-0.10.13.tar.gz
# https://github.com/simpl/ngx_devel_kit/releases
tar -zxvf ngx_devel_kit-0.3.0.tar.gz
编译安装nginx
./configure --prefix ...省略... --with-http_image_filter_module --add-module=/opt/src/ngx_devel_kit-0.3.0 --add-module=/opt/src/lua-nginx-module-0.10.13
make
cd objs
cp /usr/sbin/nginx /usr/sbin/nginx.old.20181215
/bin/cp nginx /usr/sbin/nginx -f
ln -s /usr/local/luajit/lib/libluajit-5.1.so.2.0.5 /usr/lib64/libluajit-5.1.so.2
service nginx restart
# 验证Nginx是否链接了libluajit-5.1.so.2
ldd /usr/sbin/nginx | grep lua
hello,lua
location /lua_hello {
default_type 'text/plain';
content_by_lua 'ngx.say('hello,lua!')';
}
location /lua_hello2 {
default_type 'text/plain';
content_by_lua_block {
ngx.say("hello,world!");
ngx.log(ngx.ERR, "hello");
}
}
用lua来做代理
location ~* ^/lua_capture/(.*)_(\d+)x(\d+)\.(jpg|JPG|jpeg|JPEG|gif|GIF|png|PNG|webp|WEBP)$ {
default_type 'text/plain';
content_by_lua_block {
local proxy_url = "/proxy/" .. ngx.var[1] .. "." .. ngx.var[4]
ngx.log(ngx.ERR, proxy_url)
local resp = ngx.location.capture(proxy_url, {
method = ngx.HTTP_GET,
args = {q="hello"}
})
if not resp then
ngx.say("request error:", err);
return
end
ngx.log(ngx.ERR, tostring(resp.status)) ngx.status = resp.status for k, v in pairs(resp.header) do
if k ~= "Transfer-Encoding" and k ~= "Connection" then
ngx.header[k] = v
end
end if resp.body then
ngx.say(resp.body)
end
}
} location ~ ^/proxy/(.*)$ {
# internal;
resolver 114.114.114.114;
proxy_pass http://image-demo.oss-cn-hangzhou.aliyuncs.com/$1;
}
todo: 如何实现实时转webp呢?
参考:
- nginx模块 ngx_http_image_filter_module
- ngx.location.capture 只支持相对路径,不能用绝对路径
- 利用 Aliyun OSS Nginx proxy module 实现OSS 图片处理回写功能
- 大型网站高并发解决方案分析之图片服务器分离架构
- WebP(整理),比较了WebP和PNG
nginx图片处理笔记(http-image-filter-module、lua)的更多相关文章
- nginx图片过滤处理模块http_image_filter_module安装配置笔记
http_image_filter_module是nginx提供的集成图片处理模块,支持nginx-0.7.54以后的版本,在网站访问量不是很高磁盘有限不想生成多余的图片文件的前提下可,就可以用它实时 ...
- nginx图片过滤处理模块http_image_filter_module
nginx图片过滤处理模块http_image_filter_module安装配置笔记 http_image_filter_module是nginx提供的集成图片处理模块,支持nginx-0.7.54 ...
- nginx图片过滤处理模块http_image_filter_module安装配置
http_image_filter_module是nginx提供的集成图片处理模块,支持nginx-0.7.54以后的版本,在网站访问量不是很高磁盘有限不想生成多余的图片文件的前提下可,就可以用它实时 ...
- Windows下搭建Nginx图片服务器
在项目最开始,上传图片的时候,服务器先保存原图再使用ImageMagick生成上传图片缩略图,这种方法有很多缺点,例如生成的缩略图的大小是固定的,不能动态请求指定大小的缩略图. 虽然有非常多的图片云存 ...
- nginx图片处理
前言 不管一个系统或网站的大与小,都存在相应的图片处理,生成缩略图.为图片加水印等等,如果涉及到APP端,这个图片的处理需求变得更加重要了,因为在目前看来,客户端的屏幕大小不一,会导致以下问题: 1. ...
- nginx 配置rewrite 笔记
nginx 配置rewrite笔记: 通过下面的示例来说明一下,1. 先说说location : location 表示匹配传入的url地址,其中配置符有多种,各种情况的意义不一样: location ...
- 搭建Nginx图片服务器
搭建Nginx图片服务器 Part-I 安装Nginx 安装PCRE 下载 ngx_cache_purge 并解压,用来清除缓存 下载Nginx并解压 cd nginx-1.7.7 编译,--pref ...
- 用nginx图片缓存服务器
图片的存储硬件 把图片存储到什么介质上? 如果有足够的资金购买专用的图片服务器硬件或者 NAS 设备,那么简单的很: 如果上述条件不具备,只想在普通的硬盘上存储,首先还是要考虑一下物理硬盘的实际处理能 ...
- Nginx 图片服务器
文件服务器:后台如果是集群,每次请求都会到不同的服务器,所以每台服务器的图片文件等都要做同步处理,才能保证每次用户不管访问到哪台服务器都能获取一样的资源.这种做法开销会很大,专门使用 nginx 作为 ...
随机推荐
- (网络流)Food -- hdu -- 4292
链接: http://acm.hdu.edu.cn/showproblem.php?pid=4292 Food Time Limit: 2000/1000 MS (Java/Others) Me ...
- Android-HttpUtil工具类
Http(Java 版 HttpURLConnection)请求的相关工具类 public class HttpUtil { private static final int TIMEOUT_IN_M ...
- nginx反向代理后abp的webapi host如何获取客户端ip?
dotnet core 跨平台是微软伟大的创举,脱离iis后服务器成本都降低了. 问题 这不,采用abp搞了个小项目,部署到centos后发现审计日志里面的ip信息不对. 解决 这个问题在.net 4 ...
- Spring Data MongoDB 一:入门篇(环境搭建、简单的CRUD操作)
一.简介 Spring Data MongoDB 项目提供与MongoDB文档数据库的集成.Spring Data MongoDB POJO的关键功能区域为中心的模型与MongoDB的DBColle ...
- docker为什么适合devops?
欢迎访问网易云社区,了解更多网易技术产品运营经验 进阶版结论:Kubernetes + Docker 是 Dev 和 Ops 融合的一个桥梁. DevOps 强调的是高效组织团队之间如何通过自动化 ...
- util.Date转化成sql.date格式
https://www.cnblogs.com/zhaotiancheng/p/6413067.html
- python网络编程--socketserver 和 ftp功能简单说明
1. socketserver 我们之前写的tcp协议的socket是不是一次只能和一个客户端通信,如果用socketserver可以实现和多个客户端通信.它是在socket的基础上进行了一层封装,也 ...
- iOS Socket编程(一)基本概念
1.Socket的解释 Socket翻译过来中文称为套接字, 这里我找到了一段比较官方的解释Socket是什么东西: Socket是通信的基石,是支持TCP/IP协议的网络通信的基本操作单元,包含进行 ...
- C# 键盘中的按键对应KeyValue
首先先看一下什麼情況下需要對按鍵進行識別: KeyPress事件響應函數中,有KeyPressEventArgs, 對應於e.KeyChar; KeyDown事件響應中有KeyEventArgs 求取 ...
- java实际项目中interface和abstract interface 区别
参考:https://zhidao.baidu.com/question/424485344260391052.html 这2种有什么区别,根据实际项目经验 帮我解答下 谢谢啊~~~~~~~~~问题补 ...