redis缓存服务重点简单总结

redis缓存服务重点简单总结

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                    #默认端口号,也可修改为其他,若改为其他,则客户端登录时需指定端口号

注意事项2redis可以设置密码,让客户端指定密码才能连接:客户端不指定密码,看似能连上,但用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的权重值

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

运维实战课程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值