Python存储系统(Redis)
存储系统数据缓存一般会使用三个模块:Mongodb,redis,memcache。其中memcache是轻量级缓存,只能将数据保存到内存中,redis可以配置数据保存在内存还是硬盘。
其主要用途有:不同应用(语言)中共享数据
CentOS安装Redis
安装
yum install epel-release
yum install redis
开启服务:
systemctl start redis
设置密码:
编辑文件:/etc/redis.conf
#requirepass foobared去掉注释,foobared改为自己的密码
requirepass newpasswd #这句表示该密码为newpasswd
保存并重启redis服务
设置密码后的命令行登入方式:redis-cli -h 127.0.0.1 -p 6379 -a newpasswd
设置远程端可访问:
因为redis服务默认不提供远程操作
编辑文件:/etc/redis.conf
将bind 127.0.0.1 改为 bind 0.0.0.0
保存并重启redis服务
设置防火墙开放端口
firewall-cmd --zone=public --add-port=6379/tcp --permanent
重启防火墙
systemctl restart firewalld
命令行基本操作操作
连接
redis-cli
通过键值对设置值
set key value [EX seconds] [PX milliseconds] [NX|XX]
其中ex表示保存的秒数,px表示毫秒数,nx表示key不存在时才操作,xx表示key存在时才操作
set keyx valuex
设置值且保存5秒
set keyx1 valuex1 ex 5
一次性设置多个
mset key1 value1 key2 value2
设置新值并返回原值
getset key1 value1111
字符串切片,如"value1"经过下面结果为:"val"
getrange key1 0 2
退出
exit
通过键值对获取值
get keyx
查看所有的键
keys *
查看带有e字符的所有key
keys *e*
一次性获取多个
mget key1 key2
通过键值对删除值
del key [key ...]
判断键是否存在,返回0或1
exists key1
重命名
rename key1 key2
跳转到另一个空间(db)
总共有[0,15]个,默认为0
select 1
移动键值内容
move key db
自增自减
自增:
incr keycunx #执行一次增加一
自减
decr keycunx #执行一次减去一
二进制位操作:
如果把设置值的offset匹配成用户id,则可以实现高效的用户登入判断,设置1为登入,0为非登入
设置值:
setbit key offset value 设置二进制offset位的值为value
setbit dongbit 2 1
setbit dongbit 1000 1
取出值为1的位个数:
bitcount dongbit #输出2
获取二进制第几位的值:
getbit dongbit 10 #输出0
getbit dongbit 2 #输出1
Hash操作:
设置数据
hset key field value 其中key总键,field为子键,value为子键的值
hset user name dongxiaodong
hset user passwd pdongdongdong
获取到所有数据:
hgetall user
hkeys user
hvals user
获取到指定数据:
hget user passwd
批量设置:
hmset user1 name dong1 passwd pdong111
判断子键是否存在,存在返回1,否则为0
hexists user1 passwd
列表操作:
设置
rpush key value [value ...] #一个key可以保持多个value,先入先出,如果需要先入后出则使用rpush
rpush listdong dong1 dong2 dong3
取值:
lrange key start stop 取key的值需要确定起始和结束位置
lrange listdong 0 -1 #取所有
lrange listdong 1 1 #确定某个
集合操作(值不可重复):
设置
sadd aggdong dong1 dong2 33 dong1
取值
smembers aggdong
获取个值数
scard aggdong
Python基本操作
安装模块
pip3 install redis
简单的连接:
#连接方法一:
#每次操作都是一个连接,如get、set等,一个就是一个网络连接,所以不可取
# conn=redis.Redis(host="192.168.1.195",port=6379,password="rpdong") #连接方法二(连接池)
poolx=redis.ConnectionPool(host="192.168.1.195",port=6379,password="rpdong")
conn=redis.Redis(connection_pool=poolx) #设置数据
conn.set("keyx","valuexx")
#取出数据
print(conn.get("keyx"))
键值对操作补充:
只有键本身存在时才更改数据值和最长保留时间为10秒
#设置数据,
conn.set("keyx","valuexx",ex=10,xx=True)
发布和订阅:
发布
命令行发布:
参数为:publish 主题 内容
publish dongtop dongtototo
Python发布:
import redis #连接池
poolx=redis.ConnectionPool(host="192.168.1.195",port=6379,password="rpdong")
conn=redis.Redis(connection_pool=poolx) #发布消息,参数(主题,内容)
conn.publish("dongtop","dongxiaodongtext")
conn.publish("dongtop2","dongxiaodongtext222") print("------ 发送完成 --------")
订阅:
import redis #连接池
poolx=redis.ConnectionPool(host="192.168.1.195",port=6379,password="rpdong")
conn=redis.Redis(connection_pool=poolx) pub=conn.pubsub() #打开接收
pub.subscribe("dongtop") #设置接收主题
pub.subscribe("dongtop2") print("-------- 等待接收 ---------") while True:
msgx=pub.parse_response() #准备接收,如果无数据则阻塞
'''
第一次会输出订阅成功消息:
收到的数据为: [b'subscribe', b'dongtop', 1]
收到的数据为: [b'subscribe', b'dongtop2', 2]
#输出:
收到的数据为: [b'message', b'dongtop', b'dongxiaodongtext']
收到的数据为: [b'message', b'dongtop2', b'dongxiaodongtext222'
'''
print("收到的数据为:",msg
基于订阅和发布的小文件传输:
发布端
#发布消息,参数(主题,文件内容)
conn.publish("dongtop",open("南沙客运港.mp4","rb").read()) print("------ 发送完成 --------")
接收端:
msgx =pub.parse_response() # 去掉第一次订阅成功的消息
print("-------- 等待接收 ---------",msgx)
while True:
msgx =pub.parse_response() # 准备接收,如果无数据则阻塞
#得到文件数据并写入文件
open("客运港.mp4","wb").write(msgx[2])
print("----* 接收完成 *----")
Python存储系统(Redis)的更多相关文章
- python之redis和memcache操作
Redis 教程 Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理.Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据 ...
- python——操作Redis
在使用django的websocket的时候,发现web请求和其他当前的django进程的内存是不共享的,猜测django的机制可能是每来一个web请求,就开启一个进程去与web进行交互,一次来达到利 ...
- 【python】Redis介绍及简单使用
一.redis redis是一个key-value存储系统.和 Memcached类似,它支持存储的value类型相对更多,包括string(字符串). list(链表).set(集合).zset(s ...
- python之 Redis
Redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorte ...
- python 实现redis订阅发布功能
redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorted set ...
- python之redis模块
一.redis简介 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(s ...
- Python操作Redis(一)
redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorted set ...
- Python操作Redis、Memcache
今天主要介绍如何通过python来对Redis和memcache进行操作,下面开始今天的内容: 一.Memcached操作 Memcached是一个高性能的分布式内存对象缓存系统,用于动态Web ...
- Redis - Python操作Redis
目录 Python操作Redis 一. Redis安装和基本使用 二. Python操作Redis API使用 1.操作模式 2.连接池 3.Django配置Redis 4.操作 Python操作Re ...
- python中redis
一.简介 二.redis的安装和使用 三.python操作readis之安装和支持存储类型 四.python操作redis值普通链接 五.python操作redis值连接池 六.操作之String操作 ...
随机推荐
- 《javascript语言精粹》读书笔记 Item2 对象
第三章 对象 JavaScript的简单数据类型包括数字.字符串.布尔值(true和false).null值和undefined值.其他 数字.字符串和布尔值"貌似"对象,因为它们 ...
- Windows平台软件推荐:神器小工具(骨灰级)
底层工具 "If you know how to use Process Monitor competently, people of both sexes will immediately ...
- Windows10 使用docker toolbox安装docker
一.介绍 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相互之间 ...
- 重设msyql数据库root密码
重设密码的方法: 具体方法是: 1.先在安装目录找到my.ini配置文件,打开配置文件, 找到[mysqld]一行,在下面添加skip-grant-tables后保存该文件 重新启mysql动服务; ...
- Go 延迟函数 defer 详解
Go 延迟函数 defer 详解 Go 语言中延迟函数 defer 充当着 try...catch 的重任,使用起来也非常简便,然而在实际应用中,很多 gopher 并没有真正搞明白 defer.re ...
- 【原创】分布式之redis复习精讲
引言 为什么写这篇文章? 博主的<分布式之消息队列复习精讲>得到了大家的好评,内心诚惶诚恐,想着再出一篇关于复习精讲的文章.但是还是要说明一下,复习精讲的文章偏面试准备,真正在开发过程中, ...
- 关于DatePicker在模态窗体下失效的问题
最近用bootstrap做了一个租赁相关的管理系统,由于前端知识薄弱,也是编查资料边做.关于一些控件的用法,也是从网上查资料.下面,来说一下在写前端页面时遇到的几个坑. 这个系统中,日期控件用的是Da ...
- 大白话5分钟带你走进人工智能-第十五节L1和L2正则几何解释和Ridge,Lasso,Elastic Net回归
第十五节L1和L2正则几何解释和Ridge,Lasso,Elastic Net回归 上一节中我们讲解了L1和L2正则的概念,知道了L1和L2都会使不重要的维度权重下降得多,重要的维度权重下降得少,引入 ...
- 多租户实现之基于Mybatis,Mycat的共享数据库,共享数据架构
前言 SaaS模式是什么? 传统的软件模式是在开发出软件产品后,需要去客户现场进行实施,通常部署在局域网,这样开发.部署及维护的成本都是比较高的. 现在随着云服务技术的蓬勃发展,就出现了SaaS模式. ...
- Vue 进阶之路(二)
之前的文章我们初识了 vue,对其原理,数据绑定和方法进行了简单的演示,本篇将对 vue 插值表达式,v-text,v-html 进行讲解. <!DOCTYPE html> <htm ...