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

你可能感兴趣的:(服务配置相关)