wget http://download.redis.io/releases/redis-x.x.x.tar.gzhtml
tar xzf redis-x.x.x.tar.gznode
sudo mv ./redis-x.x.x /usr/local/redis/python
cd /usr/local/redis/git
sudo makegithub
sudo make test正则表达式
/usr/local/bin/
⽬录sudo make installredis
/usr/local/bin
中查看cd /usr/local/bin算法
ls -all数据库
redis-server redis服务器ubuntu
redis-cli redis命令行客户端
redis-benchmark redis性能测试工具
redis-check-aof AOF文件修复工具
redis-check-rdb RDB文件检索工具
/etc/
⽬录下 配置⽂件⽬录为/usr/local/redis/redis.conf
sudo cp /usr/local/redis/redis.conf /etc/redis/
Mac 上安装 Redis:https://brew.sh/
使用 brew 安装 Redis:https://www.cnblogs.com/cloudshadow/p/mac_brew_install_redis.html
/etc/redis/redis.conf
下查看 sudo vi /etc/redis/redis.conf
键命令 1)查看全部键:keys * 2)查看名称中包含a的键:keys a* 3)判断键是否存在,若是存在返回1,不存在返回0:exists key1 4)查看键对应的value的类型:type key 5)删除键及对应的值:del key1 key2 ... 6)设置过时时间,以秒为单位:expire key seconds 7)查看有效时间,以秒为单位:ttl key
hash类型: hash⽤于存储对象,对象的结构为属性、值 值的类型为string 1、增长、修改 设置单个属性:hset key field value 设置多个属性:hmset key field1 value1 field2 value2 ... 2、获取 获取指定键全部的属性:hkeys key 获取全部属性的值:hvals key 获取⼀个属性的值:hget key field 获取多个属性的值:hmget key field1 field2 ... 3、删除 删除整个hash键及值,使⽤del命令:hdel key ...
list类型 列表的元素类型为string 按照插⼊顺序排序 1、增长 在左侧插⼊数据:lpush key value1 value2 ... 在右侧插⼊数据:rpush key value1 value2 ... 在指定元素的前或后插⼊新元素: linsert key before或after 现有元素 新元素 2、获取 返回列表⾥指定范围内的元素:range key start stop 设置指定元素的值:lset key index value 3、删除 删除指定元素 将列表中前count次出现的值为value的元素移除 count > 0: 从头往尾移除 count < 0: 从尾往头移除 count = 0: 移除全部 lrem key count value 4、截取修剪 修剪(截取) 在[start stop]区间内的元素,区间外的元素所有删除 ltrim key start stop
set类型 1)⽆序集合 2)元素为string类型 3)元素具备惟⼀性,不重复 4)说明:对于集合没有修改操做 1、增长 1)添加元素:sadd key member1 member2 ... 2、获取 1)返回全部的元素:smembers key 3、删除 1)删除指定元素:srem key values
zset类型 1)sorted set,有序集合 2)元素为string类型 3)元素具备惟⼀性,不重复 4)每一个元素都会关联⼀个double类型的score, 表示权重,经过权重将元素从⼩到⼤排序 5)说明:没有修改操做 1、增长 1)添加:zadd key score1 member1 score2 member2 ... 2、获取 1)返回指定范围内的元素:zrange key start stop 2)获取键a1的集合中权限值在min和max之间的成员 zrangebyscore a1 5 6 3)获取键a2的集合中元素zhangsan的权重 zscore a4 zhangsan 3、删除 1)删除指定元素:zrem key member1 member2 ... 2)删除权重在指定范围的元素:zremrangebyscore key min max
安装Redis的有3种方式https://github.com/andymccurdy/redis-py
StrictRedis对象
,⽤于链接redis服务器,并按照不一样类型提供 了不一样⽅法,进⾏交互操做
sr = StrictRedis(host='localhost', port=6379, db=0) sr=StrictRedis()
1、exists 2、type 3、delete 4、expire 5、getrange 六、ttl
1、set 2、setex 3、mset 4、append 5、get 6、mget 七、key
1、hset 2、hmset 3、hkeys 4、hget 5、hmget 6、hvals 七、hdel
1、lpush 2、rpush 3、linsert 4、lrange 5、lset 六、lrem
1、sadd 2、smembers 三、srem
1、zadd 2、zrange 3、zrangebyscore 4、zscore 5、zrem 六、zremrangebyscore
⽅法set,添加键、值,若是添加成功则返回True,若是添加失败则返回False 编写代码以下: from redis import * if __name__=="__main__": try: #建立StrictRedis对象,与redis服务器建⽴链接 sr=StrictRedis() #添加键name,值为itheima result=sr.set('name','itheima') #输出响应结果,若是添加成功则返回True,不然返回False print(result) except Exception as e: print(e)
1)⽅法get,添加键对应的值,若是键存在则返回对应的值, 若是键不存在则返回None 编写代码以下: from redis import * if __name__=="__main__": try: #建立StrictRedis对象,与redis服务器建⽴链接 sr=StrictRedis() #获取键name的值 result = sr.get('name') #输出键的值,若是键不存在则返回None print(result) except Exception as e: print(e)
1)⽅法set,若是键已经存在则进⾏修改,若是键不存在则进⾏添加 编写代码以下: from redis import * if __name__=="__main__": try: #建立StrictRedis对象,与redis服务器建⽴链接 sr=StrictRedis() #设置键name的值,若是键已经存在则进⾏修改,若是键不存在则进⾏添加 result = sr.set('name','itcast') #输出响应结果,若是操做成功则返回True,不然返回False print(result) except Exception as e: print(e)
1)⽅法delete,删除键及对应的值,若是删除成功则返回受影响的键数, 不然返回0 编写代码以下: from redis import * if __name__=="__main__": try: #建立StrictRedis对象,与redis服务器建⽴链接 sr=StrictRedis() #设置键name的值,若是键已经存在则进⾏修改,若是键不存在则进⾏添加 result = sr.delete('name') #输出响应结果,若是删除成功则返回受影响的键数,不然则返回0 print(result) except Exception as e: print(e)
1)⽅法keys,根据正则表达式获取键 编写代码以下: from redis import * if __name__=="__main__": try: #建立StrictRedis对象,与redis服务器建⽴链接 sr=StrictRedis() #获取全部的键 result=sr.keys() #输出响应结果,全部的键构成⼀个列表,若是没有键则返回空列表 print(result) except Exception as e: print(e)
master和slave都是一个redis实例(redis服务)
/etc/redis/redis.conf
文件 sudo vi redis.conf
bind 192.168.26.128
sudo service redis stop
sudo redis-server redis.conf
配置从
/etc/redis/redis.conf
文件 sudo cp redis.conf ./slave.conf
redis/slave.conf
文件 sudo vi slave.conf
bind 192.168.26.128
port 6378
slaveof 192.168.26.128 6379
sudo redis-server slave.conf
redis-cli -h 192.168.26.128 info Replication
redis-cli -h 192.168.26.128 -p 6379
redis-cli -h 192.168.26.128 -p 6378
set aa aa
get aa
REDIS = { 'Master':{ 'host':'192.168.56.100', 'port': '6379', 'db': 0 }, 'Slave':{ 'host':'192.168.56.100', 'port': '6378', 'db': 0 }, } class MSRedis(object): '''读写分离客户端(只针对程序中用到的命令)''' def __init__(self,conf): self.master = StrictRedis(**conf['Master']) self.slave = StrictRedis(**conf['Slave']) self.read_commands = [ 'ttl', 'exist', 'expire', 'get', 'keys', 'hget', 'hgetall', 'hkeys', 'hmget', 'sismember', 'smembers', 'sdiff', 'sinter', 'sunion' 'zrevrange', 'zrevrangebyscore', 'zrevrank', 'zscore' ] def __getattribute__(self, name): if name in ['master', 'slave', 'read_commands']: return object.__getattribute__(self, name) elif name in self.read_commands: print('选择了从库') return self.slave.__getattribute__(name) else: print('选择了主库') return self.master.__getattribute__(name) rds = MSRedis(REDIS) res = rds.get('name2') # res = rds.set('name2','lisi') print(res)
port 7000 bind 192.168.56.100 daemonize yes pidfile 7000.pid cluster-enabled yes cluster-config-file 7000_node.conf cluster-node-timeout 15000 appendonly yes
port 7001 bind 192.168.56.100 daemonize yes pidfile 7001.pid cluster-enabled yes cluster-config-file 7001_node.conf cluster-node-timeout 15000 appendonly yes
port 7002 bind 192.168.56.100 daemonize yes pidfile 7002.pid cluster-enabled yes cluster-config-file 7002_node.conf cluster-node-timeout 15000 appendonly yes
redis-server 7000.conf redis-server 7001.conf redis-server 7002.conf
port 7003 bind 192.168.56.100 daemonize yes pidfile 7003.pid cluster-enabled yes cluster-config-file 7003_node.conf cluster-node-timeout 15000 appendonly yes
port 7004 bind 192.168.56.100 daemonize yes pidfile 7004.pid cluster-enabled yes cluster-config-file 7004_node.conf cluster-node-timeout 15000 appendonly yes
port 7005 bind 192.168.56.100 daemonize yes pidfile 7005.pid cluster-enabled yes cluster-config-file 7005_node.conf cluster-node-timeout 15000 appendonly yes
redis-server 7003.conf redis-server 7004.conf redis-server 7005.conf
sudo cp /usr/share/doc/redis-tools/examples/redis-trib.rb /usr/local/bin/
sudo apt-get install ruby
redis-trib.rb create --replicas 1 192.168.56.100:7000 192.168.56.100:7001 192.168.56.100:7002 192.168.56.100:7003 192.168.56.100:7004 192.168.56.100:7005
-- 先查看⾃⼰的 gem 源是什么地址 gem source -l -- 若是是https://rubygems.org/ 就须要更换 -- 更换指令为 gem sources --add https://gems.ruby-china.com/ --remove https://rubygems.org/ -- 经过 gem 安装 redis 的相关依赖 sudo gem install redis -- 而后从新执⾏指令
redis-trib.rb create --replicas 1 192.168.56.100:7000 192.168.56.100:7001 192.168.56.100:7002 192.168.56.100:7003 192.168.56.100:7004 192.168.56.100:7005
redis-cli -h 172.16.179.131 -c -p 7002
set name itheima
在7003能够获取数据,若是写入数据又重定向到7000(负载均衡)
from rediscluster import * if __name__ == '__main__': try: # 构建全部的节点,Redis会使⽤CRC16算法,将键和值写到某个节点上 startup_nodes = [ {'host': '192.168.56.100', 'port': '7000'}, {'host': '192.168.56.100', 'port': '7001'}, {'host': '192.168.56.100', 'port': '7002'}, {'host': '192.168.56.100', 'port': '7003'}, {'host': '192.168.56.100', 'port': '7004'}, {'host': '192.168.56.100', 'port': '7005'}, ] # 构建StrictRedisCluster对象 src=RedisCluster(startup_nodes=startup_nodes,decode_responses=True) #decode_responses=True 返回的内容自动decode一下 # 设置键为name、值为itheima的数据 result=src.set('name','zhangsan') print(result) # 获取键为name name = src.get('name') print(name) except Exception as e: print(e) #一、存储的位置不须要管 由于它是经过哈希自动分配到一个服务器上 #二、如今咱们开发只是要求高性能 还没 # 有高可用 崩溃了以后 有崩溃的处理方式 高可用交给运维去作