一:配置php扩展memcached

wget http://memcached.googlecode.com/files/memcached-1.4.9.tar.gz


# tar zvxf memcached-1.4.9.tar.gz
# cd memcached-1.4.9


 /usr/bin/phpize   #生成configure编译文件



如果这里出现


Can’t find PHP headers in /usr/include/php
    The php-devel package is required for use of this command


那么执行 yum install php-devel


 ./configure --with-php-config=/usr/bin/php-config \

make && make insll  

会提示找到memcache.so位置
Installing shared extensions: /usr/local/webserver/php/lib/php/extensions/no-debug-non-zts-20060613/      [不同的电脑提示也不同]

修改php.ini

先找到Php.ini的位置

find / -name php.ini

vim xxx/xxx/xxx/php.ini

extension=/根据提示的mecached的位置/memcache.so ;

杀死php进程:pkill -9 php

重启php:./usr/bin/php-fpm
最后检查memcached是否安装成功  127.0.0.1 查看是否有memcache 模块。
---------------------------------------------------------
利用telnet 测试memcached

超找memcached的位置 find / -name memcached

./usr/local/memcached/bin/memcached -m 64 -p 11211 -vvv

【注意不能是root用户开启】  ./usr/local/memcached/bin/memcached -u nobody -vv -p 11211

----------------------------------------------------------------------------------------------------------------

如果上面的不能够安装memcached就按这里的方式来安装。

wget -c http://www.memcached.org/files/memcached-1.4.17.tar.gz
tar -zxvf memcached-1.4.17.tar.gz

cd memcached-1.4.17
./configure --prefix=/usr/local/memcached
make
sudo make install

第三步:启动memcached

cd /usr/local/memcached
./bin/memcached -d -m 1024 -u root -l 127.0.0.1 -p 11211

第三步:检查是否安装成功

$ps -aux | grep memcache 

-----------------------------------------------------------------------------------------------------

测试是否安装了telnet

rpm -q telnet-server 无信息回复表示没安装

安装 telnet

yum install telnet

在linux上打开一个窗口 打开telnet服务

telnet 127.0.0.1 11211 回车

ctrl+] 打开回显回车。

在linux上打开一个窗口 测试mecached

add news 0 0 8 /

12345678 回车

get news 回车

-------------------------------------------------------

二:nginx配置

(1)配置nginx.conf 信息
   location / {

#设置key
     set $memcached_key "$uri";
     #根据key查找对应的服务器
     memcached_pass 127.0.0.1:11211;
     #出错的时候回调php,查找数据库中的数据
     error_page 404 /callback.php;

}

在linux上打开一个窗口 打开telnet服务

telnet 127.0.0.1 11211 回车

ctrl+] 打开回显回车。

在linux上打开一个窗口添加一个memcache key

add /4.html 0 0 10 /
   hello word

浏览器上测试:输入 127.0.0.1/4.html

浏览器上显示:hello word

(2)新建测试数据
mysql -uroot -p;
use test; CREATE TABLE `abc_table` (

`uid` int(10) unsigned NOT NULL AUTO_INCREMENT,
   `name` varchar(25) NOT NULL,
    PRIMARY KEY (`uid`)
   ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

insert abc_table values(null,'1.html page');
 insert abc_table values(null,'2.html page');

insert abc_table values(null,'3.html page');

insert abc_table values(null,'4.html page');

insert abc_table values(null,'5.html page');

insert abc_table values(null,'6.html page');

insert abc_table values(null,'7.html page');

insert abc_table values(null,'8.html page');

insert abc_table values(null,'9.html page');

 insert abc_table values(null,'10.html page');

select * from abc_table
+-----+--------------+
| uid | name |
+-----+--------------+
| 1 | 1.html page |
| 2 | 2.html page |
| 3 | 3.html page |
| 4 | 4.html page |
| 5 | 5.html page |
| 6 | 6.html page |
| 7 | 7.html page |
| 8 | 8.html page |
| 9 | 9.html page |
| 10 | 10.html page |
+-----+--------------+

(3)编写callback.php  要是在nginx的html目录文件夹中编写。

<?php
  header("Content-type: text/html; charset=utf-8");

$uri=$_SERVER['REQUEST_URI'];

#/user4243.html

#字符串截取获取数字

$uid=substr($uri,5,strpos($uri,'.')-5);
  # echo $uid;die;
  #连接数据库并入memcached

$con=mysql_connect("localhost","root","root");

  $sql='use test';
  mysql_query($sql,$con);
  $sql="set names utf8";
  $sql="select * from abc_table where uid=".$uid;
  # echo $sql ;die;

$rs=mysql_query($sql,$con);

$sql="set names utf8";
  $sql="select * from abc_table where uid=".$uid;
  # echo $sql ;die;

$rs=mysql_query($sql,$con);

$user=mysql_fetch_assoc($rs);

if(empty($user)){
     echo "用户不存在";
   }else{
    #写入memcached
    $men=new memcache();
    $men->connect('localhost',11211);
    #echo '2222';
    $men->add($uri,$user['name'],0,300);
    $men->close();
}

(4)测试是否连接成功memcache
浏览器输入:127.0.0.1/user1.html 出现空白
再次刷新 出现数据

可以通过telnet窗口观察其中取值的变化。 --------------------------------------------------------------------------------------------------------------
请求过程如下图

17 nginx连接memcached的更多相关文章

  1. Nginx网络架构实战学习笔记(四):nginx连接memcached、第三方模块编译及一致性哈希应用

    文章目录 nginx连接memcached 第三方模块编译及一致性哈希应用 总结 nginx连接memcached 首先确保nginx能正常连接php location ~ \.php$ { root ...

  2. 手把手让你实现开源企业级web高并发解决方案(lvs+heartbeat+varnish+nginx+eAccelerator+memcached)

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://freeze.blog.51cto.com/1846439/677348 此文凝聚 ...

  3. 【转】Nginx+Tomcat+Memcached集群Session共享

    cookie是怎样工作的? 例 如,我们创建了一个名字为login的Cookie来包含访问者的信息,创建Cookie时,服务器端的Header如下面所示,这里假设访问者的注册名 是“Michael J ...

  4. 为php安装memcached扩展连接memcached服务器

    首先必须完成必要的软件安装,memcached是php连接memcached服务器的php扩展 以前有个叫memcache也是php连接memcached服务器的扩展 php的memcache和mem ...

  5. Nginx+Tomcat+Memcached负载均衡集群服务搭建

    操作系统:CentOS6.5  本文档主要讲解,如何在CentOS6.5下搭建Nginx+Tomcat+Memcached负载均衡集群服务器,Nginx负责负载均衡,Tomcat负责实际服务,Memc ...

  6. session服务器Nginx+Tomcat+Memcached集群Session共享

    cookie是怎样工作的? 例如,我们创立了一个名字为login的Cookie来包含访问者的信息,创立Cookie时,服务器端的Header如下面所示,这里假设访问者的注册名是“Michael Jor ...

  7. Nginx+Tomcat+Memcached 实现集群部署时Session共享

    Nginx+Tomcat+Memcached 实现集群部署时Session共享 一.简介 我们系统经常要保存用户登录信息,有Cookie和Session机制,Cookie客户端保存用户信息,Sessi ...

  8. Nginx+Tomcat+memcached高可用会话保持

    Nginx+Tomcat+memcached高可用会话保持 文章来源dyc2005   一.概述 之前文章已经描述了企业高可用负载相关的架构及实现,其中常用的nginx或haproxy,LVS结合ke ...

  9. Nginx+Tomcat8+Memcached实现负载均衡及session共享

    1> 基础环境 简易拓扑图: 2> 部署Tomcat [root@node01 ~]# ll -h ~ |egrep 'jdk|tomcat'-rw-r--r-- 1 root root ...

随机推荐

  1. mdf 与 mdb的对比

    下面的内容从网上搜索而来,未经过本人严格验证,仅供参考. 1.问:mdb数据库能否脱离Access运行?即,没有安装Access,可以打开mdb吗? 答:可以,脱离Access运行,可以到微软的同类产 ...

  2. mysql 增加字段

    alter table 表名 add 字段 varchar(500) comment '备注' default 0 after 字段;

  3. react native windows create bundle folder

    生成bundle 文件 命令 react-native bundle --platform android --dev false --entry-file index.js --bundle-out ...

  4. Oracle 表分区partition(http://love-flying-snow.iteye.com/blog/573303)

    http://www.jb51.net/article/44959.htm Oracle表分区分为四种:范围分区,散列分区,列表分区和复合分区. 一:范围分区 就是根据数据库表中某一字段的值的范围来划 ...

  5. windows内核实现的34个关键问题

    http://book.kongfz.com/237217/670391178/#bookComm

  6. 双网卡环境导致Oracle连接异常

    现在就是流行向最高水平看齐,这次项目的部署,好好的SQL Server扔了(有正版授权的企业版,神啊...),逢人就夸:“俺们那上的可是最顶级的Oracle Database System!”.看了看 ...

  7. 爬虫:网页里元素的xpath结构,scrapy不一定就找的到

    这种情况原因是html界面关联的js文件可能会动态修改DOM结构,这样浏览器完成了动态修改DOM,在 浏览器上看到的DOM结构,就和后台抓到的DOM结构不通 举例:新浪微博发的微博,在浏览器通过fir ...

  8. JS请求报错:Unexpected token T in JSON at position 0

    <?php /* 最近做一个ajax validate表单验证提交的代码,在ajax提交的时候 JS请求报错:Unexpected token T in JSON at position 0 描 ...

  9. EasyMvc入门教程-高级控件说明(17)对话框控件

    上一节我们说到的信息框比较简单,如果我们想简单实现用户用户交互,比如常用的锁屏界面,应该如何实现呢?首先看效果: 当用户输入"mxd",后,界面显示如下: 以上效果的实现代码为: ...

  10. 【重点突破】——第三方绘图工具FusionCharts.js的使用详解

    一.引言 项目组中,经常会因为绘制图表的繁杂度,衡量会不会使用第三方绘图工具,如果自己做很困难,成本使用高于第三方绘图工具库,就会使用.很多人使用的是Chart.js,因为它是免费使用的,不过,缺点就 ...