NoSQL之Redis配置

文章目录

  • NoSQL之Redis配置
    • 一、关系数据库和非关系数据库
      • 1、关系型数据库
      • 2、非关系型数据库
      • 3、非关系型数据库产生背景
      • 4、关系型数据库和非关系型数据库的区别
        • 4.1 数据存储方式不同
        • 4.2 扩展方式不同
        • 4.3 对事务性的支持不同
      • 5、总结
        • 5.1 关系型数据库
        • 5.2 非关系型数据库
    • 二、Redis的基础概念
      • 1、Redis简介
      • 2、Redis程序
      • 3、Redis的优点
        • 3.1 具有极高的数据读写速度
        • 3.2 支持丰富的数据类型
        • 3.3 支持数据的持久化
        • 3.4 原子性
        • 3.5 支持数据备份
      • 4、Redis的使用场景
      • 5、Redis速度快的原因
      • 6、Redis与Memcashed区别
    • 三、Redis安装部署
      • 1、关闭防火墙
      • 2、源码编译及安装
      • 3、优化路径
      • 4、Redis服务控制
      • 5、修改/etc/redis/6379.conf配置参数
    • 四、Redis管理控制
      • 1、Redis命令工具
      • 2、redis-cli命令行工具
      • 3、redis-benchmark测试工具

NoSQL之Redis配置

一、关系数据库和非关系数据库

1、关系型数据库

  • 关系型数据库是一个结构化的数据库,创建在关系模型(二维表格模型)基础上,一般面向于记录。
  • 包括:Oracle、MySQL、SQLServer、Microsoft Access、DB2等

2、非关系型数据库

  • 非关系型数据库(NoSQL,Not Only SQL)意思是“不仅仅是SQL”,是非关系型数据库的总称。

  • 除了主流的关系型数据库外的数据库,都认为是非关系型

  • 包括:Redis、MongBD、Hbase、CouhDB等

3、非关系型数据库产生背景

  • 可用于应对Web2.0纯动态网站类型的三高问题

    High Performance

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

    High Storage

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

    High Scalability && High Availability

  • 对数据库高可扩展性与高看可用性需求

4、关系型数据库和非关系型数据库的区别

4.1 数据存储方式不同
  • 关系型和非关系型数据库的主要差异是数据存储的方式。关系型数据天然就是表格式的,因此存储在数据表的和合列中。数据表可以彼此关联协作存储,也很容易提取数据。

  • 与其相反,非关系型数据不适合存储在数据表的行和列中,而是大块组合在一起。非关系型数据通常存储在数据集中,就像文档、键值对或者图结构。

  • 你的数据及其特性是选择数据存储和提取方式的首要影响因素。

4.2 扩展方式不同
  • SQL和NoSQL数据库最大的差别可能是在扩展方式上,要支持日益增长的需求当然要扩展。
  • 要支持更多并发量,SQL数据库是纵向扩展,也就是说提高处理能力,使用速度更快速的计算机,这样处理相同的数据集就更快了。因为数据存储在关系表中,操作的性能瓶颈可能涉及很多个表,这都需要通过 提高计算机性能来克服。虽然SQL数据库有很大扩展空间,但最终肯定会达到纵向扩展的上限。
  • 而NoSQL数据库是横向扩展的,因为非关系型数据存储天然就是分布式的,NoSQL数据库的扩展可以通过给资源池添加更多普通的数据库服务器(节点)来分担负载。
4.3 对事务性的支持不同
  • 如果数据操纵需要高事务型或者复杂数据查询需要控制执行计划,那么传统的SQL数据库从性能和稳定性方面考虑是你的最佳选择。SQL数据库支持对事务原子性细粒度控制,并且易于回滚事务。
  • 虽然NoSQL数据库也可以使用事务操作,但稳定性方面没法和关系型数据库比较,所以它们真正闪亮的价值是在操作的扩展性和大数据量处理方面。

5、总结

5.1 关系型数据库

实例–>数据库–>表(table)–>记录行(row)–>数据字段(column)

5.2 非关系型数据库

实例–>数据库–>集合(collection)–>键值对(key-value)
非关系型数据库不需要手动创建数据和集合(表)。

二、Redis的基础概念

1、Redis简介

  • Redis(Remote Dictionary Server ),即远程字典服务,是一个开源的、使用C语言编写的NoSQL数据库。
  • Redis基于内存运行并支持持久化,采用key-value(键值对)的存储形式,是目前分布式架构中不可或缺的一环。

2、Redis程序

  • Redis服务器程序是单进程模型,也就是在一台服务器上可以同时启动多个Redis进程,Redis的实际处理速度则是完全依靠于主进程的执行效率。若在服务器上只运行一个Redis进程,当多个客户端同时访问时,服务器的处理能力是会有一定程度的下降;若在同一台服务器上开启多个Redis进程,Redis在提高并发处理能力的同时会给服务器的CPU造成很大压力。
  • 即:在实际生产环境中,需要根据实际的需求来决定开启多少个Redis进程。若对高并发要求更高一些,可能会考虑在同一台服务器上开启多个进程。若CPU资源比较紧张,采用单进程即可。

3、Redis的优点

3.1 具有极高的数据读写速度
  • 数据读取的速度最高可达到110000次/秒,数据写入速度最高可达到81000次/秒。
3.2 支持丰富的数据类型
  • 支持key-value、String、Lists、Hashes、Sets及Stored Sets等数据类型操作。
3.3 支持数据的持久化
  • 可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
3.4 原子性
  • Redis所有操作都是原子性的(要么都执行,要么都不执行)。
3.5 支持数据备份
  • 即master-slave模式的数据备份。

4、Redis的使用场景

  • Redis作为基于内存运行的数据库,缓存是最长应用的场景之一。除此之外,Redis常见应用场景还包括获取最新N个数据的操作、排行榜类应用、计算器应用、存储关系、实时分析系统、日志记录等。

5、Redis速度快的原因

  • Redis是纯内存结构,避免了磁盘的I/O等耗时操作。
  • Redis命令处理的核心模块为单线程,减少了锁竞争,以及频繁创建线程和销毁线程的代价,减少了线程上下文切换的消耗。
  • 采用了I/O多路复用机制,大大提升了并发效率。
  • I/O多路复用程序虽然会同时监听多个socket连接,但是其会将监听的socket都放到一个队列里面,然后通过这个队列有序的,同步的将每个socket对应的时间传送到文件事件分派器,再由文件事件分派器给对应的事件处理器进行处理,只有当一个socket所对应的事件被处理完毕之后,I/O多路复用程序才会继续向文件事件分派器传送下一个socket所对应的的事件,这也可以验证上面的结论,处理客户端的命令请求是单线程的方式逐个处理,但是事件处理器内并不是只有一个线程。

6、Redis与Memcashed区别

说明MemcachedRedis
类型Key-valueKey-value
过期策略支持支持
数据类型单一数据类型五大数据类型
持久化不支持支持
主从复制不支持支持
虚拟内存不支持支持

三、Redis安装部署

1、关闭防火墙

systemctl stop firewalld
setenforce 0
#需要先关闭防火墙和防护中心

2、源码编译及安装

cd /opt
#切换目录

#上传需要的安装包

yum install -y gcc gcc-c++ make
#安装依赖环境

tar xf redis-5.0.7.tar.gz
#解压

cd redis-5.0.7/
#切换目录

make && make PREFIX=/usr/local/redis install
#由于Redis源码包中直接提供了Makefile文件,所以在解压完软件包后,不用先执行./configure进行配置,可直接执行make与make install命令进行安装

cd utils/
#执行软件包提供的install_server.sh脚本文件设置Redis服务所需要相关配置文件

./install_server.sh
......
#一直回车

Please select the redis executable path []
#需要手动修改为/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
#客户端命令工具

Is this ok? Then press ENTER to go on or Ctrl-C to abort.
#确认并回车

image-20240401172325502

image-20240401172900744

3、优化路径

ln -s /usr/local/redis/bin/* /usr/local/bin
#把redis的可执行程序文件放入路径环境变量的目录中便于系统识别

ss -natp |grep redi
#当install_server.sh脚本运行完毕,Redis服务就已经启动,默认监听端口为6379

image-20240401173204917

4、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
#状态

image-20240401173643689

5、修改/etc/redis/6379.conf配置参数

#修改配置文件
vim /etc/redis/6379.conf
bind 127.0.0.1 192.168.10.15
#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
#重启

ss -natp | grep redis
#查看redis端口号

image-20240401174710321

image-20240401174833981

四、Redis管理控制

1、Redis命令工具

redis-server
#用于启动Redis的工具

redis-benchmark
#用于检测Redis在本机的运行效率

redis-check-aof
#修复AOF持久化文件

redis-check-rdb
#修复RDB持久化文件

redis-cli
#Redis命令行工具

2、redis-cli命令行工具

语法

redis-cli -h root -p port -a password
-h:指定远程主机
-p:指定Redis服务的端口号
-a:指定密码,未设置数据库密码可以省略-a选项

若不添加任何选项表示,则使用127.0.0.1:6379连接本机上的Redis数据库
redis-cli -h 192.168.10.15 -p 6379
#连接远程主机192.168.10.15

redis-cli
#默认连接本机

image-20240401180544854

3、redis-benchmark测试工具

  • redis-benchmark是官方自带的Redis性能测试工具,可以有效的测试Redis服务的性能。
  • 基本的测试语法:redis-benchmark [选项] [选项值]
常用选项说明
-h指定服务器主机名
-p指定服务器端口
-s指定服务器socket
-c指定并发连接数
-n指定请求数
-d以字节的形式指定SET/GET值的数据大小
-k1=keep alive 0=reconnect
-rSET/GET/INCR使用随机key,SADD使用随机值
-P通过管道传输请求
-q强制退出redis,仅显示query/sec值
–csv以CSV格式输出
-I生成循环,永久执行测试
-t仅运行以逗号分隔的测试命令列表
-IIdle模式,仅打开N个idle连接并等待
redis-benchmark -h 192.168.10.15 -p 6379 -c 100 -n 100000
#向IP地址为192.168.10.15,端口号为6379的Redis服务器发送100个并发连接与100000个请求测试性能

redis-benchmark -h 192.168.10.15 -p 6379 -q -d 100
#测试存取大小为100字节的数据包的性能

redis-benchmark -t set,lpush -n 100000 -q
#测试本机上Redis服务在进行set与lpush操作时的性能

image-20240401180505220

image-20240401180733150

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/518215.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Spring-IoC 基于注解

基于xml方法见:http://t.csdnimg.cn/dir8j 注解是代码中的一种特殊标记,可以在编译、类加载和运行时被读取,执行相应的处理,简化 Spring的 XML配置。 格式:注解(属性1"属性值1",...) 可以加在类上…

大数据基础设施搭建 - Spark

文章目录 一、解压压缩包二、修改配置文件conf/spark-env.sh三、测试提交Spark任务四、Spark on Hive配置4.1 创建hive-site.xml(spark/conf目录)4.2 查看hive的hive-site.xml配置与3.1配置的是否一致4.3 测试SparkSQL4.3.1 启动SparkSQL客户端&#xff…

【JAVA】JAVA快速入门(长期维护)

下面是java的一些入门基础知识,有需要借鉴即可。 课程:B站黑马程序员,JAVA入门LINK 一、初识JAVA 1.java概述 概念:java是由sun公司研发,在2009年被oracle收购,祖师爷詹姆斯高斯林,是一种高级…

Copilot for Microsoft365使用心得

从去年3月份的发布到上周获得的体验名额,关注copilot已经超过了一年, 实际体验了一周觉得微软这款产品真的挺厉害的,至少在我认知里面确实可以减少很多的工作量,在此感谢陈老师公众号的体验卡的活动(活动真实有效&…

101. 对称二叉树及同类题

101. 对称二叉树 力扣题目链接(opens new window) 给定一个二叉树,检查它是否是镜像对称的。 递归 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNo…

【青龙脚本】星抖

脚本出处:Huaji 功能:完成日常任务 每天运行1次即可 变量名:yuanshen_xddj 手机登录软件后,抓包,搜索Authorization里面的参数 注意:每天12小时都要进软件领取金块,超过12小时就会停止产出 参数设置都在脚本注释里,懂的都懂&a…

Redis从入门到精通(五)Redis实战(二)商户查询缓存

↑↑↑请在文章头部下载测试项目原代码↑↑↑ 文章目录 前言4.2 商户查询缓存4.2.1 缓存介绍4.2.2 查询商户信息的传统做法4.2.2.1 接口文档4.2.2.2 代码实现4.2.2.3 功能测试 4.2.3 查询商户信息添加Redis缓存4.2.3.1 逻辑分析4.2.3.2 代码实现4.2.3.3 功能测试 4.2.3 数据一致…

传输层 --- UDP

目录 1. 传输层是什么呢? 2. 再谈端口号 2.1. 端口号是什么 2.2. 协议号是什么 2.3. 认识知名端口号 2.4. 端口号的相关问题 2.4.1. 一个进程可以绑定多个端口号吗? 2.4.2. 一个端口号可以被多个进程绑定吗? 2.4.3. 为什么不使用P…

向量数据库 | AI时代的航道灯塔

向量数据库 | AI时代的航道灯塔 什么是向量检索服务拍照搜商品 你使用过向量数据库吗?使用体验?为什么向量数据库能借由大模型引起众多关注向量数据库在当前AI热潮中是昙花一现,还是未来AI时代的航道灯塔? 今天的话题主要是讨论向…

python-基础篇-字符串、列表、元祖、字典-列表

文章目录 2.3.2列表2.3.2.1列表介绍2.3.2.1.1列表的格式2.3.2.1.2打印列表 2.3.2.2列表的增删改查2.3.2.2.1列表的遍历2.3.2.2.1.1使用for循环2.3.2.2.1.2使用while循环 2.3.2.2.2添加元素("增"append, extend, insert)2.3.2.2.2.1append 2.3.2.2.2.2extend2.3.2.2.2…

博客搭建(hexo+github)

简介 搭建完成网站的如下所示 https://polarday.top/ 使用github托管博客,完全免费不需要购买服务器 博客框架:hexo hexo主题:ICARUS 图床:githubPicGo 编辑:vscode 为什么使用hexo框架?因为hexo是静态框…

新手开抖店:选品过后如何有效对接达人?这些方法100%有效!

哈喽~我是电商月月 要说做抖音小店最主要的是什么?那当然是找品了 那出单最快的方法是什么?无疑是达人带货了! 但新手店铺没销量,没体验分,没好评怎么能让达人同意帮我们带货呢? 方法其实很简单&#x…

上位机图像处理和嵌入式模块部署(qmacvisual之plc通信)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 传统的非标自动化设备当中,plc发挥了很大的作用。这里面如何对这些电机和机构进行控制,大多数场景下用的就是plc设备了。目…

常用的AI绘画自动生成器介绍

AI绘画自动生成器是一种利用人工智能技术生成图像的工具。它可以根据用户输入的文本描述自动生成相应的图像。目前,有几种流行的AI绘画自动生成器,包括: 1. **DALL-E 2** DALL-E 2是由OpenAI开发的AI绘画生成器,它可以根据用户输入的自然语言描述生成高质量的图像。DALL-E 2使…

上位机图像处理和嵌入式模块部署(qmacvisual之tcp服务器端)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 上面一篇,我们谈到了tcp客户端,另外一种连接方法就是tcp服务器端。事实上,对于第三方系统,大多数情…

解析Apache Kafka:在大数据体系中的基本概念和核心组件

关联阅读博客文章:探讨在大数据体系中API的通信机制与工作原理 关联阅读博客文章:深入解析大数据体系中的ETL工作原理及常见组件 关联阅读博客文章:深度剖析:计算机集群在大数据体系中的关键角色和技术要点 关联阅读博客文章&a…

账号和权限管理

一、账号 1.用户的类型 1.超级管理:权限最高的用户 2.普通用户:权限受到限制的用户 3.程序用户:不是给人登录使用的,给程序使用的,这些用户一般不允许登录到系统,一般是为了支持程序运行(超级管理员和普…

C语言中的结构体:揭秘数据的魔法盒

前言 在C语言的广阔天地中,结构体无疑是一颗璀璨的明珠。它就像是一个魔法盒,能够容纳各种不同类型的数据,并按我们的意愿进行组合和排列。那么,这个魔法盒究竟有何神奇之处呢?让我们一探究竟。 一、结构体的诞生&…

SV学习笔记(七)

类型转换 写在前面 类型转换可以分为 静态转换和动态转换 。静态转换即需要在转换的表达式前 加上单引号 即可,该方式并不会对转换值做检查。如果发生转换失败,我们也无从得知。动态转换即需要使用 系统函数$cast(tgt, src) 做转换。静态转…

光猫桥接模式详细步骤

目录 一、前言 路由模式 (宽带默认) 桥接模式 二、桥接模式步骤 (一)图片记录备份 设备信息图 网络侧信息 远程管理密码 宽带上网设置 (二)桥接模式开始 光猫设置 路由器设置 一、前言 重点&a…