一、前言

不同程序之间实现通信的方法?

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操作才执行

 
setnx(name, value)

设置值,只有name不存在时,执行设置操作(添加)

实际上等价于 set(name,value,nx=True)

setex(name, value, time)
设置值

参数:time,过期时间(数字秒 或 timedelta对象)

 
psetex(name, time_ms, value)
设置值

参数:

   time_ms,过期时间(数字毫秒 或 timedelta对象)

 
mset(*args, **kwargs)
批量设置值
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,要设置的值

setbit(name, offset, value)
对name对应值得二进制表示的位进行操作
参数:
  name,Redis的name
  offset,位的索引(将值变换成二进制后再进行索引)
  value,值只能是1或0
注:
  如果在Redis中有一个对应:n1="foo",
那么字符串foo的二进制表示为:01100110 01101111 01101111,所以,如果执行setbit('n1',7,1),则就会将第7位设置为1,那么最终二进制则变成:01100111 01101111 01101111 ,即:“goo”
拓展,转换二进制表示:
  

source='foo'
for i in source:
num=ord(i)
print(bin(num).replace('b',''))

  特别地,如果source是汉字,怎么办?对于utf-8,每一个汉字占3个字节,那么“美少女战士”就有15个字节,对于汉字,for循环时候会按照 字节 迭代,那么在迭代时,将每一个字节转换 十进制数,然后再将十进制数转换成二进制。

getbit(name, offset)
获取name对应的值的二进制表示中的某位的值(0或1)
 
bitcount(key, start=None, end=None)

获取name对应的值的二进制表示中1的个数

参数:

  key,Redis的name

  start,位起始位置

  end,位结束位置

 
strlen(name)
返回name对应值得字节长度(一个汉字3个字节)
 
incr(self, name, amount=1)

自增name对应的值,当name不存在时,则创建name=amount,否则,则自增。

参数:

  name,Redis的name

  amount,自增数(必须是整数)

注:同incrby

 
incrbyfloat(self, name, amount=1.0)
自增name对应的值,当name不存在时,则创建name=amount,否则,则自增。

参数:

  name,Redis的name

  amount,自增数(浮点数)

  

decr(self, name, amount=1)

自减name对应的值,当name不存在时,则创建name=amount,否则,则自减。

参数:

  name,Redis的name

  amount,自减数(整数)

 
append(key, value)

在redis name对应的值后面追加内容

参数:

  key,redis的name

  value,要追加的字符串

 

Redis介绍及字符串操作的更多相关文章

  1. 如何使用RedisTemplate访问Redis数据结构之字符串操作

    Redis 数据结构简介 Redis 可以存储键与5种不同数据结构类型之间的映射,这5种数据结构类型分别为String(字符串).List(列表).Set(集合).Hash(散列)和 Zset(有序集 ...

  2. 字符串操作 — Google Guava

    前言 Java 里字符串表示字符的不可变序列,创建后就不能更改.在我们日常的工作中,字符串的使用非常频繁,熟练的对其操作可以极大的提升我们的工作效率,今天要介绍的主角是 Google 开源的一个核心 ...

  3. Redis介绍及Jedis基础操作

    1.Redis简介 Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 它支持多种类型的数据结构,如 字符串(strings), 散列(hashes ...

  4. 基于Python操作redis介绍

    (注:本文部分内容摘自互联网,由于作者水平有限,不足之处,还望留言指正.) 毕业前的最后一个学期(2016.03),龙哥结婚了.可是总有些人喜欢嘲笑别人,调侃我.当时我就理直气壮的告诉他们,等龙哥孩子 ...

  5. Redis介绍、安装部署、操作

    学习连接:http://www.runoob.com/redis/redis-tutorial.html 一.Redis介绍 Redis是NoSql的一种. NoSql,全名:Not Only Sql ...

  6. go语言之进阶篇字符串操作常用函数介绍

    下面这些函数来自于strings包,这里介绍一些我平常经常用到的函数,更详细的请参考官方的文档. 一.字符串操作常用函数介绍 1.Contains func Contains(s, substr st ...

  7. PHP操作redis之String(字符串)、List(列表)(一)

    Redis 简介 Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. Redis 与其他 key – value 缓存产品有以下三个特点: Redis支持数据的持久 ...

  8. redis 介绍与操作

    参考连接:  https://www.cnblogs.com/wupeiqi/articles/5132791.html redis 是什么? redis是一个软件,帮助开发者对一台机器的内存进行操作 ...

  9. redis 字符串操作

    redis 字符串创建SET操作 127.0.0.1:6379> set number "10086" OK 127.0.0.1:6379> set book &quo ...

随机推荐

  1. JavaScript中数组的两种排序方法详解(冒泡排序和选择排序)

    一.冒泡排序的原理(从小到大) 相邻两个数进行比较,如果前一个数大于后一个数,那么就交换,否则不交换 原理剖析 比如有一组含有6个数字的数:5.3.7.2.1.6一共6个数字,做5次循环,每次循环相邻 ...

  2. Codeforces - Watermelon

    A. Watermelon time limit per test 1 second memory limit per test 64 megabytes input standard input o ...

  3. Evolution of Image Classifiers,进化算法在神经网络结构搜索的首次尝试 | ICML 2017

    论文提出使用进化算法来进行神经网络结构搜索,整体搜索逻辑十分简单,结合权重继承,搜索速度很快,从实验结果来看,搜索的网络准确率挺不错的.由于论文是个比较早期的想法,所以可以有很大的改进空间,后面的很大 ...

  4. Mac 系统root

    没错,你没看错,就是root mac系统安装件的时候,你有没有遇到过这种情况 总之,就是安装不上软件,肿么办? 网上解觉办法是: 进入系统偏好设置,设置为允许任何人,可是进去后这样: 别着急,打开命令 ...

  5. "图片组件"组件:<pic> —— 快应用组件库H-UI

     <import name="pic" src="../Common/ui/h-ui/media/c_pic"></import> & ...

  6. php-fpm 进程数的设定

    近日,服务器出现异常,网站不能正常访问.经排查是php的问题. 在重启php-fpm时,恢复正常.1分钟之后又出现故障.查看php日志文件 /usr/local/php/var/log 后提示 WAR ...

  7. Opencv for android 模板匹配

    因为有这方面的需要所以,对模板查找搜寻了相关资料,只是对于算法的东西很难看得动,特别是opencv涉及的很多的数学方法. 所以只为了实现这个功能,因为需求比较简单,在网上也搜寻到了相关代码,就直接拿来 ...

  8. c++ 启发式搜索解决八数码问题

    本文对八数码问题 启发式搜索 (C++)做了一点点修改 //fn=gn+hn #include<iostream> #include<queue> #include<st ...

  9. python嵌套列表知多少

    今天在创建嵌套列表时遇到一个问题,决定看看到底是谁在背后捣鬼 >>> board1 = [[0]*3 for _ in range(3)] [[0, 0, 0], [0, 0, 0] ...

  10. 牛客练习赛61 相似的子串(二分+Hash)

    题面在此 题解:将字符串分成k部分,然后求最长前缀,所以我们只关注前缀部分就好了,公共前缀后边的是啥不用管,那么问题就转化成了是否存在k个不相交的字符串的最长公共前缀问题.首先用Hash来记录一下字符 ...