Python 数据处理--Memcached

2020-10-19  本文已影响0人  小啊小狼

一、Memcached介绍

Memcached:一款高性能分布式内存对象缓存系统,通过 内存缓存,以减少数据库的读取,从而分担数据库的压力,进而提高网站的加载速度

Memcached,实际上是一套简洁的键值对存储系统,可以存储各种类型的数据,包含:字符串、对象、图像、文件、视频等

由于 Memcached 的数据存储在内存中,因此重启服务或系统之后,数据会全部丢失;另外,当 Memcached 使用容量达到指定值时,会基于 LRU 算法,自动删除掉不使用的缓存

二、准备

我们以在阿里云服务器 Centos 7 安装 Memcached-Server 为例

首先,在云服务器上安装 Memcached

# 使用yum安装memcached
yum install memcached

通过 whereis 命令,查询出 Memcached 安装的目录

[root@liang ~]# whereis memcached
memcached: /usr/bin/memcached /usr/share/man/man1/memcached.1.gz

然后,通过命令行及参数启动 Memcached 服务

# 运行memcached服务
# -p:端口号
# -m:分类的内存
# -d:守护进程,后台运行
# -u:运行memcached的用户
# -l:设置哪些ip可以连接到服务,0.0.0.0:容许外网ip访问
/usr/bin/memcached -p 8889 -m 64m -d -u root -l 0.0.0.0

常见的启动参数包含:

接着,开启防火墙端口

# 开启端口号
firewall-cmd --add-port=8889/tcp --permanent

# 重启立即生效
firewall-cmd --reload

需要注意的是,如果是云服务器,需要在安全组中开放相应端口号

通过编程语言,包含:Python、Java、Php,去操作 Memcached 数据

以 Python 为例,需要安装 python-memcached 依赖

# 安装依赖
pip3 install python-memcached

三、实际操作

在操作 Memcache 中的数据之前,我们需要导入 memcache,使用 Client() 方法指定要操作的 Memecache 服务,构建一个数据连接对象

class LearnMecache():
    def __init__(self):
        # 连接memcached服务,可以包含多个服务ip
        self.mc = memcache.Client(['ip:8889'], debug=True)

1、新增操作

新增操作对应的方法是:add(key,value,timeout)

其中,参数 timeout 表示数据保留的时间,超时会自动被清除掉,默认一直保存

需要注意的是,如果准备插入键值对中的 key 在原数据集中不存在,则会新增一条记录到数据集中;否则,会添加失败,并警告提示(MemCached: while expecting 'STORED', got unexpected response 'NOT_STORED')

    def add(self,dic,time=None):
        """
        添加记录
        :return:
        """
        # 添加一条数据,如果已经存在,会添加失败,并报异常()
        # time:保存时间,超时会被清除,单位为秒,默认是保存永久
        # 注意:如果添加的key已经存在,会警告:MemCached: while expecting 'STORED', got unexpected response 'NOT_STORED'
        # self.mc.add("name", "xag", time=60 * 5)
        for key in dic.keys():
            self.mc.add(key, dic.get(key))
            print(key,dic.get(key))

2、查询操作

其中,单条记录查询对应的方法是:get(key)

    def query_one(self, key):
        """
        查询单条记录
        :return:
        """
        result = self.mc.get(key)
        print('单条记录查询,key:', key, ",value:", result)

多条记录的查询,对应的方法是:get_multi(keys)

    def query_many(self, keys):
        """
        查询多条记录
        :param keys: 键值列表
        :return:
        """
        values = self.mc.get_multi(keys)

        # dict,键值对
        print(type(values))
        print('多条记录查询:', values)

3、更新操作

更新操作包含三种方法,分别是:

    def replace_one(self,key:str,value):
        self.mc.replace(key,value)
    def set_one(self,key:str,value):
        self.mc.set(key,value)
    def set_multi(self,dic:dict):
        self.mc.set_multi(dic)

4、追加操作

追加操作相当于修改某一个键的值,在头部或者尾部追加数据

其中:

    def append(self,key:str, text:str):
        self.mc.append(key, text)

    def prepend(self,key:str, text:str):
        self.mc.prepend(key, text)

注:原数据类型为int,只可以拼接可以转为int的字符串
原数据类型为字符串,则可以随意拼接字符串

5、删除操作

和查询操作类似,删除操作同样支持单个键值对的删除和多个键值对的删除

    def delete_one(self,key:str):
        self.mc.delete(key)

    def delete_many(self,keys):
        #参数keys为可迭代对象
        self.mc.delete_multi(keys)

完整代码:

import memcache

class LearnMecache():
    def __init__(self):
        # 连接memcached服务,可以包含多个服务ip
        self.mc = memcache.Client(['ip:8889'], debug=True)

    def add(self,dic,time=None):
        """
        添加记录
        :return:
        """
        # 添加一条数据,如果已经存在,会添加失败,并报异常
        # time:保存时间,超时会被清除,单位为秒,默认是保存永久
        # 注意:如果添加的key已经存在,会警告:MemCached: while expecting 'STORED', got unexpected response 'NOT_STORED'
        # self.mc.add("name", "xag", time=60 * 5)
        for key in dic.keys():
            self.mc.add(key, dic.get(key))
            print(key,dic.get(key))

    def query_one(self, key):
        """
        查询单条记录
        :return:
        """
        result = self.mc.get(key)
        print('单条记录查询,key:', key, ",value:", result)

    def query_many(self, keys):
        """
        查询多条记录
        :param keys: 键值列表
        :return:
        """
        values = self.mc.get_multi(keys)

        # dict,键值对
        print(type(values))
        print('多条记录查询:', values)
    def replace_one(self,key:str,value):
        self.mc.replace(key,value)

    def set_one(self,key:str,value):
        self.mc.set(key,value)

    def set_multi(self,dic:dict):
        self.mc.set_multi(dic)

    def append(self,key:str, text:str):
        self.mc.append(key, text)

    def prepend(self,key:str, text:str):
        self.mc.prepend(key, text)

    def delete_one(self,key:str):
        self.mc.delete(key)

    def delete_many(self,keys):
        #参数keys为可迭代对象
        self.mc.delete_multi(keys)
上一篇 下一篇

猜你喜欢

热点阅读