Redis介绍及字符串操作
一、前言
不同程序之间实现通信的方法?
A.通过不同程序之间建立socket,实现通信。实际应用适用于使用broker,如RabbitMQ,ZeroMQ.
B.通过Json,Pickle,利用文件的写入和读取实现不同程序之间的通信,但是效率低。
C.通过在不同的程序之间加入一个中间代理程序,中间代理程序在内存中开辟一块独立的内存,程序和broker通过socket建立连接,将broker的内存通过socket共享给连接它的程序。如:memcached,redis等Key-value nosql数据库。
二、Redis介绍
1.Redis介绍
redis是业界主流的key-value nosql数据库之一。和Memcached类似,它支持存储的value类型相对更多。
支持的数据类型:字符串string,链表list,集合set,有序集合zset和哈希类型hash,这些数据类型都支持push/pop,add/remove,取交集并集和差集以及更丰富的操作。这些操作都是原子性的,从而确保两个客户同时访问redis服务器得到的是更新后的值。
支持的排序方式:redis支持各种不同方式的排序。
存储位置:与memcached一样,为了保证效率,数据都缓存在内存中。
读取速度:Redis是单线程的,通过epoll实现了高并发,异常快速,每秒可以执行大约110000设置操作,81000个/秒的读取操作。
redis与memcached的区别:redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础桑实现了master-slave(主从)同步。
MultiUtility工具:Redis是一个多功能实用工具。在应用程序中,如Web应用程序会话,网站页面点击数等任何短暂的数据;缓存,消息传递队列中使用(Redis原生支持发布/订阅)。
2.Redis的API使用
redis和python之间的API使用可以分类为:
- 连接方式
- 连接池
- 操作
- String 操作
- Hash 操作
- List 操作
- Set 操作
- Sort Set 操作
- 管道
- 发布订阅
2.1 连接方式
Python中下载redis包,调用redis模块。
2.1.1 Redis,StrictRedis
redis-py提供两个类Redis和StrictRedis用于实现Redis的命令,StrictRedis用于实现大部分官方的命令,并使用官方的语法和命令,Redis是StrictRedis的子类,用于向后兼容旧版本的redis-py。
import redis r = redis.Redis(host='10.211.55.4', port=6379)
r.set('foo', 'Bar')
print r.get('foo')
2.1.2 连接池
redis-py使用connection pool来管理对一个redis server的所有连接,避免每次建立、释放连接的开销。默认,每个Redis实例都会维护一个自己的连接池。可以直接建立一个连接池,然后作为参数Redis,这样就可以实现多个Redis实例共享一个连接池。
import redis
pool=redis.ConnectionPool('localhost')
r=redis.Redis(connection_pool=pool)
r.set('name','zoe')
print(r.get('name'))
2.2 操作
2.2.1 字符串String操作
redis中的String在在内存中按照一个name对应一个value来存储。

set(name, value, ex=None, px=None, nx=False, xx=False)
在Redis中设置值,默认,不存在则创建,存在则修改
参数:
ex,过期时间(秒)
px,过期时间(毫秒)
nx,如果设置为True,则只有name不存在时,当前set操作才执行
xx,如果设置为True,则只有name存在时,岗前set操作才执行
设置值,只有name不存在时,执行设置操作(添加)
实际上等价于 set(name,value,nx=True)
设置值
参数:time,过期时间(数字秒 或 timedelta对象)
设置值参数:
time_ms,过期时间(数字毫秒 或 timedelta对象)
mset(k1='v1',k2='v2')
mget({'k1':'v1','k2':'v2'})
get(name)
获取值
mget(keys,*args)
批量获取
mget('ylr','peipei')
r.get(['ylr','peipei'])
getset(name,value)
设置新值并获取原来的值
getrange(key,start,end)
获取子序列(根据字节获取,非字符)
参数:
name,Redis的name
start,起始位置(字节)
end,结束位置(字节)
setrange(name,offset,value)
修改字符串内容,从指定字符串索引开始向后替换(新值太长,则向后添加)
参数:
offset,字符串的索引,字节(一个汉字三个字节)
value,要设置的值
source='foo'
for i in source:
num=ord(i)
print(bin(num).replace('b',''))
特别地,如果source是汉字,怎么办?对于utf-8,每一个汉字占3个字节,那么“美少女战士”就有15个字节,对于汉字,for循环时候会按照 字节 迭代,那么在迭代时,将每一个字节转换 十进制数,然后再将十进制数转换成二进制。

获取name对应的值的二进制表示中1的个数
参数:
key,Redis的name
start,位起始位置
end,位结束位置
自增name对应的值,当name不存在时,则创建name=amount,否则,则自增。
参数:
name,Redis的name
amount,自增数(必须是整数)
注:同incrby

参数:
name,Redis的name
amount,自增数(浮点数)

自减name对应的值,当name不存在时,则创建name=amount,否则,则自减。
参数:
name,Redis的name
amount,自减数(整数)
在redis name对应的值后面追加内容
参数:
key,redis的name
value,要追加的字符串
Redis介绍及字符串操作的更多相关文章
- 如何使用RedisTemplate访问Redis数据结构之字符串操作
Redis 数据结构简介 Redis 可以存储键与5种不同数据结构类型之间的映射,这5种数据结构类型分别为String(字符串).List(列表).Set(集合).Hash(散列)和 Zset(有序集 ...
- 字符串操作 — Google Guava
前言 Java 里字符串表示字符的不可变序列,创建后就不能更改.在我们日常的工作中,字符串的使用非常频繁,熟练的对其操作可以极大的提升我们的工作效率,今天要介绍的主角是 Google 开源的一个核心 ...
- Redis介绍及Jedis基础操作
1.Redis简介 Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 它支持多种类型的数据结构,如 字符串(strings), 散列(hashes ...
- 基于Python操作redis介绍
(注:本文部分内容摘自互联网,由于作者水平有限,不足之处,还望留言指正.) 毕业前的最后一个学期(2016.03),龙哥结婚了.可是总有些人喜欢嘲笑别人,调侃我.当时我就理直气壮的告诉他们,等龙哥孩子 ...
- Redis介绍、安装部署、操作
学习连接:http://www.runoob.com/redis/redis-tutorial.html 一.Redis介绍 Redis是NoSql的一种. NoSql,全名:Not Only Sql ...
- go语言之进阶篇字符串操作常用函数介绍
下面这些函数来自于strings包,这里介绍一些我平常经常用到的函数,更详细的请参考官方的文档. 一.字符串操作常用函数介绍 1.Contains func Contains(s, substr st ...
- PHP操作redis之String(字符串)、List(列表)(一)
Redis 简介 Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. Redis 与其他 key – value 缓存产品有以下三个特点: Redis支持数据的持久 ...
- redis 介绍与操作
参考连接: https://www.cnblogs.com/wupeiqi/articles/5132791.html redis 是什么? redis是一个软件,帮助开发者对一台机器的内存进行操作 ...
- redis 字符串操作
redis 字符串创建SET操作 127.0.0.1:6379> set number "10086" OK 127.0.0.1:6379> set book &quo ...
随机推荐
- reuire代码优化之:r.js
r.js是requireJS的优化(Optimizer)工具,可以实现前端文件的压缩与合并,在requireJS异步按需加载的基础上进一步提供前端优化,减小前端文件大小.减少对服务器的文件请求.要使用 ...
- PTA数据结构与算法题目集(中文) 7-4
PTA数据结构与算法题目集(中文) 7-4 是否同一颗二叉搜索树 给定一个插入序列就可以唯一确定一棵二叉搜索树.然而,一棵给定的二叉搜索树却可以由多种不同的插入序列得到.例如分别按照序列{2, 1, ...
- SSM集合定时任务
1.首先要在spring-config.xml里面配置一下: xmlns:task="http://www.springframework.org/schema/task" htt ...
- C++头文件应该干的事情
C++头文件应该干的事情 最近在写自己项目的时候,头文件老是编译错误,后来发现还是对头文件掌握不牢. 头文件应该干什么? 所谓的头文件,其实它的内容跟 .cpp 文件中的内容是一样的,都是 C++ 的 ...
- mysql 聚集函数 count 使用详解
mysql 聚集函数 count 使用详解 本文将探讨以下问题 1.count(*) . count(n).count(null)与count(fieldName) 2.distinct 与 coun ...
- 2018蓝桥杯省赛(C/C++ C组)
因进考场不让带优盘,顾想不起有些啥题了,静待更新吧! 再次强调C++最新标准,main函数必须指定返回类型为int,且返回值最好为0(人走的多了就是路了,有人偏返回999那也没办法) 1.大概是小明给 ...
- Mac 系统root
没错,你没看错,就是root mac系统安装件的时候,你有没有遇到过这种情况 总之,就是安装不上软件,肿么办? 网上解觉办法是: 进入系统偏好设置,设置为允许任何人,可是进去后这样: 别着急,打开命令 ...
- python的int float if...else
# 字符串 string 单引号 ‘ ’ 双引号 “ ”-包含的 app = 'dongt woory' 外面单引号里面可以双引号,外面双引号,里面也可以单引号 app ='你是真的“好看”吗' ...
- 选择排序(C++,Java,Python实现)
排序算法之选择排序,选择排序,选择排序的基本思想描述为:每一趟在n-i+1(i=1,2,-,n-1)个记录中选取关键字最小的记录作为有序序列中第i个记录.具体来说,假设长度为n的数组arr,要按照从小 ...
- Python操作rabbitmq系列(一)
从本文开始,接下来的内容,我们将讨论rabbitmq的相关功能.我的这些文章,最终是要实现一个项目(具体是什么暂不透露).前面每一篇,都是在为这个系统做准备.rabbitmq,是我们这个项目的关键部分 ...