Nginx国产缩略图模块 ngx_image_thumb

简介:

关于

ngx_image_thumb是nginx中用来生成缩略图的模块,生存缩略图的方法很多,之前也写过一篇 《nginx生成缩略图配置 - ttlsa教程系列之nginx》,在github上发现国人开发的一款模块,作者的文档写的很详细,我便照搬过来了。以后将做一个测试.

特性

本nginx模块主要功能是对请求的图片进行缩略/水印处理,支持文字水印和图片水印。支持自定义字体,文字大小,水印透明度,水印位置,判断原图是否是否大于指定尺寸才处理等等

1. 编译方法

实验环境:

[root@masterserver ~]# cat /etc/redhat-release 

CentOS release 6.6 (Final)

[root@masterserver ~]# uname -m

x86_64

[root@masterserver ~]# uname -a

Linux masterserver 2.6.32-504.el6.x86_64 #1 SMP Wed Oct 15 04:27:16 UTC 2014 x86_64 x86_64 x86_64 GNU/Linux

[root@masterserver ~]# 

# 请确保已经安装了gcc automake autoconf m4

[root@masterserver ~]# yum install gd-devel pcre-devel libcurl-devel

[root@masterserver ~]# cd /home/opuser/tools/

[root@masterserver tools]# wget https://github.com/3078825/nginx-image/archive/master.zip [root@masterserver tools]# ll master.zip 

-rw-r--r-- 1 root root 14306 Mar 15 17:00 master.zip

[root@masterserver tools]# 

[root@masterserver tools]# ll master.zip 

-rw-r--r-- 1 root root 14306 Mar 15 17:00 master.zip

[root@masterserver tools]# unzip master.zip 

Archive:  master.zip

ff2a0177fdec59828a88e2a05f0adb2a432e89a4

   creating: ngx_image_thumb-master/

  inflating: ngx_image_thumb-master/.gitignore  

  inflating: ngx_image_thumb-master/README.md  

  inflating: ngx_image_thumb-master/README_EN.md  

  inflating: ngx_image_thumb-master/config  

  inflating: ngx_image_thumb-master/ngx_http_image_module.c  

[root@masterserver tools]# ll

total 852

-rw-r--r-- 1 root root  14540 Oct 16 02:37 epel-release-6-8.noarch.rpm

-rw-r--r-- 1 root root  14306 Mar 15 17:00 master.zip

-rw-r--r-- 1 root root 828607 Apr 21  2015 nginx-1.7.10.tar.gz

drwxr-xr-x 2 root root   4096 Sep 23  2014 ngx_image_thumb-master

[root@masterserver tools]#


#安装nginx加入模块ngx_image_thumb-master

[root@masterserver tools]# tar xf nginx-1.7.10.tar.gz

[root@masterserver tools]# cd nginx-1.7.10

[root@masterserver nginx-1.7.10]# ./configure --add-module=../ngx_image_thumb-master/

[root@masterserver nginx-1.7.10]# make && make install


#修改nginx配置文件

[root@masterserver nginx-1.7.10]# vim /usr/local/nginx/conf/nginx.conf

 location / {

     root   html;

     index  index.html index.htm;

    #添加以下配置

    image on;

   image_output on;

 }

#检查配置文件是否正确,然后启动nginx

[root@masterserver nginx-1.7.10]# /usr/local/nginx/sbin/nginx -t

nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok

nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

[root@masterserver nginx-1.7.10]# /usr/local/nginx/sbin/nginx


#模块ngx_image_thumb-master参介绍

image on/off 是否开启缩略图功能,默认关闭

image_backend on/off 是否开启镜像服务,当开启该功能时,请求目录不存在的图片(判断原图),将自动从镜像服务器地址下载原图

image_backend_server 镜像服务器地址

image_output on/off 是否不生成图片而直接处理后输出 默认off

image_jpeg_quality 75 生成JPEG图片的质量 默认值75

image_water on/off 是否开启水印功能

image_water_type 0/1 水印类型 0:图片水印 1:文字水印

image_water_min 300 300 图片宽度 300 高度 300 的情况才添加水印

image_water_pos 0-9 水印位置 默认值9 0为随机位置,1为顶端居左,2为顶端居中,3为顶端居右,4为中部居左,5为中部居中,6为中部居右,7为底端居左,8为底端居中,9为底端居右

image_water_file 水印文件(jpg/png/gif),绝对路径或者相对路径的水印图片

image_water_transparent 水印透明度,默认20

image_water_text 水印文字 "Power By Vampire"

image_water_font_size 水印大小 默认 5

image_water_font 文字水印字体文件路径

image_water_color 水印文字颜色,默认 #000000


#调用说明

这里假设你的nginx 访问地址为 http://10.0.0.10/

并在nginx网站根目录存在一个 pit.jpg 的图片

通过访问

wKiom1bn1HzjNOdwAAC_OYV5viU997.png

http://10.0.0.10/pit.jpg!c300x200.jpg

wKioL1bn1bHDSttlAADwD8KF01A829.png


其中 c 是生成图片缩略图的参数, 300 是生成缩略图的宽度 200 是生成缩略图的高度

一共可以生成四种不同类型的缩略图。

支持 jpeg / png / gif (Gif生成后变成静态图片)

C 参数按请求宽高比例从图片高度 10% 处开始截取图片,然后缩放/放大到指定尺寸( 图片缩略图大小等于请求的宽高 )

M 参数按请求宽高比例居中截图图片,然后缩放/放大到指定尺寸( 图片缩略图大小等于请求的宽高 )

T 参数按请求宽高比例按比例缩放/放大到指定尺寸( 图片缩略图大小可能小于请求的宽高 )

W 参数按请求宽高比例缩放/放大到指定尺寸,空白处填充白色背景颜色( 图片缩略图大小等于请求的宽高 )

5. 调用举例

http://10.0.0.10/pit.jpg!c300x300.jpg


wKioL1bn1iqgfx0UAAEg5wEJ0xM595.png

http://10.0.0.10/pit.jpg!t300x300.jpg

wKiom1bn1eXi3-rzAAC25stGi0w163.png

http://10.0.0.10/pit.jpg!m300x300.jpg

wKioL1bn1qGi6OwbAAE0d77K8FQ716.png

http://10.0.0.10/pit.jpg!w300x300.jpg

wKioL1bn1-GRxfQzAAEoZBDEjBM801.png


6. 最后

这款模块的缩略图是实时生成的,如果你的网站流量比较大,势必会造成nginx服务器负载过高,针对这个问题,你可以参考我们运维生存时间之前写的几篇文章,分别为存硬盘和redis. 《nginx实时生成缩略图到硬盘上》《srcache_nginx+redis构建缓存系统》

参考文章

项目地址:https://github.com/3078825/nginx-image/ 

下一篇解决流量大造成nginx负载过高的问题




      本文转自027ryan  51CTO博客,原文链接: http://blog.51cto.com/ucode/1751414 ,如需转载请自行联系原作者



相关文章
|
8月前
|
应用服务中间件 nginx
Nginx安装nginx-rtmp-module模块
【2月更文挑战第4天】 nginx中的模块虽然就是类似插件的概念,但是它无法像VsCode那样轻松的安装扩展。 nginx要安装其它模块必须同时拿到nginx源代码和模块源代码,然后手动编译,将模块打到nginx中,最终生成一个名为nginx的可执行文件。
596 6
|
8月前
|
应用服务中间件 nginx
百度搜索:蓝易云【利用nginx内置ngx_http_mirror_module模块实现流量复制及流量放大】
以上就是使用Nginx内置 `ngx_http_mirror_module`模块实现流量复制和流量放大的简要示例。通过合理配置和利用该模块,可以实现更复杂的流量控制和调试需求。
130 1
|
5月前
|
负载均衡 应用服务中间件 API
Nginx:location配置模块的用法(一)
Nginx:location配置模块的用法(一)
615 2
|
3月前
|
应用服务中间件 nginx C++
nginx的cgi模块
nginx的cgi模块
57 0
|
5月前
|
缓存 应用服务中间件 nginx
安装nginx-http-flv-module模块
本文介绍如何为Nginx安装`nginx-http-flv-module`模块。此模块基于`nginx-rtmp-module`二次开发,不仅具备原模块的所有功能,还支持HTTP-FLV播放、GOP缓存、虚拟主机等功能。安装步骤包括:确认Nginx版本、下载相应版本的Nginx与模块源码、重新编译Nginx并加入新模块、验证模块安装成功。特别注意,此模块已包含`nginx-rtmp-module`功能,无需重复编译安装。
288 1
|
5月前
|
负载均衡 应用服务中间件 Linux
在Linux中,常用的 Nginx 模块有哪些,常来做什么?
在Linux中,常用的 Nginx 模块有哪些,常来做什么?
|
5月前
|
缓存 前端开发 应用服务中间件
Nginx:location配置模块的用法(二)
Nginx:location配置模块的用法(二)
317 2
|
6月前
|
应用服务中间件 Linux nginx
FFmpeg开发笔记(四十)Nginx集成rtmp模块实现RTMP推拉流
《FFmpeg开发实战》书中介绍了如何使用FFmpeg向网络推流,简单流媒体服务器MediaMTX不适用于复杂业务。nginx-rtmp是Nginx的RTMP模块,提供基本流媒体服务。要在Linux上集成rtmp,需从官方下载nginx和nginx-rtmp-module源码,解压后在nginx目录配置并添加rtmp模块,编译安装。配置nginx.conf启用RTMP服务,监听1935端口。使用ffmpeg推流测试,如能通过VLC播放,表明nginx-rtmp运行正常。更多详情见书本。
160 0
FFmpeg开发笔记(四十)Nginx集成rtmp模块实现RTMP推拉流
|
5月前
|
Ubuntu 前端开发 JavaScript
如何在 Ubuntu 14.04 上为 Nginx 添加 gzip 模块
如何在 Ubuntu 14.04 上为 Nginx 添加 gzip 模块
41 0
|
8月前
|
Ubuntu 应用服务中间件 nginx
ubuntu编译安装nginx及安装nginx_upstream_check_module模块
以上是编译安装Nginx和安装 `nginx_upstream_check_module`模块的基本步骤。根据你的需求和环境,你可能需要进一步配置Nginx以满足特定的要求。
338 3