Redis配置

news2024/11/24 4:50:18

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

①了解关系和非关系

关系型数据库
  • 一个结构化的数据库,创建在关系模型基础上,一般面向于记录,包括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.coloradmin.cn/o/994116.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

java 歌词解析 源代码, 在windows10下调试运行成功。

需要两个素材。 歌词与音乐.wav package week3.exam6;public class Info {private final String info;public Info(String info){this.infoinfo;}public String getInfo() {return info;}public String toString(){return info;} }package week3.exam6;public class Lyric ext…

华为云新用户云服务器优惠价格表

华为云服务器作为业界领先的云服务提供商之一&#xff0c;一直致力于为全球用户提供高效、稳定、安全的云服务。为了帮助新用户更好地了解华为云服务器的价格和优惠活动&#xff0c;本文将详细介绍华为云服务器对新用户的优惠价格表。 一、华为云耀云服务器L实例价格表 华为云…

JavaScript基础知识09——数据类型

哈喽&#xff0c;大家好啊&#xff0c;这里是雷工笔记&#xff0c;我是雷工。 数据类型比较常见&#xff0c;无论是对程序员&#xff0c;还是电气工程师来说&#xff0c;都再熟悉不过了&#xff0c;这里跟着教程了解一下&#xff0c;主要看跟自己以往在其他PLC&#xff0c;C#&a…

2023-09-09 LeetCode每日一题(课程表)

2023-09-09每日一题 一、题目编号 207. 课程表二、题目链接 点击跳转到题目位置 三、题目描述 你这个学期必须选修 numCourses 门课程&#xff0c;记为 0 到 numCourses - 1 。 在选修某些课程之前需要一些先修课程。 先修课程按数组 prerequisites 给出&#xff0c;其中…

【牛客面试必刷TOP101】Day2.判断链表中是否有环和链表中倒数最后k个结点

作者简介&#xff1a;大家好&#xff0c;我是未央&#xff1b; 博客首页&#xff1a;未央.303 系列专栏&#xff1a;笔试强训选择题 每日一句&#xff1a;人的一生&#xff0c;可以有所作为的时机只有一次&#xff0c;那就是现在&#xff01;&#xff01;&#xff01;&#xff…

python-jieba库

jieba库&#xff0c;python提供的中文分词函数库的第三方库&#xff0c;它可以将一段中文文本分割成中文词语序列。 安装jieba库 pip install jiebajieba的三个模式 全模式 - - - jieba.lcut(s,cut_allTrue) - - - 速度非常快&#xff0c;但有冗余数据 精确模式&#xff08;…

窗口延时、侧输出流数据处理

一 、 AllowedLateness API 延时关闭窗口 AllowedLateness 方法需要基于 WindowedStream 调用。AllowedLateness 需要设置一个延时时间&#xff0c;注意这个时间决定了窗口真正关闭的时间&#xff0c;而且是加上WaterMark的时间&#xff0c;例如 WaterMark的延时时间为2s&…

嵌入式开发-绪论

目录 一.什么是嵌入式 1.1硬件系统 1.2软件系统 二.嵌入式应用场景 2.1消费电子 2.1.1智能家居 2.1.2影音 2.1.3家用电器 2.1.4玩具游戏机 2.2通信领域 2.2.1对讲机 2.2.2手机 2.2.3卫星 2.2.4雷达 2.3控制领域 2.3.1机器人 2.3.2采集器PLC 2.4金融 2.4.1POS…

快速文件复制与删除工具,将复制时文件夹里的原文件删除掉

无论是工作还是生活&#xff0c;我们都离不开文件的复制和管理。然而&#xff0c;手动复制文件不仅费时费力&#xff0c;而且容易出错。现在&#xff0c;我们为您推荐一款快速文件复制与删除工具&#xff0c;让您的文件管理更加高效&#xff01; 首先&#xff0c;我们要进入文…

MybatisPlus分页插件使用

一. 效果展示 二. 代码编写 2.1 pom <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.2</version> </dependency>2.2 添加配置类 Configuration MapperScan(…

推荐一款程序员截图神器!

快来看一下程序员必备的一款截图工具 今天就来和大家说一下作为程序员必备截图神器&#xff0c;几乎每一个程序员都会设置开机自启&#xff0c;因为这个截图功能太太太好用了&#xff01;&#xff01;&#xff01;只要你在键盘上按下F1就可以轻松截取整个屏幕&#xff0c;然后…

51单片机项目(9)——基于51单片机的电子琴设计

简易电子琴设计设计内容: 1.用矩阵键盘代表琴键&#xff0c;至少能弹出8个音符&#xff0c;分别是:音符1.23.4.,5,6, 2.键按下的时间长短表征节拍的长短&#xff0c;用蜂鸣器发出声音 3.数码管显示出当前音符 4.音量可调 &#xff08;代码及其工程文件放在最后&#xff09; …

vue中的几种name属性

vue中的几种name属性 组件名name name选项 export default{name:xxx } // 获取组件的name属性 this.$options.namevue-devtools调试工具里显示的组件名称&#xff1b; 未配置name选项&#xff0c;就是组件的文件名&#xff1b; vue3配置name通过defineOptions()函数 de…

msvcp110.dll是什么意思与msvcp110.dll丢失的解决方法

电脑突然提示msvcp110.dll丢失&#xff0c;无法执行此代码。导致软件无法打开运行&#xff0c;这个怎么办呢&#xff1f;我在网上找了一天的资料&#xff0c;终于把这个问题彻底处理好&#xff0c;也弄清楚了msvcp110.dll丢失的原因及msvcp110.dll丢失修复方法&#xff1f;现在…

20230909java面经整理

1.java常用集合 ArrayList动态数组&#xff0c;动态调整大小&#xff0c;实现List接口 LinkedList双向链表&#xff0c;实现list和queue接口&#xff0c;适用于频繁插入和删除操作 HashSet无序&#xff0c;使用哈希表实现 TreeSet有序&#xff0c;使用红黑树实现 HashMap无序&…

FPGA开发

https://www.enclustra.com.cn/?bd_vid11435475462206745180 https://www.monolithicpower.cn/design-tools/design-tools/llc-design-tool.html https://www.elecfans.com/article/88/143/2012/20120718280641_2.html

[JAVAee]IP数据包的组包与分包

目录 数据包是什么? 数据包的结构 数据包/分组与分组交换 分包是什么?为什么需要分包呢? 组包是什么? 分包组包过程中和哪些 IP 报头字段有关联? 本篇文章主要围绕三个问题来展开: 为什么要分包?分包组包过程中和哪些 IP 报头字段有关联组包时如何保证数据的顺序和…

基于Yolov8的中国交通标志(CCTSDB)识别检测系统

目录 1.Yolov8介绍 2.纸箱破损数据集介绍 2.1数据集划分 2.2 通过voc_label.py得到适合yolov8训练需要的 2.3生成内容如下 3.训练结果分析 1.Yolov8介绍 Ultralytics YOLOv8是Ultralytics公司开发的YOLO目标检测和图像分割模型的最新版本。YOLOv8是一种尖端的、最先进的&…

kafka学习-生产者

目录 1、消息生产流程 2、生产者常见参数配置 3、序列化器 基本概念 自定义序列化器 4、分区器 默认分区规则 自定义分区器 5、生产者拦截器 作用 自定义拦截器 6、生产者原理解析 1、消息生产流程 2、生产者常见参数配置 3、序列化器 基本概念 在Kafka中保存的数…

虚拟机上部署K8S集群

虚拟机上部署K8S集群 安装VM Ware安装Docker安装K8S集群安装kubeadm使用kubeadm引导集群 安装VM Ware 参考&#xff1a;http://www.taodudu.cc/news/show-2034573.html?actiononClick 安装Docker 参考&#xff1a;https://www.yuque.com/leifengyang/oncloud/mbvigg#2ASxH …