redis缓存服务重点简单总结(cent6.6和red6.5)
如果对运维课程感兴趣,可以在b站上搜索我的账号: 运维实战课程,可以关注我,学习更多免费的运维实战技术视频
1.redis缓存服务安装和测试存储数据(单redis服务,使用默认端口6379运行时)
1)在192.168.14.128上:(服务端)(安装redis服务,需要启动服务)
[root@bogon ~]# yum -y install gcc gcc-c++
[root@bogon ~]# tar -zxf redis-2.6.14.tar.gz
[root@bogon ~]# cd redis-2.6.14
[root@bogon redis-2.6.14]# make MALLOC=jemalloc
[root@bogon redis-2.6.14]# make PREFIX=/usr/local/redis install
[root@bogon redis-2.6.14]# mkdir /usr/local/redis/conf #优化目录结构
[root@bogon redis-2.6.14]# cp redis.conf /usr/local/redis/conf/ #配置其他功能可修改配置文件
[root@bogon redis-2.6.14]# echo "PATH=/usr/local/redis/bin/:$PATH" >> /etc/profile
[root@bogon redis-2.6.14]# . /etc/profile
[root@bogon redis-2.6.14]# sysctl vm.overcommit_memory=1 #解决启动时内存不够问题
[root@bogon redis-2.6.14]# echo "sysctl vm.overcommit_memory=1" >> /etc/sysctl.conf
[root@bogon redis-2.6.14]# redis-server /usr/local/redis/conf/redis.conf & #指定配置文件启动
[root@bogon redis-2.6.14]# lsof -i :6379 #有端口
[root@bogon redis-2.6.14]# ps -ef |grep redis #有进程
[root@bogon redis-2.6.14]# pkill redis-server #杀掉服务
[root@bogon redis-2.6.14]# redis-cli shutdown #停止服务
[root@bogon redis-2.6.14]# redis-server /usr/local/redis/conf/redis.conf & #指定配置文件启动
[1] 3466
.........
[3466] 18 Apr 21:22:20.483 * The server is now ready to accept connections on port 6379 回车即可
注意事项1:
1)若配置文件里改成在后台运行(yes),启动时候才能将pid号保存到配置文件指定文件,那么启动时候不用加&选项。若配置文件不是指定在后台运行(是no),那么即使配置文件指定了存放pid号的文件,该文件里也不会有pid号.
2)若默认端口号改成其他端口号,客户端连接时候需要指定端口号才能连接。
[root@bogon ~]# vim /usr/local/redis/conf/redis.conf
daemonize no #默认情况下,redis不是在后台运行的,如果需要在后台运行,把该项的值更改为yes
pidfile /var/run/redis.pid #当redis在后台运行时(yes时),redis默认会把pid文件放在/var/run/redis.pid,也可配置到其他地址
port 6379 #默认端口号,也可修改为其他,若改为其他,则客户端登录时需指定端口号
注意事项2:redis可以设置密码,让客户端指定密码才能连接:客户端不指定密码,看似能连上,但用keys * 查不到数据
#vim ...redis.conf
requirepass Duyao001 #密码设置为Duyao001
此后客户端连接redis服务器时候,需要指定密码才能连接上,#redis-cli -h redis服务ip -p 端口号 -a Duyao001(密码)
2)本地测试存储数据和获得数据:(redis-cli客户端测试)
[root@bogon redis-2.6.14]# redis-cli 或者:redis-cli -h 192.168.14.128 -p 6379
redis 192.168.14.128:6379> set key1 001
OK
redis 192.168.14.128:6379> set key2 002
OK
redis 192.168.14.128:6379> get key1
"001"
redis 192.168.14.128:6379> get key2
"002"
redis 192.168.14.128:6379> del key1
(integer) 1
redis 192.168.14.128:6379> get key1
(nil)
redis 192.168.14.128:6379> quit
3)其他机器192.168.14.129上:作为客户端测试存储数据和获得数据:(redis-cli客户端测试,也需要安装redis,利用里面的客户端工具redis-cli,但不需要启动redis服务)
[root@localhost ~]# yum -y install gcc gcc-c++
[root@localhost ~]# tar -zxf redis-2.6.14.tar.gz
[root@localhost ~]# cd redis-2.6.14
[root@localhost redis-2.6.14]# make MALLOC=jemalloc
[root@localhost redis-2.6.14]# make PREFIX=/usr/local/redis install #客户端安装一下即可,不用优化目录,不用启动服务
[root@localhost redis-2.6.14]# echo "PATH=/usr/local/redis/bin/:$PATH" >> /etc/profile
[root@localhost redis-2.6.14]# . /etc/profile
[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6379
redis 192.168.14.128:6379> set key5 005
OK
redis 192.168.14.128:6379> set key6 006
OK
redis 192.168.14.128:6379> get key5
"005"
redis 192.168.14.128:6379> get key6
"006"
redis 192.168.14.128:6379> del key5
(integer) 1
redis 192.168.14.128:6379> get key5
(nil)
redis 192.168.14.128:6379> quit
注意:本地客户端和和其他机器客户端都一样,其他机器只是需要安装一个命令,本地客户端已经安装过命令,不需再安装命令而已。
2.redis缓存服务安装和测试存储数据(redis服务多实例启动,使用指定多端口,多pid并存放到指定文件中运行时)
1)在192.168.14.128上:(服务端)(安装redis服务,需要启动服务)
[root@bogon ~]# yum -y install gcc gcc-c++
[root@bogon ~]# tar -zxf redis-2.6.14.tar.gz
[root@bogon ~]# cd redis-2.6.14
[root@bogon redis-2.6.14]# make MALLOC=jemalloc
[root@bogon redis-2.6.14]# make PREFIX=/usr/local/redis install
[root@bogon redis-2.6.14]# mkdir /usr/local/redis/conf //优化目录结构
[root@bogon redis-2.6.14]# cp redis.conf /usr/local/redis/conf/ //配置其他功能可修改配置文件
[root@bogon redis-2.6.14]# echo "PATH=/usr/local/redis/bin/:$PATH" >> /etc/profile
[root@bogon redis-2.6.14]# . /etc/profile
[root@bogon redis-2.6.14]# sysctl vm.overcommit_memory=1 //解决内存小时启动警告问题
[root@bogon redis-2.6.14]# echo "sysctl vm.overcommit_memory=1" >> /etc/sysctl.conf
[root@bogon redis-2.6.14]# cd /usr/local/redis/conf/
[root@bogon redis-2.6.14]# vim redis.conf #默认的配置文件作为实例1
daemonize yes #修改为后台,其他保持默认,
pidfile /var/run/redis.pid
port 6379
[root@bogon redis-2.6.14]# cp redis.conf redis2.conf
[root@bogon redis-2.6.14]# cp redis.conf redis3.conf
[root@bogon redis-2.6.14]# vim redis2.conf #复制一个配置文件作为实例2
daemonize yes #修改为后台
pidfile /var/run/redis2.pid #修改
port 6380 #修改
[root@bogon redis-2.6.14]# vim redis3.conf #再复制一个配置文件作为实例3
daemonize yes #修改为后台
pidfile /var/run/redis2.pid #修改
port 6381 #修改
[root@bogon conf]# redis-server /usr/local/redis/conf/redis.conf #指定配置文件启动
[root@bogon conf]# redis-server /usr/local/redis/conf/redis2.conf #指定配置文件启动
[root@bogon conf]# redis-server /usr/local/redis/conf/redis3.conf #指定配置文件启动
[root@bogon conf]# ps -ef |grep redis
root 3857 1 0 00:01 ? 00:00:00 redis-server /usr/local/redis/conf/redis.conf
root 3861 1 0 00:01 ? 00:00:00 redis-server /usr/local/redis/conf/redis2.conf
root 3865 1 0 00:01 ? 00:00:00 redis-server /usr/local/redis/conf/redis3.conf
root 3869 1406 0 00:01 pts/0 00:00:00 grep redis
[root@bogon conf]# cat /var/run/redis.pid
3857
[root@bogon conf]# cat /var/run/redis2.pid
3861
[root@bogon conf]# cat /var/run/redis3.pid
3865
[root@bogon conf]# netstat -anput |grep redis
tcp 0 0 0.0.0.0:6379 0.0.0.0:* LISTEN 3857/redis-server
tcp 0 0 0.0.0.0:6380 0.0.0.0:* LISTEN 3861/redis-server
tcp 0 0 0.0.0.0:6381 0.0.0.0:* LISTEN 3865/redis-server
多实例注意:
1)若用单独杀进程号杀掉单独一个实例,其他实例会正常工作而不受影响,只是当前杀掉的实例不能工作。
2)若用pkill redis-server按服务名杀掉服务,则所有实例都将被杀掉。
2)其他机器192.168.14.129上:作为客户端测试存储数据和获得数据:(redis-cli客户端测试,也需要安装redis,利用里面的客户端工具redis-cli,但不需要启动redis服务) #注意本地客户端和这一样,其他机器只是需要安装一个命令
[root@localhost ~]# yum -y install gcc gcc-c++
[root@localhost ~]# tar -zxf redis-2.6.14.tar.gz
[root@localhost ~]# cd redis-2.6.14
[root@localhost redis-2.6.14]# make MALLOC=jemalloc
[root@localhost redis-2.6.14]# make PREFIX=/usr/local/redis install #客户端只是安装命令,不需启动服务和优化目录
[root@localhost redis-2.6.14]# echo "PATH=/usr/local/redis/bin/:$PATH" >> /etc/profile
[root@localhost redis-2.6.14]# . /etc/profile
[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6379
redis 192.168.14.128:6379> set key1 001
OK
redis 192.168.14.128:6379> quit
[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6380
redis 192.168.14.128:6380> set key2 002
OK
redis 192.168.14.128:6380> quit
[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6381
redis 192.168.14.128:6381> set key3 003
OK
redis 192.168.14.128:6381> quit
[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6379
redis 192.168.14.128:6379> get key1
"001"
redis 192.168.14.128:6379> del key1
(integer) 1
redis 192.168.14.128:6379> get key1
(nil)
redis 192.168.14.128:6379> quit
[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6380
redis 192.168.14.128:6380> get key2
"002"
redis 192.168.14.128:6380> del key2
(integer) 1
redis 192.168.14.128:6380> get key2
(nil)
redis 192.168.14.128:6380> quit
[root@localhost redis-2.6.14]# redis-cli -h 192.168.14.128 -p 6381
redis 192.168.14.128:6381> get key3
"003"
redis 192.168.14.128:6381> del key3
(integer) 1
redis 192.168.14.128:6381> get key3
(nil)
redis 192.168.14.128:6381> quit
3.redis主从同步项目和负载均衡单实例redis服务(cent6.6和red6.5)
在192.168.4.5上(搭建redis服务(主))
[root@localhost 桌面]# yum -y install gcc gcc-c++
[root@localhost 桌面]# tar -zxf redis-2.6.14.tar.gz
[root@localhost 桌面]# cd redis-2.6.14
[root@localhost redis-2.6.14]# make MALLOC=jemalloc
[root@localhost redis-2.6.14]# make PREFIX=/usr/local/redis install
[root@localhost redis-2.6.14]# mkdir /usr/local/redis/conf //优化目录结构
[root@localhost redis-2.6.14]# cp redis.conf /usr/local/redis/conf/ //配置其他功能可修改配置文件
[root@localhost redis-2.6.14]# echo "PATH=/usr/local/redis/bin/:$PATH" >> /etc/profile
[root@localhost redis-2.6.14]# . /etc/profile
[root@localhost redis-2.6.14]# sysctl vm.overcommit_memory=1 #解决启动时内存不够问题
[root@localhost redis-2.6.14]# echo "sysctl vm.overcommit_memory=1" >> /etc/sysctl.conf
[root@localhost redis-2.6.14]# redis-server /usr/local/redis/conf/redis.conf & #指定配置文件启动
[1] 5409
.......
[5409] 19 Jun 21:09:02.779 * The server is now ready to accept connections on port 6379 回车
[root@localhost redis-2.6.14]# lsof -i :6379 #有端口
[root@localhost redis-2.6.14]# ps -ef |grep redis #有进程
注意: redis-cli shutdown 是停止服务 pkill redis-server是杀掉服务
在192.168.4.205上(搭建redis服务(从))
[root@localhost 桌面]# yum -y install gcc gcc-c++
[root@localhost 桌面]# tar -zxf redis-2.6.14.tar.gz
[root@localhost 桌面]# cd redis-2.6.14
[root@localhost redis-2.6.14]# make MALLOC=jemalloc
[root@localhost redis-2.6.14]# make PREFIX=/usr/local/redis install
[root@localhost redis-2.6.14]# mkdir /usr/local/redis/conf //优化目录结构
[root@localhost redis-2.6.14]# cp redis.conf /usr/local/redis/conf/ //配置其他功能可修改配置文件
[root@localhost redis-2.6.14]# echo "PATH=/usr/local/redis/bin/:$PATH" >> /etc/profile
[root@localhost redis-2.6.14]# . /etc/profile
[root@localhost redis-2.6.14]# sysctl vm.overcommit_memory=1
[root@localhost redis-2.6.14]# echo "sysctl vm.overcommit_memory=1" >> /etc/sysctl.conf
[root@localhost redis-2.6.14]# vim /usr/local/redis/conf/redis.conf
slaveof 192.168.4.5 6379 //修改,指定主的IP和端口
wq
[root@localhost redis-2.6.14]# redis-server /usr/local/redis/conf/redis.conf & #指定配置文件启动
上面提示中有:从库开始连主库,同步开始等提示。
[root@localhost redis-2.6.14]# lsof -i :6379 #有端口
在192.168.4.5上(在主库上写些数据)
[root@localhost redis-2.6.14]# redis-cli -h 192.168.4.5 -p 6379
redis localhost:6379> set name1 shi1
OK
redis localhost:6379> set name2 shi2
OK
redis localhost:6379> set name3 shi3
OK
redis localhost:6379> quit
在192.168.4.205上(在从库上查看数据也将主库的数据同步过来)
[root@localhost redis-2.6.14]# redis-cli -h 192.168.4.205 -p 6379
redis 192.168.4.5:6379> get name1
"shi1"
redis 192.168.4.5:6379> get name2
"shi2"
redis 192.168.4.5:6379> get name3
"shi3"
redis 192.168.4.5:6379> quit
在192.168.4.5上(在主库上删除一些数据)
[root@localhost redis-2.6.14]# redis-cli -h 192.168.4.5 -p 6379
redis localhost:6379> del name1
(integer) 1
redis localhost:6379> get name1
(nil)
redis localhost:6379> get name2
"shi2"
redis localhost:6379> get name3
"shi3"
redis localhost:6379> quit
在192.168.4.205上(在从库上查看数据也将主库的数据同步过来)
[root@localhost redis-2.6.14]# redis-cli -h 192.168.4.5 -p 6379
redis 192.168.4.5:6379> get name1
(nil)
redis 192.168.4.5:6379> get name2
"shi2"
redis 192.168.4.5:6379> get name3
"shi3"
redis 192.168.4.5:6379> quit
注意事项:redis可以设置密码,让客户端指定密码才能连接:客户端不指定密码,看似能连上,但用keys * 查不到数据
#vim ...redis.conf
requirepass Duyao001 #密码设置为Duyao001
此后客户端连接redis服务器时候,需要指定密码才能连接上,#redis-cli -h redis服务ip -p 端口号 -a Duyao001(密码)
4.redis的常用命令知识-补充(前锋python开发)
1)String:
概述:string是redis最基本的类型,最大能存储512M的数据,string类型是二进制安全的,即可以存储任何数据,比如数字、图片,序列化对象等。
设置:
A、设置键值 语法:set 键名 键值 如:set k1 v1
B、设置键值及过期时间(以秒为单位) 语法:setex 键名 秒数 键值 如:setex k1 9 v1
C、设置多个键值 语法:mset 键名1 键值1 键名2 键值2 如:mset k1 v1 k2 v2
获取:
A、根据键获取值,如果键不存在则返回null 语法:get 键名 如:get k1
B、根据多个键获取多个值 语法:mget 键名1 键名2 键名3 如:mget k1 k2 k3
运算:
要求:值时数字类型的字符串
A、将key对应的值加1 语法:incr 键名 如:incr age
B、将key对应的值减1 语法:decr 键名 如:decr age
C、将key对应的值加一个整数 语法:incrby 键名 整数数字 如:incrby age 3
D、将key对应的值减一个整数 语法:decrby 键名 整数数字 如:decrby age 3
其他:
A、追加值 语法:append 键名 键值 如:append age 4
B、获取键值长度 语法:strlen 键名 如:strlen age
2)key
查找键: 语法:keys 正则表达式 如:keys * 查找所有的键
判断键是否存在,如果存在返回1,不存在返回0 语法:exists 键名 如: exists age
查看键对应的value类型: 语法:type 键名 如:type name
删除键及对应的值: 语法:del 键名 如:del age
设置过期时间,以秒为单位 语法:expire 键名 秒数 如:expire age 5 #该键只存在5s
查看有效时间,以秒为单位 语法:ttl 键名 如:ttl age
3)hash
概述: hash用于存储对象
(1)设置
A、设置单个值: 语法:hset 大键名 小键名 小键值 如:hset k1 name tom ; hset k1 age 18;
B、设置多个值: 语法:hmset 大键名 小键名 小键值 如:hmset k2 name tom age 20
(2)获取
A、获取一个属性的值(获取大键名中小键名的值) 语法:hget 大键名 小键名 如:hget k1 name
B、获取多个属性的是(获取大键名中小键名的值) 语法:hmget 大键名 小键名1 小键名2 ... 如:hmget k1 name age
C、获取所有属性和值(获取大键名中所有小键名和值) 语法:hgetall 大键名 如:hgetall k1
D、获取所有的属性(获取大键名中所有小键名) 语法:hkeys 大键名 如:hkeys k1
E、获取所有值(获取大键名中所有小键名的值) 语法:hvals 大键名 如:hvals k1
F、返回包含数据的个数(获取大键名中所有小键名的个数) 语法:hlen 大键名 如:hlen k1
3、其他
A、判断属性是否存在,存在返回1,不存在返回0(判断大键名中小键名是否存在)
语法:hexists 大键名 小键名 如:hexists k1 name #判断k1里的name属性是否存在
B、删除属性及值
语法:hdel 大键名 小键名 如:hdel k1 name #删除k1里的name属性和值
4)list:
概述:列表的元素类型为string,按照插入顺序排序,在列表的头部或尾部添加元素。
1、设置
A、在头部插入(可插多个) 语法:lpush 键名 键值 如:lpush s1 1; lpush s1 2
B、在尾部插入(可插多个) 语法:rpush 键名 键值 如:rpush s1 3; rpush s1 4
C、在一个元素的前|后插入新元素:
语法:linsert 键名 before|after 基准元素数据 要插的值 如:linsert s1 before|after 1 4
D、设置指定索引的元素值
语法:lset 键名 索引下标 要设置成的值 ,如:lset s1 2 40 #将key为s1的下标为2的元素值设置为40
注意:index从0开始,索引值可以是负数,表示偏移量是从list的尾部开始,如:-1表示最后一个元素。
2、获取:
A、移除并返回key对应的list的第一个元素
语法:lpop 键名 如:lpop s1
B、移除并返回key对应的list的最后一个元素
语法:rpop 键名 如:rpop s1
C、返回存储在key的列表中的指定范围的元素(下标从开始到某个位置)
语法:lrange 键名 start end 如:lrange s1 2 5,若从头看到尾:lrange s1 0 -1
注意:start和end都是从0开始,偏移量可以是负数。
3、其他
A、裁剪列表,改为原集合的一个子集
语法:ltrim 键名 start end,如:ltrim s1 0 1 #只要从start到end之间的数据
注意:start和end都是从0开始,偏移量可以是负数。
B、返回存储在key里的list的长度
语法:llen 键名 如:llen s1
C、返回列表中索引对应的值
语法:lindex 键名 index 如:lindex s1 1
5)set:
概述:无序集合,元素类型为String类型,元素具有唯一性,不重复.
1、设置
A、添加元素
语法:sadd 键名 值1 值2 ... 如:sadd d1 1 2 3; sadd d2 2 3 4 5 6
2、获取
A、返回key集合中所有元素(获取所有键的值)
语法:smembers 键名 如:smembers d1
B、返回集合元素个数:
语法:scard 键名 如:scard d1
3、其他
A、求多个集合的交集,语法:sinter 键名1 键名2 如:sinter d1 d2
B、求多个集合的差集,语法:sdiff 键名1 键名2 如:sdiff d1 d2
C、求多个集合的合集,语法:sunion 键名1 键名2 如:sunion d1 d2
D、判断元素是否在集合中,存在返回1,不存在返回0
语法:sismember 键名 键值元素 如:sismember d1 2 #判断2这个元素是否存在于d1中
6)zset:
概述:
A、有序集合,元素类型为String,元素具有唯一性,不能重复。
B、每个元素都会关联一个double类型的score(表示权重),通过权重的大小排序,元素的score可以相同。
1、设置:
A、添加:
语法:zadd 键名 值1的权重值 值1 值2的权重值 值2 ... 如:zadd z1 1 a 5 b 3 c
2、获取:
A、返回指定范围的元素
语法:zrange 键名 start end 如:zrange z1 0 -1,获取z1中所有元素
B、返回元素个数
语法:zcard 键名 如: zcard z1,获取z1中的元素个数
C、返回有序集合key中,score(权重)在min和max之间的元素的个数
语法:zcount 键名 start end 如:zcount z1 2 4 ,获取z1中索引2-4之间的元素个数
D、返回有序集合key中,成员member的score(权重)值
语法:zscore 键名 元素值 如:zscore z1 c,获取z1中元素c的权重值
如果对运维课程感兴趣,可以在b站上搜索我的账号: 运维实战课程,可以关注我,学习更多免费的运维实战技术视频