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) #一、存儲的位置不須要管 由於它是經過哈希自動分配到一個服務器上 #二、如今咱們開發只是要求高性能 還沒 # 有高可用 崩潰了以後 有崩潰的處理方式 高可用交給運維去作