一个结构化的数据库,创建在关系模型基础上,一般面向于记录,包括Oracle、MySQL、SQL Server、Microsoft Access、DB2、postgreSQL等
除了主流的关系型数据库外的数据库,都认为是非关系型,包括 Redis、MongBD、Hbase、 CouhDB等
数据存储方式不同:
扩展方式不同:
对事务性的支持不同
安全性高,能做持久化,事务处理能力强,任务控制能力强,可以做日志备份、恢复、容灾的能力更强
实例——>数据库——>表(table)——>记录行(row)\数据字段(column)——>存储数据
数据保存在缓存中,利于读取速度/查询数据,架构中位置灵活,分布式、扩展性高
实例——>数据库——>集合——>键值对
非关系型数据库不需要手动建数据库和集合(表)
High performance—对数据库高并发读写需求
HugeStorage—对海量数据高效存储与访问需求High
Scalability && High Availability—对数据库高可扩展性与高可用性需求
Redis是一个非关系型数据库,是一个开源的,基于在内存上运行并且支持持久化,采用键值对(key-value),分布式架构集群
具有极高的数据读写速度
支持丰富的数据类型
支持数据的持久化
操作方式原子性
支持数据备份
Redis是一款纯内存结构,避免了磁盘I/o等耗时操作
Redis命令处理的核心模块为单线程
采用了i /o 多路复用机制,大大提升了并发效率
配置文件路径: /etc/6379.conf
日志文件:redis_6379.log
数据文件:date 6379路径下
执行文件:redis_server
客户端命令工具:redis_cli
- systemctl stop firewalld
- setenforce 0
- yum install -y gcc gcc-c++ make #安装依赖环境
- tar zxvf redis-5.0.7.tar.gz -C /opt/
- cd /opt/redis-5.0.7/
- make
- make PREFIX=/usr/local/redis install
- #执行软件包提供的 install_server.sh 脚本文件设置 Redis 服务所需要的相关配置文件
- cd /opt/redis-5.0.7/utils
- ./install_server.sh
- ...... #一直回车
- Please select the redis executable path [/usr/local/bin/redis-server] /usr/local/redis/bin/redis-server #需要手动修改为 /usr/local/redis/bin/redis-server ,注意要一次性正确输入
- #把redis的可执行程序文件放入路径环境变量的目录中便于系统识别
- ln -s /usr/local/redis/bin/* /usr/local/bin/
- #当 install_server.sh 脚本运行完毕,Redis 服务就已经启动,默认监听端口为 6379
- netstat -natp | grep redis
- #修改配置 /etc/redis/6379.conf 参数
- vim /etc/redis/6379.conf
- bind 192.168.86.11 #70行,修改 监听的主机地址
- /etc/init.d/redis_6379 restart #重启redis服务
-
- #Redis 服务控制
- /etc/init.d/redis_6379 stop #停止
- /etc/init.d/redis_6379 start #启动
- /etc/init.d/redis_6379 restart #重启
- /etc/init.d/redis_6379 status #状态
- 命令: redis-cli -h host p port #进入数据库
- 例:redis-cli -h 192.168.86.11 -p 6379
- -h: 指定远程主机
- -p :指定 Redis 服务的端口号
set:存放数据,命令格式为 set key value
get:获取数据,命令格式为 get key
keys * :查看所有的key
keys 字符* :查看所有以某字符开头的key
?:表示单个字符
keys 字符? 表示查询某字符开头的后面跟着单个字符的key
exists:判断键是否存在: 1表示已存在 0表示不存在
rename:对已有的key进行重命名
格式:rename 源key 目标key
使用rename命令进行重命名时,无论目标key是否存在都进行重命名,且源key的值会覆盖目标key的值。在实际使用过程中,建议先用 exists 命令查看目标 key 是否存在,然后再决定是否执行 rename 命令,以避免覆盖重要数据
将k3移动至数据库1中,切换到数据库1进行查看
flushdb:清空当前数据库数据
flushall:清空所有数据库的数据【慎用!】
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 :通过管道传输<numreq>请求
- --csv:以csv格式输出
- -l:生成循环,永久执行测试
- -t:仅运行以逗号分割的测试命令列表
- -I :Idle 模式。仅打开 N 个 idle 连接并等待
-
- 例:
- 向 IP 地址为 192.168.86.11、端口为 6379 的 Redis 服务器发送 100 个并发连接与 100000 个请求测试性能
- redis-benchmark -h 192.168.86.11 -p 6379 -c 100 -n 100000
-
- 测试存取大小为 100 字节的数据包的性能
- redis-benchmark -h 192.168.86.11 -p 6379 -q -d 100
-
- 测试本机上 Redis 服务在进行 set 与 lpush 操作时的性能
- redis-benchmark -t set,lpush -n 100000 -q