Memcached技术

介绍:

memcached是一种缓存技术, 他可以把你的数据放入内存,从而通过内存访问提速,因为内存最快的, memcached技术的主要目的提速,

在memachec 中维护了一张大的hashtable表 ,该表是在内存,表的结构是

key    value

字串  (字串,数值,数组,对象,布尔,二进制数据,null)

安装并使用memcached

安装步骤

(1)    下载memcached软件

(2)    安装

进入cmd ,切换到 memcached.exe 文件所在目录

memcached.exe –d install

(3)    启动memcached

第一种,可以到服务点击启动

第二种, 命令行

memcached.exe –m 200MB –d start  【以deamon方式启动,默认64M】

如果你在启动时,win7启动不成功, 则可以使用如下方法

memcached.exe –p 端口号

启动方法不要关闭控制台.

端口号的范围 : 0-65535  , 因为端口号是用两个字节来表示

有名端口: 0-1024 已经用程序使用 , apache 80  , mysql 3306 , ftp 21 , ssh 22

oracle: 1521, stmp: 25

使用netstat –an 如果看到 11211端口在监听,说明启动ok

netstat –anb 是哪个程序监听, 这个指令还可以看到有哪些用户连接到我们的服务器.

如果没有安装好,原因可能

  1. 如果你是win7, win7对安全性高,所有,必须以adminstartor 身份来安装.

你切换成adminstrator , 去安装,在启动

  1. 你的memcached.exe 目录有中文,或特殊字符, 保证目录没有中文和特殊字符.

(4)    准备研究如果对memcached进行curd操作.

看看telnet如何操作 (curd)

  1. 登录到telnet连接到 memcached服务

telnet 127.0.0.1  11211

如果你们不能使用telnet 是因为系统不存在 telnet.exe , 就可以到其它机器上拷贝 telnet.exe 放在 c:\windows\system32 即可

  1. 增加

基本语法是:

add key名 0 存放时间(秒) 数据大小(字符)

举例:

add key1 0 30 5

  1. 如何获取

基本语法是:

get key值

get key1

  1. 修改

set key名 0 存放时间 数据大小.

举例:

set key1 0 40 5

☞ 如果key1不存在,则相当于增加新,如果存在,则相当有替换

replace key名 存放时间 数据大小

replace key1 0 40 5

☞ 如果key1不存在,则失败,这个指令要求key必须存在.

  1. 删除

基本语法是

delete key名

比如

delete key1

append

Append data to existing key

append key 0 60 15

prepend

Prepend data to existing key

prepend key 0 60 15

flush_all 可以统一把数据清空.

这里主要大家可以去计算出命中率 cmd_hits/cmd_get . 越高越好.

如何使用php程序操作我们的memcached服务 curd.

步骤,准备工作.

(1)    把 php_memcache.dll 文件拷贝 php的ext 下

☞ 不同版本的php 所使用的 php_memcache.dll 的版本不一样

(2)    修改php.ini文件,加载 php_memcache.dll (该文件就是封装了一堆函数)

;加载php_memcache.dll 文件

extension=php_memcache.dll

(3)    重新启动apache

(4)    我们写程序来完成curd操作.

细节: 在我们添加数据的时候,如果

bool Memcache::add ( string $key , mixed $var [, int $flag [, int $expire ]] )

如果报 expire 设为0 表示,永不过期.(只要memcache不重新启动,就永远在mem中)

exprie 直接给的是秒数,则最大 30*3600*24

如果你希望保持时间超过30  time()+天数*3600*24 即可

最后代码:

mem1.php

<?php

//创建一个mem对象实例

$mem=new Memcache;

if(!$mem->connect("127.0.0.1",11211)){

die('连接失败!');

}

//增加

//1.增加一个字串

/*    if($mem->set('key1',"beijing",MEMCACHE_COMPRESSED,60)){

echo '添加ok';

}*/

//2.添加数值

/*    if($mem->set('key1',100,MEMCACHE_COMPRESSED,60)){

echo '添加ok';

}*/

//3.添加数组

//在添加数组是,根据需要. 希望序列号放入  ,

//serialize<=>unserialize, 如果根据需要,也可以json_encode <=> json_decode

$arr=array("bj",'tj');

if($mem->set('key1',$arr,MEMCACHE_COMPRESSED,time()+31*3600*24)){

echo '添加数组ok99111';

}

//4.添加对象

/*    class Dog{

public $name;

public $age;

public function __construct($name,$age){

$this->name=$name;

$this->age=$age;

}

}

$dog1=new Dog('小狗',50);

if($mem->set('key1',$dog1,MEMCACHE_COMPRESSED,60)){

echo '添加对象ok';

}*/

//5.添加null 布尔值

/*    if($mem->set('key1',false,MEMCACHE_COMPRESSED,60)){

echo '添加布尔ok';

}*/

//6. 资源类型放入.

/*    $con=mysql_connect("127.0.0.1","root","root");

if(!$con){

die('连接数据库失败');

}

var_dump($con);

echo "<br/>";

if($mem->set('key1',$con,MEMCACHE_COMPRESSED,60)){

echo '添加资源ok';

}*/

//查询

$val=$mem->get('key1');

var_dump($val);

//修改

//可以使用replace

if($mem->replace("key11",'hello',MEMCACHE_COMPRESSED,60)){

echo 'replace ok';

}else{

echo 'replace no ok';

}

//删除

echo "<br/>";

if($mem->delete('key14')){

echo 'key14 删除';

}else{

echo 'key14不存在';

}

mem2.php

<?php

//这个文件去操作memcached服务

//创建一个mem对象实例

$mem=new Memcache;

if(!$mem->connect("127.0.0.1",11211)){

die('连接失败!');

}

//在另外文件中取出对象时,有个注意的地方,对应php5.2这个版本会提示错误,

//对php5.3这个版本会提示 incomplete 信息, 解决方法是声明类定义即可

class Dog{

public $name;

public $age;

public function __construct($name,$age){

$this->name=$name;

$this->age=$age;

}

}

$dog=$mem->get('key1');

var_dump($dog);

test.php 说明serilize 和 json_encode用法:

//什么时候使用serilize 什么时候使用json_encode [ajax配合]

练习: 请大家使用php 程序 memcache.dll 完成对memcahce增删改查

20min

如何使用PHP源码来操作memcached服务

如果管理员不让我们去加载 memcache.dll 文件,我们可以直接通过源码操作.

关闭扩展.

代码mem3.php

<?php

require_once 'memcached-client.php';

$mc = new memcached(array(

'servers' => array('127.0.0.1:11211'), //连接的memcacheip和端口

'debug'   => false, //是否debug

'compress_threshold' => 10240, /*最大压缩*/

'persistant' => true)); /*是否是持久连接*/

$mc->set('key1', array('some', 'array'));

// $mc->replace('key', 'some random string');

$val = $mc->get('key1');

var_dump($val);

//修改

$mc->replace('key1', "北京");

$val = $mc->get('key1');

var_dump($val);

//删除

$mc->delete('key1');

$val = $mc->get('key1');

echo "删除后";

var_dump($val);

Memcached 机制的深入了解

③ , memcache的数据是放入到内存,并且在数据爆满的情况下,使用LRU 算法删除

写段代码说明: mem4.php

mem5.php 取出.

总结:

  1. mem服务的数据不是同步, 数据是分布的
  2. 把什么数据放入到哪个memcached是由客户端的mem对象决定
  3. 当执行addServer的时候,并不是立即去连接mem服务,而是通过计算,hash后才去决定连接哪个mem服务,因此当你大量加入服务器到连接池,没有多余开销

u  memcache的细节讨论

①     生命周期

从数据放入mem开始计时,直到时间到了,就销毁, 如果时间为0, 则表示不过期.

memcache的数据被销毁的情况如下:

  1. 时间到
  2. 重启memcached服务
  3. 重启memcached服务所在的机器
  4. delete / flush 销毁数据

②     如何把session数据放入到memcached服务中.

步骤:

  1. 修改php.ini的配置文件

如下:

;[sesson.save_handler 有user|files|memcache]

session.save_handler = memcache

session.save_path = "tcp://127.0.0.1:11211"

③     测试一把,重启apache

测试ok

<?php

//传统的代码

session_start();

$_SESSION['name']='天龙八部300';

$_SESSION['city']='beijing';

class Dog{

public $name;

}

$dog1=new Dog;

$dog1->name='abcde';

$_SESSION['dog']=$dog1;

//如果session数据入mem,那他一定是以session_id为

//key值进行添加

//取出

$name=$_SESSION['name'];

echo "name=$name";

echo "sessionid=".session_id();

思考,如果管理员,不让我们修改 php.ini 文件,我们如何处理session入memcached这个功能, 我们通过一个函数可以去修改 php.ini 的配置.

代码:

<?php

ini_set("session.save_handler","memcache");

ini_set("session.save_path","tcp://127.0.0.1:9999");

同时你也可以通过 ini_set 去动态的修改对php.ini 的其它设置 。但是他不影响其它php页面,也不会去修改php.ini 文件本身, 只对本页面生效.

memcached vs session比较

memcached 主要的目的是提速 ,因此它是一种无状态的数据.即,数据不和用户绑定.

session数据是和绑定的,因此是一种有状态数据.

memached安全性

如何使用memcached 服务才是安全的.

在windows下通过启用防火墙来保护我们的memcached,原理图:

在linux 也可以使用防火墙.

setup 配置防火墙

iptables -a input -p tcp -s 127.0.0.1 -dport 11211 -j ACCEPT

什么样的数据适合放入memcached中?

和memcached技术类似是redis (key/value数据库)

课后练习:

这个这个

这个练习主要是让大家去练习crud的操作.

Memcached技术的更多相关文章

  1. memcached 技术支持

    1. Install sudo apt-get install memcached 2.启动和停止 启动: service memcached start 停止: service memcached ...

  2. memcache/memcached安装教程并应用Tinkphp3.2

    在自己的新程序中打算全面应用memcached技术,这个很容易理解这是memcached是内存缓存,但是怎么还有memcache呢?其实很简单,memcache是php的一个扩展,用于php管理mem ...

  3. memcached学习笔记2--安装及命令

    学习memcached的原理: 用户一 -> 访问浏览器 -> 服务器Apache -> PHP文件(该文件应用了memcached技术) -> [第一次]到数据库DB中查找数 ...

  4. windows下AppServ安装php的memcached扩展

    memcache和memcached的区别  在自己的新程序中打算全面应用memcached技术,这个很容易理解这是memcached是内存缓存,但是怎么还有memcache呢?  其实很简单,mem ...

  5. win7下64位系统memcache/memcached安装教程

    折腾了1个多小时,终于搞定.操作系统时64位的,php5.3.13 类似于上一篇的xdebug安装教程~~ memcache和memcached的区别  在自己的新程序中打算全面应用memcached ...

  6. wamp在win7下64位系统memcache/memcached安装教程

    折腾了1个多小时,终于搞定.操作系统时64位的,php5.3.13 类似于上一篇的xdebug安装教程~~ memcache和memcached的区别  在自己的新程序中打算全面应用memcached ...

  7. Memcached的安装与使用

    这一段折腾了下Memcached,有所收获吧,记录一下. 1.什么是Memcached memcached是一种缓存技术, 他可以把你的数据放入内存,从而通过内存访问提速,因为内存最快的, memca ...

  8. tp下的memcached运用

    来源:http://blog.csdn.net/fudaoji/article/details/50722839   侵删 一.环境: lnmp开发服务器, memcached2.2.0,thinkp ...

  9. spring-aop + memcached 的简单实现

    一般情况下,java程序取一条数据是直接从数据库中去取,当数据库达到一定的连接数时,就会处于排队等待状态,某些在一定时间内不会发生变化的数据,完全没必要每次都从数据库中去取,使用spring-aop ...

随机推荐

  1. ant design环境搭建过程中遇到的问题--Windows-dva-cli

    基础的此处略去,nodejs和npm是前提. 1.官网介绍的是脚手架工具是antd-init,但是又建议真实项目中用dva-cli,所以博主就直接装的是dva-cli,这里主要是简单介绍下博主在Win ...

  2. j2ee应用开发调试工具

    j2ee应用程序不能独立运行,需要运行在一个servlet/jsp容器中,常用的servlet/jsp容器如:tomcat,jetty等.在开发调试j2ee程序时,也需要部署在一个指定的容器中.如果每 ...

  3. Silverlight设计器——Path

    如下图,在设计一个InfoWindow的时候,顶栏的关闭按钮没有出现.观察了半天,也没有弄明白.无意中,拖动一个几乎透明的信息框,突然就出现了关闭的按钮.原来,那个信息框只是一个Path,它遮住了关闭 ...

  4. Python3.6 Schedule模块定时任务

    本文使用Python的Schedule模块.Python访问数据库的框架SQLAIchemy 实现了一个:周期性读取mysql 数据的小示例. 一,编程环境 PyCharm2016,Anaconda3 ...

  5. WEUI Picker不切换数据

    /*js部分,myPicker是设备号input的ID*/ $('#myPicker').change(function () { /*选择设备号后,根据当前设备号设置不同的摄像头选项,具体判断逻辑根 ...

  6. c# 线程锁 ,

    using System; using System.Collections.Generic; using System.Text; using System.Threading; namespace ...

  7. sql插入oracle链接的数据

    报错OLE DB 访问接口 "OraOLEDB.Oracle" 返回了消息 "ORA-29275: 部分多字节字符". select addr from tes ...

  8. 状压DP初探·总结

    2018过农历新年这几天,学了一下状态压缩动态规划,现在先总结一下.   状态压缩其实是一种并没有改变dp本质的优化方法,阶段还是要照分,状态还是老样子,决策依旧要做,转移方程还是得列,最优还是最优, ...

  9. 查看linux服务器CPU相关

    查看linux服务器CPU相关: 1.查看物理CPU个数 cat /proc/cpuinfo| grep "physical id"| sort| uniq| wc -l 2.查看 ...

  10. C++11 线程并发

    并发 头文件<future> <thread> 高级接口 async().future<> future<int> result1; //int为fun ...