文档章节

对php中 memcache的详解

c
 chenhongjiang
发布于 2016/03/21 23:35
字数 1491
阅读 29
收藏 2

memcahe 是一个分布式储存系统,分布式主要体现在各个服务器之间是没有联系的,主要是通过内存来维护一张hash表,hash表主要是以键值对方式存储的,就是一款cs软件包.

key

value

mystr

abc

myarr

Array(aacc);

object

Object


工作原理

Memcache 软件, memcached

memcached是以守护程序方式运行在一个或者多个服务之中,随时客服端的操作和连接.


关于memcache的安装

在linux 下面的安装

  基于libevent事件
        Linux下
        安装libevent时
            ./configure –with-libevent=/usr
            Make && make install

        安装memcached
            ./configure –with-libevent=/usr

            Make && make install

           启动Memcahced –d –m 128 –l 192.168.1.111 –p 11211 –u root
            停止: kill `cat /tmp/memcached.pid`;
            Killall  memcached

   Windows下
            Memcahced.exe  -d  install [uninstall]
            Memcached.exe –d  -m 50 –l 127.0.0.1  -p 11211 start


、Memcached服务器的管理(启动)
        memcached的基本设置:
-p 监听的端口
-l 连接的IP地址, 默认是本机
-d start 启动memcached服务
-d restart 重起memcached服务
-d stop|shutdown 关闭正在运行的memcached服务
-d install 安装memcached服务
-d uninstall 卸载memcached服务
-u 以的身份运行 (仅在以root运行的时候有效)
-m 最大内存使用,单位MB。默认64MB ,最大好像2G
-M 内存耗尽时返回错误,而不是删除项
-c 最大同时连接数,默认是1024
-f 块大小增长因子,默认是1.25
-n 最小分配空间,key+value+flags默认是48
-h 显示帮助


七、如何遍历memcache

八、在PHP程序中使用Memcached
    a 在PHP安装Memcache扩展

        可以按面向过程方式

        面向对象的方式

    b 在PHP什么地方使用memcache

        一、 数据库读出来的数据(select)使用memcache处理
        
        二、 在会话控制session中使用

    c 实例

九、Memcache的安全(不让别人访问)

    1 .内网
    2. 设置放火墙
         Iptables –A INPUT –p tcp –s 192.168.1.111 –dport 11211 –j ACCEPT
         Iptables –A INPUT –p udp –s 192.168.1.111 –dpost 11211 –j ACCEPT
        

安装. 然后开始 memcached -d start

Command

Description

Example

get

Reads a value

get mykey

set

Set a key unconditionally

set mykey 0 60 5

add

Add a new key

add newkey 0 60 5

replace

Overwrite existing key

replace key 0 60 5

append

Append data to existing key

append key 0 60 15

prepend

Prepend data to existing key

prepend key 0 60 15

incr

Increments numerical key value by given number

incr mykey 2

decr

Decrements numerical key value by given number

decr mykey 5

delete

Deletes an existing key

delete mykey

flush_all

Invalidate specific items immediately

flush_all

Invalidate all items in n seconds

flush_all 900


stats

Prints general statistics

Stats

Prints memory statistics

stats slabs


Prints memory statistics

stats malloc


Print higher level allocation statistics

stats items



stats detail



stats sizes


Resets statistics

stats reset


version

Prints server version.

version

verbosity

Increases log level

verbosity

quit

Terminate telnet session

quit

 

 

 

pid

memcache服务器的进程ID

uptime

服务器已经运行的秒数

time

服务器当前的unix时间戳

version

memcache版本

pointer_size

当前操作系统的指针大小(32位系统一般是32bit)

rusage_user

进程的累计用户时间

rusage_system

进程的累计系统时间

curr_items

服务器当前存储的items数量

total_items

从服务器启动以后存储的items总数量

bytes

当前服务器存储items占用的字节数

curr_connections

当前打开着的连接数

total_connections

从服务器启动以后曾经打开过的连接数

connection_structures

服务器分配的连接构造数

cmd_get

get命令(获取)总请求次数

cmd_set

set命令(保存)总请求次数

get_hits

总命中次数

get_misses

总未命中次数

evictions

为获取空闲内存而删除的items数(分配给memcache的空间用满后需要删除旧的items来得到空间分配给新的items)

bytes_read

总读取字节数(请求字节数)

bytes_written

总发送字节数(结果字节数)

limit_maxbytes

分配给memcache的内存大小(字节)

threads

当前线程数




pid    memcache服务器的进程ID
uptime    服务器已经运行的秒数
time    服务器当前的unix时间戳
version    memcache版本
pointer_size    当前操作系统的指针大小(32位系统一般是32bit)
rusage_user    进程的累计用户时间
rusage_system    进程的累计系统时间
curr_items    服务器当前存储的items数量
total_items    从服务器启动以后存储的items总数量
bytes    当前服务器存储items占用的字节数
curr_connections    当前打开着的连接数
total_connections    从服务器启动以后曾经打开过的连接数
connection_structures    服务器分配的连接构造数
cmd_get    get命令(获取)总请求次数
cmd_set    set命令(保存)总请求次数
get_hits    总命中次数
get_misses    总未命中次数
evictions    为获取空闲内存而删除的items数(分配给memcache的空间用满后需要删除旧的items来得到空间分配给新的items)
bytes_read    总读取字节数(请求字节数)
bytes_written    总发送字节数(结果字节数)
limit_maxbytes    分配给memcache的内存大小(字节)
threads    当前线程数


具体可以参考PHP手册 “LXXXIV. Memcache Functions” 这章。
  Memcache面向对象的常用接口包括:
  Memcache::connect -- 打开一个到Memcache的连接
  Memcache::pconnect -- 打开一个到Memcache的长连接
  Memcache::close -- 关闭一个Memcache的连接
  Memcache::set -- 保存数据到Memcache服务器上
  Memcache::get -- 提取一个保存在Memcache服务器上的数据
  Memcache::replace -- 替换一个已经存在Memcache服务器上的项目(功能类似Memcache::set)
  Memcache::delete -- 从Memcache服务器上删除一个保存的项目
  Memcache::flush -- 刷新所有Memcache服务器上保存的项目(类似于删除所有的保存的项目)
  Memcache::getStats -- 获取当前Memcache服务器运行的状态
  Memcache::addServer -- 分布式服务器添加一个服务器

使用 php 操作 memcache 


<?php
    $mem=new Memcache;

    $mem->connect("localhost", 11211);

    /*
     * 注意:
     *     1. 同一个项目安装两次,key要有前缀
     *    
     *
     */

    $sql="select * from shops";
    $key=substr(md5($sql), 10, 8);

    $data=$mem->get($key);

    if(!$data){    

        $mysqli=new mysqli("localhost", "root", "123456", "xsphpdb");

        $result=$mysqli->query($sql);

        $data=array();

        while($row=$result->Fetch_assoc()){
            $data[]=$row;
        }

        $result->free();
        $mysqli->close();

        $mem->set($key, $data, MEMCACHE_COMPRESSED, 3600);

        echo $sql;

    }
    echo '<pre>';
    print_r($data);
    echo '</pre>';

    $mem->close();


比较不错的资料 推荐  http://my.oschina.net/leetiger/blog/201248#OSC_h3_2


© 著作权归作者所有

c
粉丝 2
博文 71
码字总数 42353
作品 0
朝阳
私信 提问
加载中

评论(1)

染心
染心
13
PHP MEMCACHE 详解 php缓存

Memcache函数库是在 PECL(PHP Extension Community Library)中,主要作用是搭建大容量的内存数据的 临时存放区域,在分布式的时候作用体现的非常明显,否则不建议使用。 本人在ubuntu上安装 ...

啊和
2012/07/27
59
0
Memcache所有方法及参数详解以及使用方法

参考http://www.php.net/manual/zh/function.Memcache-add.php Memcache::add - 添加一个值,如果已经存在,则返回false Memcache::addServer - 添加一个可供使用的服务器地址 Memcache::cl...

zchd
2013/02/21
0
0
PHP中的Memcache详解

一、Memcache简介 Memcache是danga.com的一个项目,最早是为 LiveJournal 服务的,目前全世界不少人使用这个缓存项目来构建自己大负载的网站,来分担数据库的压力。它可以应对任意多个连接,...

沉淀岁月
2016/09/09
30
0
PHP中Memcache类函数详解

Memcache类函数列表如下: Memcache::add – 添加一个值,如果已经存在,则返回false Memcache::addServer – 添加一个可供使用的服务器地址 Memcache::close – 关闭一个Memcache对象 Memc...

Junn
2015/01/06
281
0
Memcache的安装使用及与mysql交互实例

一、Memcache介绍 Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等...

行者PHPer
2012/05/06
1K
0

没有更多内容

加载失败,请刷新页面

加载更多

OSChina 周四乱弹 —— 当你简历注水但还是找到了工作

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @花间小酌 :#今日歌曲推荐# 分享成龙的单曲《男儿当自强》。 《男儿当自强》- 成龙 手机党少年们想听歌,请使劲儿戳(这里) @hxg2016 :刚在...

小小编辑
今天
3K
22
靠写代码赚钱的一些门路

作者 @mezod 译者 @josephchang10 如今,通过自己的代码去赚钱变得越来越简单,不过对很多人来说依然还是很难,因为他们不知道有哪些门路。 今天给大家分享一个精彩的 GitHub 库,这个库整理...

高级农民工
昨天
5
0
用好项目管理工具,人人都可以成为项目经理

现在市面上的项目管理工具越来越多了,但是大多数都是一些协同工具或轻量项目管理工具。如果是多团队、跨部门使用或者企业级的项目管理,从管理思想到工具运用,需要适应企业的业务流程体系,...

cs平台
昨天
13
0
只需一步,在Spring Boot中统一Restful API返回值格式与统一处理异常

统一返回值 在前后端分离大行其道的今天,有一个统一的返回值格式不仅能使我们的接口看起来更漂亮,而且还可以使前端可以统一处理很多东西,避免很多问题的产生。 比较通用的返回值格式如下:...

晓月寒丶
昨天
70
0
区块链应用到供应链上的好处和实际案例

区块链可以解决供应链中的很多问题,例如记录以及追踪产品。那么使用区块链应用到各产品供应链上到底有什么好处?猎头悬赏平台解优人才网小编给大家做个简单的分享: 使用区块链的最突出的优...

猎头悬赏平台
昨天
32
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部