目录
一、关系数据库与非关系型数据库概述
1、关系型数据库
2、非关系型数据库
3、关系数据库与非关系型数据库区别
①、数据存储方式不同
②、扩展方式不同
③、对事务性的支持不同
4、非关系型数据库产生背景
二、Redis简介
1、Redis的单线程模式
2、Redis的优点
Redis 缺点:
三、redis安装、部署
下载安装包
编辑 解压tar zxvf redis-5.0.7.tar.gz
关防火墙和增强,下载依赖环境
再在配置文件/etc/redis/6379.conf中修改监听地址
重启redis服务 查看端口
四、Redis 命令工具
1、redis-benchmark 测试工具
五、Redis 数据库常用命令
六、Redis 多数据库常用命令
七,Redis性能管理
1、查看内存使用
2、清理内存碎片
①、内存碎片如何产生
②、内存碎片率
③、清理内存碎片
3、内存使用率
4、内回收key
优点:
缺点:
NoSQL(NoSQL = Not Only SQL ),意思是“不仅仅是 SQL”,是非关系型数据库的总称。
除了主流的关系型数据库外的数据库,都认为是非关系型。
主流的 NoSQL 数据库有 Redis、MongBD、Hbase、Memcached 等。
可用于应对web2.0纯动态网站类型的三高问题
关系型数据库和非关系型数据库都有各自的特点与应用场景,两者的紧密结合将会给Web2.0的数据库发展带来新的思路。让关系数据库关注在关系上,非关系型数据库关注在存储上。例如,在读写分离的MySQL数据库环境中,可以把经常访问的数据存储在非关系型数据库中,提升访问速度。
数据容量收到物理内存的限制,不能用于海量数据的高性能读写,因此Redis适合的场景主要局限在较小数据量的高性能操作和运算上
cd /opt/redis-5.0.7/
make
make PREFIX=/usr/local/redis install #指定安装位置
#由于Redis源码包中直接提供了makefile文件,所以在解压完软件后,不用先执行 ./configure 进行配置,可直接执行make与make install命令进行安装
#执行软件包中提供的 install_server.sh 脚本文件设置Redis服务所需要的相关配置文件
cd /opt/redis-5.0.7/utils
./install_server.sh
#一直回车,出现C下面
Please select the redis executable path [/usr/local/bin/redis-server]
/usr/local/redis/bin/redis-server
#需要手动修改为/usr/local/redis/bin/redis-server
----------------------------------------------------------------------------
Selected config:
Port : 6379 #默认监听端口6379
Config file : /etc/redis/6379.conf #配置文件路径
Log file : /var/log/redis_6379.log #日志文件路径
Data dir : /var/lib/redis/6379 #数据文件路径
Executable : /usr/local/redis/bin/redis-server #可执行文件路径
Cli Executable : /usr/local/redis/bin/redis-cli #客户端命令工具
-----------------------------------------------------------------------------
-----------------------------------
#把redis的可执行程序文件放入路径环境变量的目录中
ln -s /usr/local/redis/bin/* /usr/local/bin/
/etc/init.d/redis_6379 stop #停止
/etc/init.d/redis_6379 start #启动
/etc/init.d/redis_6379 restart #重启
/etc/init.d/redis_6379 status #状态
修改配置 /etc/redis/6379.conf 参数
vim /etc/redis/6379.conf
bind 127.0.0.1 192.168.184.10 #70行,添加监听的主机地址
port 6379 #93行,Redis默认的监听端口
daemonize yes #137行,启用守护进程
pidfile /var/run/redis_6379.pid #159行,指定 PID 文件
loglevel notice #167行,日志级别
logfile /var/log/redis_6379.log #172行,指定日志文件
/etc/init.d/redis_6379 restart
netstat -natp | grep redis
redis-server #用于启动 Redis 的工具
redis-cli #Redis命令行工具
redis-benchmark #用于检测 Redis 在本机的运行效率
redis-check-aof #修复 AOF 持久化文件
redis-check-rdb #修复 RDB 持久化文件
1、redis-cli 命令行工具
redis-cli -h host -p port -a password
-h 指定远程主机
-p 指定 Redis 服务的端口号
-a 指定密码,未设置数据库密码可以省略-a 选项
若不添加任何选项表示,则使用127.0.0.1:6379连接本机上的Redis数据库
redis-benchmark 是官方自带的 Redis 性能测试工具,可以有效的测试 Redis 服务的性能
redis-benchmark [选项] [选项值]
-h 指定服务器主机名。
-p 指定服务器端口。
-s 指定服务器 socket
-c 指定并发连接数。
-n 指定请求数。
-d 以字节的形式指定 SET/GET 值的数据大小。
-k 1=keep alive 0=reconnect 。
-r SET/GET/INCR 使用随机 key, SADD 使用随机值。
-P 通过管道传输请求。
-q 强制退出 redis。仅显示 query/sec 值。
–csv 以 CSV 格式输出。
-l 生成循环,永久执行测试。
-t 仅运行以逗号分隔的测试命令列表。
-I Idle 模式。仅打开 N 个 idle 连接并等待。
例:
向 IP 地址为 192.168.184.10、端口为 6379 的 Redis 服务器发送 100 个并发连接与 10 万个请求测试性能
redis-benchmark -h 192.168.184.10 -p 6379 -c 100 -n 100000
测试存取大小为 100 字节的数据包的性能
redis-benchmark -h 192.168.184.10 -p 6379 -q -d 100
测试本机上 Redis 服务在进行 set 与 lpush 操作时的性能
redis-benchmark -t set,lpush -n 100000 -q
set:存放数据,命令格式为 set key value
get:获取数据,命令格式为 get key
#keys 命令可以取符合规则的键值列表,通常情况可以结合*、?等选项来使用。
keys * #查看当前数据库中所有的数据
keys v* #查看当前数据库中以v开头的数据
keys v? #查看当前数据库中以v开头后面包含任意一位的数据
keys v?? #查看当前数据库中以v开头后面包含任意两位的数据
exists 命令可以判断键值是否存在。
exists [键]
返回值为1表示存在,0表示不存在
del 命令可以删除当前数据库的指定 key。
del [键]
type 命令可以获取 key 对应的 value 值类型。
type [键]
rename 命令是对已有 key 进行重命名。(覆盖)
rename 源key 目标key
使用rename命令进行重命名时,无论目标key是否存在都进行重命名,且源key的值会覆盖目标key的值。在实际使用过程中,建议先用 exists 命令查看目标 key 是否存在,然后再决定是否执行 rename 命令,以避免覆盖重要数据
renamenx 命令是对已有 key 进行重命名,并检测新名是否存在,如果目标 key 存在则不进行重命名。(不覆盖)
renamenx 源key 目标key
dbsize 命令的作用是查看当前数据库中 key 的数目。
设置密码
config set requirepass password
查看密码(一旦设置密码,必须先验证通过密码,否则所有操作不可用)
auth 密码
config get requirepass
#删除密码
auth 密码
config set requirepass ''
切换数据库
SELECT 库号
将数据移动到指定库
MOVE 键 库号
info memory
mem fragmentation _ratio #内存碎片率 = used memory_rss / used memoryused
memory _rss #是Redis向操作系统申请的内存。
used memory #是Redis中的数据占用的内存。
used memory peak # redis内存使用的峰值。
跟踪内存碎片率对理解Redis实例的资源性能是非常重要的
Redis版本4.0以下
需要在 redis-cli工具上输入shutdown save 命令,让Redis数据库执行保存操作并关闭Redis服务,再重启服务器。Redis服务器重启后,Redis会将没用的内存归还给操作系统,碎片率会降下来。
Redis4.0版本以上
执行 config set activedefrag yes,开启自动碎片清理;
执行 memory purge,手动碎片清理
redis实例的内存使用率超过可用最大内存,操作系统将开始进行内存与swap空间交换,导致性能大大降低。
避免内存交换发生的方法
内存清理策略,保证合理分配redis有限的内存资源。默认情况下回收策略是禁止删除,当达到设置的最大阀值时,需选择一种key的回收策略。
配置文件中修改maxmemory-policy属性值
|
|
||
---|---|---|---|
|
|
||
|
|
||
|
|
||
|
|
||
|
|