redis基础管理

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介:
                  #NoSQL -> Not Only SQL

                                                                                                                                                #REmote Dictionary Server

                                                                                                                                                #tui: text user interface 文本用户界面
                                                                                                                                                #gui: graphical user interface图形用户界面
                                                                                                                                                #cli: command line interface命令行接口

一、redis基础管理
1、安装
[root@vh01 lnmp_soft]# tar xzf redis-3.0.6.tar.gz 
[root@vh01 lnmp_soft]# cd redis-3.0.6/
[root@vh01 redis-3.0.6]# make && make install
2、初始化
[root@vh01 redis-3.0.6]# ./utils/install_server.sh 
提示的问题全部回车,但是要观察各种文件存放的路径
3、服务管理
[root@vh01 ~]# service redis_6379 status 查看状态
[root@vh01 ~]# service redis_6379 stop
[root@vh01 ~]# service redis_6379 start
4、服务器基础测试
[root@vh01 ~]# redis-cli 
127.0.0.1:6379> ping
PONG
127.0.0.1:6379> set username songtao
OK
127.0.0.1:6379> get username
"songtao"
127.0.0.1:6379> set counter 10
OK
127.0.0.1:6379> INCR counter
(integer) 11
127.0.0.1:6379> GET counter
"11"
5、操作字符串
127.0.0.1:6379> set first 'hello world'
OK
127.0.0.1:6379> get first
"hello world"
127.0.0.1:6379> SETRANGE first 6 'tedu.cn'
(integer) 13
127.0.0.1:6379> get first
"hello tedu.cn"
127.0.0.1:6379> APPEND username "sudan" 向变量中追加
127.0.0.1:6379> SETBIT mytest 0 1
(integer) 0
127.0.0.1:6379> SETBIT mytest 1 0
(integer) 0
127.0.0.1:6379> get mytest
127.0.0.1:6379> SETBIT peter 100 1 设置2进制的第100位为1
(integer) 0
127.0.0.1:6379> SETBIT peter 105 1 设置2进制的第105位为1
(integer) 0
127.0.0.1:6379> BITCOUNT peter 统计peter设置为1的位数有多少
(integer) 2
127.0.0.1:6379> set num1 100 相当于是num1=100
OK
127.0.0.1:6379> get num1
"100"
127.0.0.1:6379> INCR num1 相当于是num1++
(integer) 101
127.0.0.1:6379> DECR num1 相当于是num1--
(integer) 100
127.0.0.1:6379> DECRBY num1 10 # num1=num1-10
127.0.0.1:6379> INCRBY num1 10 # num1=num1+10

127.0.0.1:6379> set hi "hello world"
127.0.0.1:6379> STRLEN hi
127.0.0.1:6379> GETRANGE hi 6 -1
127.0.0.1:6379> GETRANGE hi 6 10

127.0.0.1:6379> set num2 10.5
OK
127.0.0.1:6379> INCRBYFLOAT num2 0.3
"10.8"
127.0.0.1:6379> INCRBYFLOAT num2 -0.8
"10"
127.0.0.1:6379> MGET num1 num2
127.0.0.1:6379> MSET a 10 b "abc"
OK
127.0.0.1:6379> get a
"10,"
127.0.0.1:6379> get b
"abc"

哈希表类型数据
127.0.0.1:6379> hset site google "www.google.com"
(integer) 1
127.0.0.1:6379> hset site baidu "www.baidu.com"
(integer) 1
127.0.0.1:6379> HGET site google
"www.google.com"
127.0.0.1:6379> hget site baidu
"www.baidu.com"

127.0.0.1:6379> hmset site2 tedu "www.tedu.cn" tarena "www.tarena.com"
127.0.0.1:6379> hmget site2 tedu tarena
127.0.0.1:6379> HKEYS site 查看key中存在的value
127.0.0.1:6379> HKEYS site2
127.0.0.1:6379> HGETALL site 返回field和value
127.0.0.1:6379> HVALS site 返回site中所有的value
127.0.0.1:6379> HDEL site google 从site中删除google

列表
127.0.0.1:6379> LPUSH mylist chenshun chenglijun yegutian
127.0.0.1:6379> LRANGE mylist 0 -1
127.0.0.1:6379> LPUSH mylist mayang
127.0.0.1:6379> LRANGE mylist 0 -1
127.0.0.1:6379> help @<tab> #<tab>表示按tab键
127.0.0.1:6379> help @list
127.0.0.1:6379> RPUSH mylist wanghongli
127.0.0.1:6379> LRANGE mylist 0 -1
127.0.0.1:6379> LSET mylist 2 chenyuan

127.0.0.1:6379> LLEN mylist
127.0.0.1:6379> LPOP mylist
127.0.0.1:6379> RPOP mylist
127.0.0.1:6379> LINDEX mylist 1

127.0.0.1:6379> get username
127.0.0.1:6379> ttl username # 查看生存周期
127.0.0.1:6379> PERSIST username # 设置永不过期
127.0.0.1:6379> EXPIRE username 30 # 生存时间为30秒
127.0.0.1:6379> del mylist # 删除mylist

127.0.0.1:6379> keys # 查看所有的key
127.0.0.1:6379> set hello 10
OK
127.0.0.1:6379> set hllo 20
OK
127.0.0.1:6379> set habllo 30
OK
127.0.0.1:6379> set hfllo 40
OK
127.0.0.1:6379> KEYS h?llo # ?匹配任意一个字符
127.0.0.1:6379> KEYS h
llo # *匹配0到多个任意思字符
127.0.0.1:6379> KEYS h[a-z]llo # []匹配1个字符
127.0.0.1:6379> set h1llo 5
127.0.0.1:6379> KEYS h[a-z0-9]llo
127.0.0.1:6379> KEYS h[ade0-9]llo

127.0.0.1:6379> KEYS 
127.0.0.1:6379> FLUSHALL 清空所有数据
127.0.0.1:6379> KEYS 

127.0.0.1:6379> set username zhangsan
127.0.0.1:6379> get username
"zhangsan"
127.0.0.1:6379> select 1
127.0.0.1:6379[1]> get username
(nil)
127.0.0.1:6379[1]> select 0
127.0.0.1:6379> get username
"zhangsan"
127.0.0.1:6379> select 0
127.0.0.1:6379> MOVE username 1
(integer) 1
127.0.0.1:6379> get username
(nil)
127.0.0.1:6379> select 1
OK
127.0.0.1:6379[1]> get username
"zhangsan"
127.0.0.1:6379[1]>

127.0.0.1:6379[1]> keys 
1) "username"
127.0.0.1:6379[1]> RENAME username name # 改名
OK
127.0.0.1:6379[1]> keys 

1) "name"
127.0.0.1:6379[1]> get name
"zhangsan"

127.0.0.1:6379[1]> lpush mylist 10 2 38 69 42
127.0.0.1:6379[1]> SORT mylist # 不会改变mylist
127.0.0.1:6379[1]> LRANGE mylist 0 -1
127.0.0.1:6379[1]> sort mylist desc # 降序

127.0.0.1:6379[1]> lpush names zhangsan lisi bob alice
127.0.0.1:6379[1]> sort names alpha #按字母顺序排序
按字母顺序排序,从下标为1的单词开始,取出2项
127.0.0.1:6379[1]> SORT names alpha limit 1 2
127.0.0.1:6379[1]> SORT names alpha limit 1 2 desc
将mylist排序后,另存为mylist2
127.0.0.1:6379[1]> sort mylist store mylist2
127.0.0.1:6379[1]> LRANGE mylist2 0 -1

配置redis主从
1、主服务器使用现有的redis
2、从服务器
[root@vh02 lnmp_soft]# yum install -y gcc gcc-c++
[root@vh02 lnmp_soft]# tar xzf redis-3.0.6.tar.gz 
[root@vh02 lnmp_soft]# cd redis-3.0.6/
[root@vh02 redis-3.0.6]# make && make install
[root@vh02 redis-3.0.6]# ./utils/install_server.sh 
3、主服务器设置同步密码
[root@vh01 ~]# vim /etc/redis/6379.conf 
requirepass redis123
[root@vh01 ~]# service redis_6379 restart 或
[root@vh01 ~]# /etc/init.d/redis_6379 restart
4、设置关闭服务的认证密码
[root@vh01 ~]# vim /etc/init.d/redis_6379 
$CLIEXEC -a redis123 -p $REDISPORT shutdown
[root@vh01 ~]# service redis_6379 restart
5、配置从属服务器
[root@vh02 ~]# vim /etc/redis/6379.conf 
slaveof 192.168.4.1 6379
masterauth redis123
[root@vh02 ~]# service redis_6379 restart
6、验证
[root@vh02 ~]# redis-cli 
[root@vh01 ~]# redis-cli -h 192.168.4.1 -a redis123
192.168.4.1:6379> set aaa 100
[root@vh02 ~]# redis-cli 
127.0.0.1:6379> keys *
127.0.0.1:6379> get aaa










本文转自 英强云计算 51CTO博客,原文链接:http://blog.51cto.com/13404755/2051844,如需转载请自行联系原作者
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
8月前
|
存储 缓存 NoSQL
深入了解Redis键管理:探索Redis键命令及其功能与应用场景
深入了解Redis键管理:探索Redis键命令及其功能与应用场景
|
NoSQL 关系型数据库 Go
更新Navicat Premium 16.2 之 如何使用Navicat连接Redis的新手教程《更新Navicat Premium 16.2并连接Redis:高效管理数据库和键值存储》
更新Navicat Premium 16.2 之 如何使用Navicat连接Redis的新手教程《更新Navicat Premium 16.2并连接Redis:高效管理数据库和键值存储》
843 0
更新Navicat Premium 16.2 之 如何使用Navicat连接Redis的新手教程《更新Navicat Premium 16.2并连接Redis:高效管理数据库和键值存储》
|
6月前
|
存储 NoSQL 数据管理
如何借助Redis巧妙的管理用户签到?——Bitmap篇
Redis位操作用于高效存储分析,如用户签到。通过位操作,每个用户签到只需1位,节省空间。使用`setbit`设置签到状态,`getbit`查询,`bitcount`统计签到天数。适用于用户特征标记、系统功能开关和在线状态追踪。高效率、低空间占用,适合大数据场景。
102 0
|
8月前
|
消息中间件 缓存 NoSQL
利用Redis实现高效缓存管理与加速
本文将探讨如何利用Redis作为缓存管理工具,通过深入分析Redis的特性、使用场景和优势,帮助开发人员更好地理解和应用Redis来提升系统性能和响应速度。
|
8月前
|
消息中间件 存储 NoSQL
【Redis项目实战】使用Springcloud整合Redis分布式锁+RabbitMQ技术实现高并发预约管理处理系统
【Redis项目实战】使用Springcloud整合Redis分布式锁+RabbitMQ技术实现高并发预约管理处理系统
|
8月前
|
存储 NoSQL 算法
Redis 的数据库和键管理
Redis 是一个键值对(key-value pair)的数据库服务器,其数据保存在 src/server.h/redisDb 中(网上很多帖子说在 redis.h 文件中,但是 redis 6.x版本目录中都没有这个文件。redisDb 结构应该在 server.h文件中)
109 0
Redis 的数据库和键管理
|
8月前
|
存储 监控 NoSQL
Redis 大键问题解析:如何管理和优化巨型数据【redis拓展】
Redis 大键问题解析:如何管理和优化巨型数据【redis拓展】
292 0
|
消息中间件 缓存 NoSQL
阿里云国际站代理商:Redis实现分布式配置管理的方法与应用案例
@luotuoemo飞机@TG阿里云国际站代理商:Redis实现分布式配置管理的方法与应用案例,为了实现高可用和负载均衡,可以将Redis部署成哨兵集群或集群模式。哨兵负责监控主从节点的状态,发现故障时自动进行故障转移。集群模式可以提高系统的可扩展性,通过添加更多的从节点来分摊负载压力。
|
缓存 NoSQL 前端开发
【Go】基于 Gin 从0到1搭建 Web 管理后台系统后端服务(三)路由、自定义校验器和 Redis
【Go】基于 Gin 从0到1搭建 Web 管理后台系统后端服务(三)路由、自定义校验器和 Redis
|
NoSQL Redis
Redis - CLUSTER命令中槽管理命令详解
Redis - CLUSTER命令中槽管理命令详解
76 0