玖叶教程网

前端编程开发入门

redis缓存服务重点简单总结

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站上搜索我的账号: 运维实战课程,可以关注我,学习更多免费的运维实战技术视频

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言