当前位置: 首页 > news >正文

Redis配置

关系型数据库和非关系型数据库

①了解关系和非关系

关系型数据库
  • 一个结构化的数据库,创建在关系模型基础上,一般面向于记录,包括Oracle、MySQL、SQL Server、Microsoft Access、DB2、postgreSQL等

非关系型数据库
  • 除了主流的关系型数据库外的数据库,都认为是非关系型,包括 Redis、MongBD、Hbase、 CouhDB等

②区别

  • 数据存储方式不同:

  • 扩展方式不同:

  • 对事务性的支持不同

关系型:

        安全性高,能做持久化,事务处理能力强,任务控制能力强,可以做日志备份、恢复、容灾的能力更强

        实例——>数据库——>表(table)——>记录行(row)\数据字段(column)——>存储数据

非关系型:

         数据保存在缓存中,利于读取速度/查询数据,架构中位置灵活,分布式、扩展性高

         实例——>数据库——>集合——>键值对

         非关系型数据库不需要手动建数据库和集合(表)

非关系型数据库产生背景

  • High performance—对数据库高并发读写需求

  • HugeStorage—对海量数据高效存储与访问需求High

  • Scalability && High Availability—对数据库高可扩展性与高可用性需求

了解Redis

           Redis是一个非关系型数据库,是一个开源的,基于在内存上运行并且支持持久化,采用键值对(key-value),分布式架构集群

Redis的优点

  1. 具有极高的数据读写速度

  2. 支持丰富的数据类型

  3. 支持数据的持久化

  4. 操作方式原子性

  5. 支持数据备份

为什么这么快?
  1. Redis是一款纯内存结构,避免了磁盘I/o等耗时操作

  2. Redis命令处理的核心模块为单线程

  3. 采用了i /o 多路复用机制,大大提升了并发效率

部署安装Redis(配置文件说明)

配置文件路径: /etc/6379.conf

日志文件:redis_6379.log

数据文件:date 6379路径下

执行文件:redis_server

客户端命令工具:redis_cli

reids安装部署

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表示不存在

del(delete):删除当前数据库的指定 key:

type:获取 key 对应的 value 值类型       string表示字符串

rename:对已有的key进行重命名
     格式:rename  源key 目标key  
    使用rename命令进行重命名时,无论目标key是否存在都进行重命名,且源key的值会覆盖目标key的值。在实际使用过程中,建议先用 exists 命令查看目标 key 是否存在,然后再决定是否执行 rename 命令,以避免覆盖重要数据

renamenx: 对已有 key 进行重命名,如果目标 key 存在则不进行重命名(不覆盖)

dbsize:查看当前数据库中 key 的数目

move:移动   
select:切换数据库 【连接 Redis 数据库后,默认使用的是序号为 0 的数据库】

将k3移动至数据库1中,切换到数据库1进行查看 

flushdb:清空当前数据库数据


 

flushall:清空所有数据库的数据【慎用!】

redis-benchmark 测试工具

         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

http://www.lryc.cn/news/162900.html

相关文章:

  • CSDN每日一练 |『小艺照镜子』『Ctrl+X,Ctrl+V』『括号上色』2023-09-11
  • React 全栈体系(四)
  • 各种UI库使用总结
  • 2023Web前端开发面试手册
  • 一文了解数据科学Notebook
  • 2020年12月 C/C++(二级)真题解析#中国电子学会#全国青少年软件编程等级考试
  • 关于ChatGPT的个人的一些观点
  • Solidity 小白教程:13. 继承
  • 队列(Queue)的顶级理解
  • 选择 Guava EventBus 还是 Spring Framework ApplicationEvent
  • Linux下go环境安装、环境配置并执行第一个go程序
  • 自定义Dynamics 365实施和发布业务解决方案 - 5. 高级自定义
  • 软件测试下的AI之路(2)
  • 前端面试的话术集锦第 7 篇:高频考点(浏览器渲染原理 安全防范)
  • 打印剪刀手“耶”(V形)
  • eNSP基本命令大全
  • java并发编程 ConcurrentLinkedQueue详解
  • msvcp110.dll是什么意思与msvcp110.dll丢失的解决方法
  • 八)Stable Diffussion使用教程:MultiDiffusion
  • java通过钉钉机器人发消息
  • Git工具本地管理总结
  • 单片机C语言实例:13、看门狗
  • 时序分解 | MATLAB实现基于SSA奇异谱分析的信号分解分量可视化
  • mysql报错:Duplicate entry ‘...‘ for key ‘field‘
  • 什么是回流跟重绘?从中怎么优化网页性能?
  • Redis事务机制
  • [EROOR] SpringMVC之500 回调函数报错
  • [Linux]文件系统
  • 常见面试题记录
  • Android 系统源码目录frameworks/base/packages和packages/apps下的APP区别