linux下memcache的运用,和php结合小案例。

时间:2022-09-06 14:08:46

由于是采用脚本安装的memache,所以软件的依赖关系我就不操心了,脚本已经帮我装好了和php的关联关系,实在是很省心。后续如果有需要,我会针对windows和linux各写一个安装和配置的说明,一来提高自己的水平,而来也给有需要的朋友们。

因此这次我将关注点放在memcache的配置以及php的操作上。

1.启动Memcache的服务器端:

如果是虚拟机的话,你的写的ip要能用ping 命令ping通。这样才可以使用。我刚开始就在上面浪费了许多时间。
# ./memcached -d -m 10 -u root -l 127.0.0.1  -p  12000  -c  256
-P /tmp/memcached.pid

 -d选项是启动一个守护进程,
-m是分配给Memcache使用的内存数量,单位是MB,我这里是10MB,
-u是运行Memcache的用户,我这里是root,
-l是监听的服务器IP地址,如果有多个地址的话,我这里指定了服务器的IP地址127.0.0.,
-p是设置Memcache监听的端口,我这里设置了12000,最好是1024以上的端口,
-c选项是最大运行的并发连接数,默认是1024,我这里设置了256,按照你服务器的负载量来设定,
-P是设置保存Memcache的pid文件,我这里是保存在 /tmp/memcached.pid,

memcache中的常量。

memcache中set(‘key’, ‘value’, 0, 60)

其中的0是MEMCACHE_COMPRESSED ,的值。

MEMCACHE_COMPRESSED (integer)

用于在 Memcache::set(), Memcache::add() 和 Memcache::replace()几个方法中指定是否对写入数据压缩。 

MEMCACHE_HAVE_SESSION (integer)   

1代表当前Memcache session处理器可用,其他为0

常用的几个方法:

Memcache::add()方法在缓存服务器之前不存在key时, 以key作为key存储一个变量var到缓存服务器。 同样可以使用函数memcache_add()

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

key

将要分配给变量的key。

var

将要被存储的变量。字符串和整型被以原文存储,其他类型序列化后存储。

flag

使用MEMCACHE_COMPRESSED标记对数据进行压缩(使用zlib)。

expire

当前写入缓存的数据的失效时间。如果此值设置为0表明此数据永不过期。你可以设置一个UNIX时间戳或 以秒为单位的整数(从当前算起的时间差)来说明此数据的过期时间,但是在后一种设置方式中,不能超过 2592000秒(30天)。

分割线后是我自己写的一个小的demo,简单说明memcache的用法。

关于memcache,用法实在是很简易。网上的资料也很多。下面这个网址可以参考下,写的很不错。

http://www.ccvita.com/259.html


 <?php
header("content-type:text/html;charset=utf-8"); //实例化Memcache类.初始化条件
$memcache = new Memcache;
$memcache -> connect('127.0.0.1', 12000); //初始化mysql服务.
$link = @mysql_connect('127.0.0.1', 'root', '123456', 'test')or die('数据库连接失败'.mysql_error());
mysql_select_db('test');
mysql_set_charset('utf8'); //建立sql语句
$sql = 'select * from user';
$key = md5($sql); if($memcache -> get($key)){
//memecache缓存区间
echo '我是读的memcache缓存';
$result = $memcache -> get($key);
}else{
//mysql区间
echo '我是读的mysql';
$handle = mysql_query($sql);
if($handle){
while($array = mysql_fetch_array($handle)){
$result[] = $array;
}
}
mysql_close(); //关闭mysql资源
$memcache -> set($key, $result, MEMCACHE_COMPRESSED, 5); //MEMCACHE_COMPRESSED是常量1. 缓存5秒
} echo '<pre>';
print_r($result);
echo '</pre>'; ?>

下面是ThinkPHP里面写的一个小的demo.

首先要配置Common下面的config文件。配置文件如下:

<?php
return array(
/* 数据库设置 */
'DB_TYPE' => 'Mysql', // 数据库类型
'DB_HOST' => 'localhost', // 服务器地址
'DB_NAME' => 'datebase', // 数据库名
'DB_USER' => 'root', // 用户名
'DB_PWD' => '', // 密码
'DB_PORT' => '', // 端口
'DB_PREFIX' => 'smm_', // 数据库表前缀 /* 数据缓存设置 */
'DATA_CACHE_TIME' => , // 数据缓存有效期 0表示永久缓存,我写了5秒,为了测试方便。
'DATA_CACHE_COMPRESS' => true, // 数据缓存是否压缩缓存
'DATA_CACHE_CHECK' => true, // 数据缓存是否校验缓存
'DATA_CACHE_PREFIX' => 'HOME_', // 缓存前缀
'DATA_CACHE_TYPE' => 'Memcache', // 数据缓存类型,支持:File|Db|Apc|Memcache|Shmop|Sqlite|Xcache|Apachenote|Eaccelerator
'DATA_CACHE_PATH' => TEMP_PATH,// 缓存路径设置 (仅对File方式缓存有效) );

例子如下:

 class IndexController extends Controller {
//载入添加数据库
private $smm_iron_user; //初始化数据库,避免多次实例化。
public function __construct(){
parent::__construct();
$this -> smm_iron_user = M('iron_user');
} public function index () {
$sql = "select * from smm_iron_user";
$md5sql = md5($sql); if(S($md5sql)){
echo '我读的是缓存';
$result = S($md5sql);
}else{
echo '我读的是mysql';
$result = $this -> smm_iron_user -> query($sql);
S($md5sql, $result, 5);
}
//S($md5sql,null);
dump($result);die(); } }

linux下memcache的运用,和php结合小案例。的更多相关文章

  1. Linux下Memcache 安装和使用

    Memcached是一种高性能的分布式内存对象缓存系统(memcached虽然称为“分布式”缓存服务器,但服务器端并没有“分布式”功能,其“分布式”由客户端函数库完成,成熟算法的为一致性Hash),用 ...

  2. Linux 下memcache安装及使用

    memcache是高性能,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度.据说官方所说,其用户包括twitter.digg.flickr等,都是些互联网大腕呀.目前用memca ...

  3. Linux下Memcache服务器端的安装

    最近在研究怎么让Discuz!去应用Memcache去做一些事情,记录下Memcache安装的过程. Linux下Memcache服务器端的安装服务器端主要是安装memcache服务器端,目前的最新版 ...

  4. Linux下Eclipse以及Java环境安装教程&lbrack;小白化&rsqb;&lpar;2019-9&rpar;

    Linux下安装Eclipse以及Java 一.前言 许久未用Eclipse, Ubuntu上也没装Eclipse, 今天安装发现, 好多东西都忘了. 不过经过一番查找(百度, csdn) 终于还是安 ...

  5. Linux下memcache的安装

    memcache是高性能,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度.目前用memcache解决互联网上的大用户读取是非常流行的一种用法,在互联网企业中有着广泛的应用.‍关 ...

  6. Linux下memcache编译安装与基本使用

    memcache是一套分布式的高速缓存系统,特点为key-value 存储 一.在 linux 编译安装memcache.redis等,需要 gcc,make,cmake,autoconf,libto ...

  7. Linux下memcache的安装和启动测试

    memcache是一套分布式的高速缓存系统,MemCache的工作流程如下:先检查客户端的请求数据是否在memcached中,如有,直接把请求数据返回,不再对数据库进行任何操作:如果请求的数据不在me ...

  8. Linux下memcache的安装和启动

    memcache是高性能,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度.据说官方所说,其用户包括twitter.digg.flickr等,都是些互联网大腕呀.目前用memca ...

  9. Linux下memcache的安装和启动&lpar;转&rpar;

    memcache是高性能,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度.据说官方所说,其用户包括twitter.digg.flickr等,都是些互联网大腕呀.目前用memca ...

随机推荐

  1. windows下python的tar&period;gz文件安装

    windows下下载了django,PIL,web.py发现都是tar.gz格式的文件,网上查找也非常系统的方法,总结一下其他大神的方法,归纳于此. 首先下载tar.gz文件,比如web.py,下载后 ...

  2. java web学习之表单

    前台页面与后台页面的数据又form表单完成. <form  name ="form1"  method="post" action="index ...

  3. UCOS-互斥信号量(学习笔记)

    互斥信号量主要是为了解决信号量出现的优先级反转的情况:任务的运行取决于优先级和获得信号量2个条件,并且获得信号量又优先于设定的优先级.剥夺性内核对信号量进行独占访问,就有可能出现先获得信号量的低优先级 ...

  4. 顺序容器:vector&comma;deque&comma;list

    1.顺序容器:vector,deque,list 容器类共享公共接口,只要学会其中一种类型就能运用另一种类型.每种容器提供一组不同的时间和功能这种方案,通常不需要修改代码,秩序改变类型声明,每一种容器 ...

  5. Web---session技术代码演示&lpar;request&comma;session&comma;servletContext&rpar;

    Session会话简介与基本知识点 当浏览器第一次访问服务器时,无论先访问哪一个页面,服务器就会给用户分配一个唯一的会话标识,即jsessionid然后以cookie的形式返回给用户. 会话是指在一段 ...

  6. 3d 人物残像

    前言: gameunity 框架 还在继续完善中,0.2版本将会是一次 重大的里程碑. 正文: 哈哈,大家一定流汗了吧.请原谅我为自己代言. 好了,今天我要讲的是  3d人物残像. 首先我来说下 目前 ...

  7. BZOJ 3787&colon; Gty的文艺妹子序列 &lbrack;分块 树状数组!&rsqb;

    传送门 题意:单点修改,询问区间内逆序对数,强制在线 看到加了!就说明花了不少时间.... 如果和上题一样预处理信息,用$f[i][j]$表示块i到j的逆序对数 强行修改的话,每个修改最多会修改$(\ ...

  8. &lbrack;HNOI2015&rsqb;开店

    如果没有年龄区间 画图发现ans=\(\sum_{i=1}^n dis_i + n * dis_u - 2 * \sum_{i=1}^{n} dis_{lca(i, u)}\) 对\(\sum_{i= ...

  9. 初识DOM

    初识DOM 一. 节点的获取.插入.创建.删除.替换.修改文本节点 获取 1.document.getElementById 2.(element)document.getElementsByTagN ...

  10. 让java从Mysql返回多个ResultSet

    首先,JDBC对于SQLSERVER来说默认是支持返回,但对于MySql来说,只默认支持存储过程返回多个ResultSet,那对于手写SQL怎么办. 其实很简单,只要一个在连接字符串中加一个参数:al ...