Nginx读取memcached发生乱码
Nginx读取memcached产生乱码
最近研究nginx+memcached.
Nginx配置如下
user nobody nobody; worker_processes 1; error_log /usr/local/nginx/nginx_error.log crit; pid /usr/local/nginx/sbin/nginx.pid; events { use epoll; worker_connections 5120; } http { #include mime.types; # default_type text/html; # sendfile on; # tcp_nodelay on; # upstream memcached { # server 127.0.0.1:22345 weight=4 max_fails=2 fail_timeout=30s; # } # upstream webserver { #server 172.16.20.2:80; # } server { listen 80; server_name localhost; location / { default_type text/html; set $memcached_key $request_uri; memcached_pass 127.0.0.1:22345; error_page 404 = @nodata; } location @nodata { internal; proxy_pass http://XXX.XXX.0.245; break;} } }
是在程序内用memcached客户端存入memcached.
但是在用nginx读取的时候发现所有页面均出现乱码.经多次测试发现页面大小超过16K时就会出现乱码.查询memcached的相关文档得知,是由于memcached客户端内部的一个压缩机制,在页面超过16K时,会自动压缩页面存入memcached.如果用memcached客户端读取的话会自动解压,但是用其他方式读取的话就会成为乱码.
在baidu,google后,发现有两种解决方式.
一种如果是JAVA的memcached客户端的话可以直接设置setCompressEnable关闭压缩功能.
我们用的是coldfusion的memcached客户端,我并没有发现有setCompressEnable这一方法.于是只能用setCompressThreshold来设置文件在多大时才进行压缩.
但是我觉得这种方法并不是很好。因为memcached设置了最大单个缓存大小为1M,如果不压缩的话文件很容易超过1M。
现在解决思路是看nginx是否可以对这种压缩进行解压。