php经过twemproxy无法delete后端memcache值的解决方法

php操作memcache的代码如下:



[[email protected] mc]# cat memcache.php
<?php

$conf = array(
    array("host" => ‘192.168.8.57‘, "port" => ‘7522‘),
    //array("host" => ‘192.168.90.130‘, "port" => ‘7510‘),
    //array("host" => ‘192.168.30.22‘, "port" => ‘7011‘)
    //array("host" => ‘192.168.30.23‘, "port" => ‘7030‘)
    //array("host" => ‘192.168.1.61‘ , "port" => ‘11211‘),
);
$memcache = new Memcache();
memcache_debug(true);
foreach ($conf as $memCachedConfig) {
    @$memcache->addServer($memCachedConfig[‘host‘], $memCachedConfig[‘port‘]);
}

$str = "test";
@$memcache->set(‘testkey‘, $str);
echo $memcache->get(‘testkey‘);
echo "\n";
try{
$rs = $memcache->delete(‘testkey‘, 0);
}catch( Exception $e ){
    print_r($e->getMessage());
}
var_dump($rs);
echo "\n";
echo $memcache->get(‘testkey‘);

#备注:192.168.8.57为haproxy的虚ip,后端指向的是192.168.30.21和192.168.30.22这两个twemproxy,然后twemproxy的后端又是192.168.30.21、192.168.30.22、192.168.30.23、192.168.30.24这4个memcache



执行但无法删除的显示结果如下:

[[email protected] mc]# php memcache.php
test
bool(false)##如果删除成功显示的应该是true



问题的原因定位是因为php的memcache扩展版本过低造成的,应该是php的低版本memcache的一个bug,升级就可以解决了

升级前:

升级后:

升级步骤:

wget "https://pecl.php.net/get/memcache-3.0.8.tgz"

tar xf memcache-3.0.8.tgz
cd memcache-3.0.8

/usr/local/webserver/php/bin/phpize

./configure --with-php-config=/usr/local/webserver/php/bin/php-config

make

make install

/kuxun/php-cgid restart

php -m | grep mem

查看phpinfo的方法

nginx配置如下:

[[email protected] sites-enabled]# vim op.conf

log_format  op_log "$remote_addr" - "$remote_user" [$time_local] "$request"
                   "$status" "$body_bytes_sent" "$http_referer"
                   "$http_user_agent" "$http_x_forwarded_for";
server {
        listen 80;
        server_name 192.168.90.99;
        set $ROOT_PATH /home/himalayas/op;

location / {
        #auth_basic            "Password please";
        #auth_basic_user_file  /usr/local/webserver/nginx/conf/htpasswd;
        root $ROOT_PATH;
        index index.php;
        }

location ~ .php$ {
        root $ROOT_PATH;
        fastcgi_pass  unix:/tmp/php-cgi.sock;
        fastcgi_param  SCRIPT_FILENAME  $ROOT_PATH$fastcgi_script_name;
        send_timeout 300;
        fastcgi_buffers 8 256k;
        include /usr/local/webserver/nginx/conf/fastcgi_params;
    }

access_log /home/nginxlog/accesslog/access.log op_log;
        error_log /home/nginxlog/errorlog/error.log;
}

代码如下:

[[email protected] ~]# cat /home/himalayas/op/test.php
<?php
phpinfo();
?>

访问方式:http://192.168.90.99/test.php

时间: 2024-12-26 03:30:24

php经过twemproxy无法delete后端memcache值的解决方法的相关文章

从客户端中检测到有潜在危险的Request.Form值的解决方法

描述:从客户端中检测到有潜在危险的Request.Form值的解决方法asp.net 2.0 通常解决办法将.aspx文件中的page项添加ValidateRequest="false"或者修改配置文件 <system.web> <pages validateRequest="false" > </pages> </system.web> 从客户端中检测到有潜在危险的Request.Form值的解决方法

BootStrap iCheck插件全选与获取value值的解决方法

这篇文章主要介绍了BootStrap iCheck插件全选与获取value值的解决方法,解决方法其实很简单,下面小编给大家分享下这方面的知识 在使用jQuery iCheck 插件的时候遇到了一个问题,就是当我们使用普通的js全选功能无效了. $("#checkall").click( function(){ if(this.checked){ $("input[name='checkname']").each(function(){this.checked=tru

【异常记录(七)】MVC:从客户端中检测到有潜在危险的 Request.Form 值 的解决方法 [转]

从客户端(Content="<EM ><STRONG ><U >这是测试这...")中检测到有潜在危险的Request.Form 值. 说明: 请求验证过程检测到有潜在危险的客户端输入值,对请求的处理已经中止.该值可能指示存在危及应用程序安全的尝试,如跨站点脚本攻击. 若要允许页面重写应用程序请求验证设置,请将 httpRuntime 配置节中的 requestValidationMode 特性设置为requestValidationMode=&qu

ashx页面 “检测到有潜在危险的 Request.Form 值”的解决方法(控制单个处理程序不检测html标签)

如题: 使用web.config的configuration/location节点. 在configuration节点内新建一个location节点,注意这个节点和system.webserver那些是平级节点 然后使用location/@path 来指定某个单独的文件,这个文件可以是aspx也可以是ashx,更加可以是Razor模板的cshtml(当然MVC有Unvalidated方法,用不到这样), 然后在location下面配置page和httpruntime(4.0)节的属性就OK了.这

bootstrap iCheck插件 全选和获取value值的解决方法

在使用jQuery iCheck 插件的时候遇到了一个问题,就是当我们使用普通的js全选功能无效了. $("#checkall").click(     function(){         if(this.checked){             $("input[name='checkname']").each(function(){this.checked=true;});         }else{             $("input[

javascript使用for循环批量注册的事件不能正确获取索引值的解决方法

今天遇到一个问题,那就是当使用for循环批量注册事件处理函数,然后最后通过事件处理函数获取当前元素的索引值的时候会失败,先看一段代码实例: <script type="text/javascript"> window.onload=function(){ var oLis=document.getElementsByTagName("li"); var oshow=document.getElementById("show"); fo

从客户端中检测到有潜在危险的Request.Form值 的解决方法

在提交表单时候,asp.net 提示:"从客户端(......)中检测到有潜在危险的 Request.Form 值" .asp.net中的请求验证特性提供了某一等级的保护措施防止XSS攻击,asp.net的请求验证是默认启动的.这个给出各个版本.net的解决方法. asp.net 2.0 通常解决办法 方案一: 将.aspx文件中的page项添加ValidateRequest="false" ,如下: <%@ Page ValidateRequest=&quo

DataGridViewComboBoxColumn值无效解决方法

值无效,可能是你下拉框选项,没有这样的值,而你却设置这个值. dataGridView1.Rows[i].Cells[1].Value?=?"选项一"; 解决方法就是在窗体的构造函数里添加如下代码: this.dataGridView1.DataError?+=?delegate(object?sender,?DataGridViewDataErrorEventArgs?e)?{?}; 1.必须确定,给DataVridView赋值,是在DataGridViewComboBox已经绑定了

KindEditor得不到textarea值的解决方法----摘至天涯

以前有朋友遇到过这个问题,就是KindEditor在火狐下或者其他浏览器下都无法得到textarea文本框的值,点击表单提交按钮得到的是空白.昨天天涯PHP博客[http://blog.phpha.com]也无意遇到这个问题,于是想认真找下原因. 首先描述下我这边KindEditor的错误现象: 1.在IE8/FF下均得不到值: 2.当点击KindEditor的全拼按钮切换到全屏模式输入时,再返回正常模式,可以得到值: 3.我用的是jQuery的点击事件提交表单的,提交,无法得到值: 4.直接用