首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > Web前端 >

Nginx读取memcached发生乱码

2012-10-13 
Nginx读取memcached产生乱码最近研究nginx+memcached.Nginx配置如下user nobody nobody worker_processes

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是否可以对这种压缩进行解压。

热点排行