缓存memcached
❶ python 操作memcached
1、设定缓存放在那里:CACHE_BACKEND
也可以使用memcached:CACHE_BACKEND = 'memcached://127.0.0.1:11211/'
多个memcached:CACHE_BACKEND = 'memcached://172.19.26.240:11211;172.19.26.242:11211/'
/// pip install python-memcached
2、python 操作memcached:
import memcache
mc = memcache.Client(['139.129.5.191:12000'], debug=True)
mc.set("name", "python")
ret = mc.get('name')
print (ret)
python
3、设置权重
import memcache
mc = memcache.Client([('1.1.1.1:12000', 1), ('1.1.1.2:12000', 2),('1.1.1.3:12000',3)])
mc.set('k1','value1')
ret = mc.get('k1')
print (ret)
4、已经存在的键重复添加会出错:
import memcache
mc = memcache.Client(['0.0.0.0:12000'])
mc.add('k1', 'v1')
mc.add('k1', 'v2') # 报错,对已经存在的key重复添加,失败!!!
例如:
ret1 = mc.add('name','tom')
print(refalse)
ret2 = mc.add('name','jack')
print(retrue)
结果:
False #当已经存在key 那么返回false
True #如果不存在key 那么返回treue
5、替换操作:replace,如果键不存在,出错
import memcache
mc = memcache.Client(['0.0.0.0:12000'])
mc.set('name','tom')
re = mc.get('name')
print(re)
rereplace = mc.replace('name','jack')
re = mc.get('name')
print(rereplace,re)
结果:
tom #第一次赋值
True jack #如果存在key那么修改成功为yaoyao 返回True
rereplace = mc.replace('name1','hahaha')
re = mc.get('name1')
print(rereplace,re)
结果:
False None #如果不存在key,修改失败,返回空值
6、set:键值存在,就修改,不存在,则创建
import memcache
mc = memcache.Client(['0.0.0.0:12000'])
mc.set('name','tom')
re = mc.get('name')
print('set用法',re) #设置一个键值对
dic = {'name':'to,','age':'19','job':'IT'}
mc.set_multi(dic) #设置多个键值对
mcname = mc.get('name')
mcage = mc.get('age')
mcjob = mc.get('job')
print('set_multi用法:',mcname,mcage,mcjob)
7、delete:
import memcache
mc = memcache.Client(['0.0.0.0:12000'])
mc.set('name','tom')
re = mc.get('name')
print('存在',re)
mc.delete('name')
re = mc.get('name')
print('删除',re) #删除一个键值对
8、get
import memcache
mc = memcache.Client(['0.0.0.0:12000'])
mc.set('name','tom')
re = mc.get('name')
print('get',re) #获取一个键值对
dic = {'name':'to,','age':'19','job':'IT'}
mc.set_multi(dic)
regetmu=mc.get_multi(['name','age','job'])
print('get_multi',re) #获取多个键值对的值
9、append,prepend
import memcache
mc = memcache.Client(['0.0.0.0:12000'])
mc.set('num','第一|')
re = mc.get('num')
print(re)
mc.append('num','追加第二个') #在第一后面追加
re = mc.get('num')
print(re)
mc.prepend('num','我是零个') #在第一前面追加
re = mc.get('num')
print(re)
结果:
第一|
第一|追加第二个
我是零个第一|追加第二个
10、decr,incr自增自减
import memcache
mc = memcache.Client(['0.0.0.0:12000'])
mc.set('num','1')
re = mc.get('num')
print('我是没加过的值',re)
mc.incr('num','9')
re = mc.get('num')
print('我是加上新增后的值',re)
mc.decr('num','5')
re = mc.get('num')
print('我是减去的值',re)
我是没加过的值 1
我是加上新增后的值 10
是减去的值 5
11、锁机制:gets cas
import memcache
mc = memcache.Client(['0.0.0.0:12000'],cache_cas=True)
mc.set('count','10')
reget = mc.get('count')
print('件数',reget)
regets = mc.gets('count')
print(regets)
下面的设置将会执行失败,剖出异常,从而避免非正常数据的产生
recas = mc.cas('count','11')
print(recas)
regets = mc.gets('count')
print('修改',regets)
❷ 什么是memcached
memcached是一种高性能的内存式缓存系统,通过将数据存储在内存中减少读取数据库的次数
❸ 如何将php session信息缓存到memcached里面
在PHP的ini配置文件里面提供了[Session]相关配置,可以支持将信息存到文件或memcached服务器里面。由配置项session.save_handler = memcached决定。大多数场景,该session数据并不需要持久化,且为了提升网站性能,会选择将session信息缓存到memcached里面。
需要修改php.ini配置文件:
1、session段
找到[Session]段落,修改存储引擎为:
session.save_handler = memcached(注意是带d扩展)
修改存储地址,即OCS访问地址为:
session.save_path = “be6b6b8221cc11e4.m.cnhzalicm10pub001.ocs.aliyuncs.com:11211″(注意带d扩展,则前面不用加tcp://,不带d的扩展需要加)
修改缓存到memcached的key的时间
session.gc_maxlifetime = 1440(单位是秒,强烈建议必须设置一个合理时间,以保证OCS始终只缓存热点数据)
2、memcached段
在php.ini的全局段,建一个单独段落[memcached],然后在空白地方加入下面配置
[memcached]
memcached.use_sasl = On
memcached.sess_binary = On
memcached.sess_sasl_username = “your_ocs_name”
memcached.sess_sasl_password = “your_ocs_password”
memcached.sess_locking = Off
举例:
<?php
$memc = new Memcached();
$memc->setOption(Memcached::OPT_COMPRESSION, false);
$memc->setOption(Memcached::OPT_BINARY_PROTOCOL, true);
$memc->addServer(“be6b6b8221cc11e4.m.cnhzalicm10pub001.ocs.aliyuncs.com”, 11211);
$memc->setSaslAuthData(“your_ocs_name”, “your_ocs_password”);
echo $memc->get(“memc.sess.key. ttrct9coa2q62r2sodlq4qf376″);
/*注意这里的key是有前缀的,由php.ini中memcached.sess_prefix字段决定,默认值为“memc.sess.key.”。然后再拼接上面打出来的sessionid“ttrct9coa2q62r2sodlq4qf376”即可。*/
?>
该代码输出如下:
ocs_key|s:13:”session_value”;
即PHP SESSION已经成功写入OCS。
❹ 缓存系统中的主要使用的数据结构是什么
缓存系统中的主要使用的数据结构是memcached。
memcached是一套分布式的高速缓存系统,由LiveJournal的Brad Fitzpatrick开发,但被许多网站使用。这是一套开放源代码软件,以BSD license授权发布。
memcached的API使用三十二比特的循环冗余校验(CRC-32)计算键值后,将数据分散在不同的机器上。当表格满了以后,接下来新增的数据会以LRU机制替换掉。
由于memcached通常只是当作缓存系统使用,所以使用memcached的应用程序在写回较慢的系统时(像是后端的数据库)需要额外的代码更新memcached内的数据。
(4)缓存memcached扩展阅读:
一、存储方式
为了提高性能,memcached中保存的数据都存储在memcached内置的内存存储空间中。由于数据仅存在于内存中,因此重启memcached、重启操作系统会导致全部数据消失。
另外,内容容量达到指定值之后,就基于LRU(Least Recently Used)算法自动删除不使用的缓存。memcached本身是为缓存而设计的服务器,因此并没有过多考虑数据的永久性问题。
二、通信分布式
memcached尽管是“分布式”缓存服务器,但服务器端并没有分布式功能。各个memcached不会互相通信以共享信息。那么,怎样进行分布式呢?这完全取决于客户端的实现。本文也将介绍memcached的分布式。
❺ win10怎么安装memcache缓存服务
1. 下载memcache的windows稳定版,解压放某个盘下面,比如在c:\memcached
2. 在终端(也即cmd命令界面)下输入 'c:\memcached\memcached.exe -d install' 安装
3. 再输入: 'c:\memcached\memcached.exe -d start' 启动。NOTE: 以后memcached将作为windows的一个服务每次开机时自动启动。这样服务器端已经安装完毕了。
4.下载php_memcache.dll,请自己查找对应的php版本的文件
5. 在C:\winnt\php.ini 加入一行 'extension=php_memcache.dll'
6.重新启动Apache,然后查看一下phpinfo,如果有memcache,那么就说明安装成功
❻ 常用的缓存技术
第一章 常用的缓存技术
1、常见的两种缓存
本地缓存:不需要序列化,速度快,缓存的数量与大小受限于本机内存
分布式缓存:需要序列化,速度相较于本地缓存较慢,但是理论上缓存的数量与大小无限(因为缓存机器可以不断扩展)
2、本地缓存
Google guava cache:当下最好用的本地缓存
Ehcache:spring默认集成的一个缓存,以spring cache的底层缓存实现类形式去操作缓存的话,非常方便,但是欠缺灵活,如果想要灵活使用,还是要单独使用Ehcache
Oscache:最经典简单的页面缓存
3、分布式缓存
memcached:分布式缓存的标配
Redis:新一代的分布式缓存,有替代memcached的趋势
3.1、memcached
经典的一致性hash算法
基于slab的内存模型有效防止内存碎片的产生(但同时也需要估计好启动参数,否则会浪费很多的内存)
集群中机器之间互不通信(相较于Jboss cache等集群中机器之间的相互通信的缓存,速度更快<--因为少了同步更新缓存的开销,且更适合于大型分布式系统中使用)
使用方便(这一点是相较于Redis在构建客户端的时候而言的,尽管redis的使用也不困难)
很专一(专做缓存,这一点也是相较于Redis而言的)
3.2、Redis
可以存储复杂的数据结构(5种)
strings-->即简单的key-value,就是memcached可以存储的唯一的一种形式,接下来的四种是memcached不能直接存储的四种格式(当然理论上可以先将下面的一些数据结构中的东西封装成对象,然后存入memcached,但是不推荐将大对象存入memcached,因为memcached的单一value的最大存储为1M,可能即使采用了压缩算法也不够,即使够,可能存取的效率也不高,而redis的value最大为1G)
hashs-->看做hashTable
lists-->看做LinkedList
sets-->看做hashSet,事实上底层是一个hashTable
sorted sets-->底层是一个skipList
有两种方式可以对缓存数据进行持久化
RDB
AOF
事件调度
发布订阅等
4、集成缓存
专指spring cache,spring cache自己继承了ehcache作为了缓存的实现类,我们也可以使用guava cache、memcached、redis自己来实现spring cache的底层。当然,spring cache可以根据实现类来将缓存存在本地还是存在远程机器上。
5、页面缓存
在使用jsp的时候,我们会将一些复杂的页面使用Oscache进行页面缓存,使用非常简单,就是几个标签的事儿;但是,现在一般的企业,前台都会使用velocity、freemaker这两种模板引擎,本身速度就已经很快了,页面缓存使用的也就很少了。
总结:
在实际生产中,我们通常会使用guava cache做本地缓存+redis做分布式缓存+spring cache就集成缓存(底层使用redis来实现)的形式
guava cache使用在更快的获取缓存数据,同时缓存的数据量并不大的情况
spring cache集成缓存是为了简单便捷的去使用缓存(以注解的方式即可),使用redis做其实现类是为了可以存更多的数据在机器上
redis缓存单独使用是为了弥补spring cache集成缓存的不灵活
就我个人而言,如果需要使用分布式缓存,那么首先redis是必选的,因为在实际开发中,我们会缓存各种各样的数据类型,在使用了redis的同时,memcached就完全可以舍弃了,但是现在还有很多公司在同时使用memcached和redis两种缓存。
❼ memcache怎样清除缓存两种方法
memcache确实是一个加速很好的缓存器,什么都可以缓存~
——方法一——-cmd上直接清除,【清除所有缓存】
$ telnet localhost 11211
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
flush_all
OK
quit
Connection to localhost closed by foreign host.
——方法二——-PHP清理缓存方法
<?php
$memcache = new Memcache;
$memcache->connect(‘localhost’, 11211) or die (“Could not connect”);
$version = $memcache->getVersion();
echo ”Server’s version: ”.$version.”
\n”;
?>
<?php
$memcache = new Memcache;
$memcache->connect(‘localhost’, 11211) or die (“Could not connect”);
print_r($memcache->getStats());
/**
* Array
* (
* [pid] => 8052
* [uptime] => 9205
* [time] => 1205898428
* [version] => 1.2.5 www.shellsec.com
* [pointer_size] => 32
* [rusage_user] => 0.008000
* [rusage_system] => 0.000000
* [curr_items] => 1
* [total_items] => 17
* [bytes] => 57
* [curr_connections] => 2
* [total_connections] => 15
* [connection_structures] => 3
* [cmd_get] => 9
* [cmd_set] => 23
* [get_hits] => 5
* [get_misses] => 4
* [evictions] => 0
* [bytes_read] => 671
* [bytes_written] => 850
* [limit_maxbytes] => 10485760
* [threads] => 1
* )
*/
?>
<?php
$memcache = new Memcache;
$memcache->connect(‘localhost’, 11211) or die (“Could not connect”);
$memcache->set( ’name’, ’leo’, 0, 30);
if(!$memcache->add( ’name’, ’susan’, 0, 30))
{
echo ’susan is exist’;
};
$memcache->replace( ’name’, ’lion’, 0, 300);
echo $memcache->get( ’name’);
$memcache->delete( ’name’, 5);
?>
<?php
function _callback_memcache_failure($host, $port) {
print ”memcache ’$host:$port’ failed”;
}
$memcache = new Memcache;
$memcache->addServer(’192.168.1.116′, 11211);
$memcache->setServerParams(’192.168.1.116′, 11211, 1, 15, true,
‘_callback_memcache_failure’);
echo $memcache->getServerStatus(’192.168.1.116′, 11211);
?>
<?php
$memcache = new Memcache;
$memcache->connect(‘localhost’, 11211);
$memcache->set(‘test_item’, 8);
$memcache->increment(‘test_item’, 4);
echo $memcache->decrement(‘test_item’, 7);
// 显示 5
?>
/usr/local/bin/memcached -d -m 10 -u root -l 127.0.0.1 -p 11211 -c 256 -P
/tmp/memcached.pid
memcached的服务正式启动
Memcache::add — 添加一个值,如果已经存在,则返回false
Memcache::addServer — 添加一个可供使用的服务器地址
Memcache::close — 关闭一个Memcache对象
Memcache::connect — 创建一个Memcache对象
memcache_debug — 控制调试功能
Memcache::decrement — 对保存的某个key中的值进行减法操作
Memcache::delete — 删除一个key值
Memcache::flush — 清除所有缓存的数据
Memcache::get — 获取一个key值
Memcache::getExtendedStats — 获取进程池中所有进程的运行系统统计
Memcache::getServerStatus — 获取运行服务器的参数
Memcache::getStats — 返回服务器的一些运行统计信息
Memcache::getVersion — 返回运行的Memcache的版本信息
Memcache::increment — 对保存的某个key中的值进行加法操作
Memcache::pconnect — 创建一个Memcache的持久连接对象
Memcache::replace — R对一个已有的key进行覆写操作
Memcache::set — 添加一个值,如果已经存在,则覆写
Memcache::setCompressThreshold — 对大于某一大小的数据进行压缩
Memcache::setServerParams — 在运行时修改服务器的参数
建议用面向对象的方式来测试这个库:
Memcache::getVersion方法的作用是返回运行的Memcache的版本信息。
Memcache::getStats 方法的作用是返回服务器的一些运行统计信息。Memcache::getStats方法有三个参
数,第一个参数表示要求返回的类型:reset, malloc, maps, cachemp, slabs, items, sizes;第二个
参数和第三个参数是在第一个参数设置为“cachemp”时使用的。Memcache::getExtendedStats方法的
作用是获取进程池中所有进程的运行系统统计。
Memcache::connect方法的作用是创建一个Memcache对象。Memcache::pconnect方法的作用是创建一个
Memcache的持久连接对象。Memcache::close方法的作用是关闭一个Memcache对象。
Memcache::set 方法的作用是添加一个值,Memcache::set方法有四个参数,第一个参数是key,第二个参
数是value,第三个参数可选,表示是否压缩保存,第四个参数可选,用来设置一个过期自动销毁的时间
。Memcache::add方法的作用和Memcache::set方法类似,区别是如果 Memcache::add方法的返回值为
false,表示这个key已经存在,而Memcache::set方法则会直接覆写。 Memcache::get方法的作用是获取
一个key值,Memcache::get方法有一个参数,表示key。Memcache::replace 方法的作用是对一个已有的
key进行覆写操作,Memcache::replace方法有四个参数,作用和Memcache::set方法的相同。
Memcache::delete方法的作用是删除一个key值,Memcache::delete方法有两个参数,第一个参数表示key
,第二个参数可选,表示删除延迟的时间。
memcache_debug()函数的作用是控制调试功能,前提是php在编译的时候使用了–enable-debug选项,否
则这个函数不会有作用。
Memcache::addServer 方法的作用是添加一个可供使用的服务器地址,Memcache::addServer方法有8个参
数,除了第一个参数意外,其他都是可选的,第一个参数表示服务器的地址,第二个参数表示端口,第三
个参数表示是否是一个持久连接,第四个参数表示这台服务器在所有服务器中所占的权重,第五个参数表
示连接的持续时间,第六个参数表示连接重试的间隔时间,默认为15,设置为-1表示不进行重试,第七个
参数用来控制服务器的在线状态,第8个参数允许设置一个回掉函数来处理错误信息。
Memcache::setServerParams方法的作用是在运行时修改服务器的参数,Memcache::setServerParams方法
有六个参数,Memcache::addServer方法少了第三和第四个参数。 Memcache::getServerStatus方法的作
用是获取运行服务器的参数,两个参数分别表示的地址和端口。
Memcache::flush方法的作用是清除所有缓存的数据,但是不会削去使用的内存空间。
Memcache::increment方法的作用是对保存的某个key中的值进行加法操作,Memcache::decremen方法的作
用是对保存的某个key中的值进行减法操作。
❽ C# 操作Memcached
要在nuget里引用(安装) EnyimMemcached ,下面是以调用阿里云的ocs(memcached)服务为例
using System;
using Enyim.Caching;
namespace MemcacheTest
{
///
/// MemcachedClient 帮组类 对外提供接口方法
///
public class MemcachedHelper {
///
/// 定义一个静态MemcachedClient客户端,它随类一起加载,所有对象共用
///
private static MemcachedClient mclient;
///
/// 静态构造函数,初始化Memcached客户端
///
static MemcachedHelper()
{
mclient = MemCached.getInstance();
}
///
/// 向Memcached缓存中添加一条数据
///
///返回是否添加成功
public static bool SetValue(string groupName,string key, object value, DateTime expiry)
{
key = groupName + "-" + key;
return mclient.Store(Enyim.Caching.Memcached.StoreMode.Set,key, value, expiry);
}
///
/// 向Memcached缓存中添加一条数据 默认超时24小时
////
public static bool SetValue(string groupName, string key, object value)
{
key = groupName + "-" + key;
eturn mclient.Store(Enyim.Caching.Memcached.StoreMode.Set, key, value, DateTime.Now.AddHours(24));
}
///
/// 通过key 来得到一个对象
///
public static object GetValue(string groupName, string key)
{
key = groupName + "-" + key;
return mclient.Get(key);
}
///
/// 通过key 来得到一个对象(前类型)
///
public static T GetValue(string groupName, string key)
{
key = groupName + "-" + key;
return mclient.Get(key);
}
///
/// 清除指定key的cache
///
public static bool Remove(string groupName, string key)
{
key = groupName + "-" + key;
return mclient.Remove(key);
}
///
/// 清除所有cache
///
public static void RemoveAll()
{
mclient.FlushAll();
}
}
}
usingSystem.Net;
usingEnyim.Caching;
usingEnyim.Caching.Configuration;
usingEnyim.Caching.Memcached;
namespaceMemcacheTest
{
///
///MemcachedClient 配置类
///
publicsealedclassMemCached
{
privatestaticMemcachedClient MemClient;
staticreadonlyobjectpadlock =newobject();
//线程安全的单例模式
()
{
if(MemClient ==null)
{
lock(padlock)
{
if(MemClient ==null)
{
MemClientInit();
}
}
}
returnMemClient;
}
staticvoidMemClientInit()
{
//初始化缓存
MemcachedClientConfiguration memConfig =();
IPAddress newaddress = IPAddress.Parse(Dns.GetHostEntry("XXXXXXXXXX.m.cnhzalicm10pub001.ocs.aliyuncs.com").AddressList[0].ToString());//xxxx替换为ocs控制台上的“内网地址”
IPEndPoint ipEndPoint =newIPEndPoint(newaddress,11211);// 配置文件 - ip
memConfig.Servers.Add(ipEndPoint);// 配置文件 - 协议
memConfig.Protocol = MemcachedProtocol.Binary;
// 配置文件-权限,如果使用了免密码功能,则无需设置userName和password
memConfig.Authentication.Type =typeof(PlainTextAuthenticator);
memConfig.Authentication.Parameters["zone"] ="";
memConfig.Authentication.Parameters["userName"] ="XXXXXXXXXXXXXXXXX";
memConfig.Authentication.Parameters["password"] ="XXXXXXXXXX";
//下面请根据实例的最大连接数进行设置
memConfig.SocketPool.MinPoolSize =5;
memConfig.SocketPool.MaxPoolSize =200;
MemClient =newMemcachedClient(memConfig);
}
}
}
程序调用
MemcachedHelper.SetValue(groupName,strKey, strValue, DateTime.Now.AddMinutes(5));
varrestr = MemcachedHelper.GetValue(groupName,strKey);
varobj = MemcachedHelper.GetValue(groupName,"p001");
❾ memcached 缓存什么数据
memcached 是流行的key/value缓存软件。就是说缓存的内容是以key/value对的形式缓存的。只要值可以被序列化且大小不超过系统限制均可缓存。一般用来缓存代码表,频繁使用的查询结果等。
❿ 如何更新MemcacheD Is Your Friend缓存
步骤如下:
1、php安装Memcached插件。
2、WordPress安装Memcached缓存插件(MemcacheD Is Your Friend)。
3、部署Memcached内存缓存图形化界面监控页面。