前言:最近在写业务的时候有用到Memcached的缓存,因为公司的项目不只一台服务器,所以在对缓存中的数值进行操作的时候,我使用了decr和incr方法来解决同步问题。一切都很美好,本地写完测完我就上传远程了,这时坑爹的情况出现了,现上的环境一运行到decr或incr方法的时候就出现如下错误:
10:21:32,908 ERROR ~ Error: CLIENT_ERROR cannot increment or decrement non-numeric value
踩坑:顺便说下我项目用的是play框架,在本地用的时候刚开始没注意是没有配置Memcached的,用的是play框架自带的单独的缓存ECache,所以本地测的时候没问题,但是线上的有配置Memcached。
试验:刚开始看到错误:不能对非数值的数值做inr和decr操作。还以为是自己传入的值有问题,查看后感觉自己没毛病啊,运维给了我个可视化的treenms链接,从上面看我设置的是一个序列化的Object对象,还不能修改,从控制台直接get值,是乱码的,运维说可能是编码格式不同。然后我就从网上查看Memcachedf的使用例子,跳过了封装好的Cache直接去调MemcachedClient,然后发现例子里传的值都是字符串,然后我写个最简单的例子试一下,如下:
能成功运行的例子:
Cache.set("test", "100");
System.out.println(Cache.decr("test"));
99
失败的例子:
Cache.set("test", 100);
System.out.println(Cache.decr("test"));
Error: CLIENT_ERROR cannot increment or decrement non-numeric value