231022|redis_demo

安装
https://github.com/tporadowski/redis
https://github.com/redis/redis-py/
解压后要先配置redis.windows.conf文件,里面有本地端口和密码设置
默认host:127.0.0.1 port:6379
打开命令行到redis文件夹下,redis-server.exe redis.windows.conf输入即可(该页面不关闭)
再打开命令行到redis文件夹下运行redis-cli.exe可以输入相关命令
redis在python中的使用
构建server有两个方法 redis.ConnectionPool和redis.Redis
设置数据get/hset/hmset,获取数据hget/hmget/hgetall

python 复制代码
pool = redis.ConnectionPool(host='121.40.96.93', port=6379, db=0, password='123456')
r = redis.Redis(connection_pool=pool)
r = redis.Redis(host='127.0.0.1', port=6379, db=0)
#插入key-value
o = r.set(
        name="name",
        value="我是来及湖南的小明同学",  # value可以是字符串,也可以是任意一个byte字节数组
        ex=60,  # 设置当前加入的key ex秒后过期(删除)
        # px=10000,  # 设置当前加入的key px毫秒后过期;不能和ex同时给定
        nx=False,  # 当设置为True的时候,当却仅当name(key)在redis中不存在的时候,才会插入
        xx=False  # 当设置为True的时候,当却仅当name(key)在redis中存在的时候,才会插入;不能和nx同时给定为True
    )
# get就是获取String类型的key对应的value值
o = r.get(name="name")
# 设置key对应数据过期时间
r.expire(name='user:1001', time=10000)  # 过期秒数
# 让hash结构的value中添加数据
o = r.hset(name="user:1001", key="id", value="1001")
# 建议添加数据的写法(从redis理论上来讲)
o = r.hmset(name="user:1002", mapping={
        "id": "1002",
        "name": "小明1111",
        "age": 17,
        "sex": "男",
        "address": "上海",
        "address2": "北京"
    })
# 一次性获取所有field的value数据 --> hgetall返回结果是一个字典,如果key不存在,那么返回字典为空{}
o = r.hgetall(name='user:1001')
# 针对我们需要的field可以采用(单一field),只要key(name)或者field不存在,返回就是None
o = r.hget(name='user:1001', key='address')
# 针对我们需要的field可以采用(多个field),返回一个list列表,如果field存在对应位置为bytes,如果field不存在,那么对应位置为None
o = r.hmget(name='user:1002', keys=['name', 'age', 'address', 'address2'])

可以用pipeline的方法进行加速

python 复制代码
def t2():
    pool = redis.ConnectionPool(host='121.40.96.93', port=6379, db=0, password='123456', max_connections=100)
    with redis.Redis(connection_pool=pool) as r:
        _t1 = time.time()
        n = 10000
        _pipeline = r.pipeline()
        for i in range(n):
            _pipeline.set(name=f'l:{i}', value=i, ex=220)
        _pipeline.execute()
        print(time.time() - _t1)
相关推荐
Anastasiozzzz4 小时前
MySQL深分页问题与优化思路
数据库·mysql
伯明翰java4 小时前
数据库的操作
数据库
知识分享小能手8 小时前
PostgreSQL 入门学习教程,从入门到精通,PostgreSQL 16 语法知识点与案例详解(1)
数据库·学习·postgresql
康康的AI博客8 小时前
智能情感分析与品牌策略优化:如何通过AI洞察提升企业市场响应力
大数据·数据库·人工智能
Anastasiozzzz8 小时前
阿亮随手记:MySQL移除查询缓存、子查询优化深分页、自增主键溢出、索引失效
数据库·mysql·缓存
ppp今天又没打瓦8 小时前
围达梦数据库批量插入更新性能实测:普通表、一级分区与二级分区的对决
数据库
@insist1239 小时前
软考-数据库系统工程师-计算机体系结构与流水线核心考点解析
数据库·软考·数据系统工程师
可观测性用观测云9 小时前
KES(KingbaseES)数据库监控最佳实践
数据库
新缸中之脑9 小时前
在Reddit上探索未满足的需求
数据库·oracle
安当加密10 小时前
用 SMS 凭据管理系统替代 HashiCorp Vault:中小企业的轻量级 Secrets 管理实践
服务器·数据库·安全·阿里云