基于内存的分布式NoSQL数据库Redis(一)介绍与安装

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Tair(兼容Redis),内存型 2GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
简介: 基于内存的分布式NoSQL数据库Redis(一)介绍与安装

基于内存的分布式NoSQL数据库Redis

知识点01:课程目标

  1. 整体目标
  • Redis:NoSQL数据库,实时存储
  • Kafka:消息队列,实时存储
  • Hbase:NoSQL数据库,实时存储
  1. Redis的基本介绍和使用
  • 功能与应用场景
  • Redis的使用:基于命令的操作、基于编程的操作【JavaAPI】
  • 多练习
  • Redis的存储设计:性能、安全
  • 思想:大道至简

知识点02:NoSQL与RDBMS

  • 目标:了解NoSQL的应用场景与RDBMS的区别
  • 路径
  • step1:RDBMS的特点
  • step2:业务架构中的问题
  • step3:NoSQL的特点
  • 实施
  • 工具:MySQL、Oracle、SQL Server……
  • 应用:业务性数据存储系统:事务和稳定性
  • 特点:体现数据之间的关系,支持事务,保证业务完整性和稳定性,小数据量的性能也比较好
  • 开发:SQL
  • 问题:以网站后台存储为例,当并发量很大,所有高并发全部直接请求MySQL,容易导致MySQL奔溃

  • 需求:能实现高并发的数据库,接受高并发请求
  • 工具:Redis、HBASE、MongoDB……
  • 应用:一般用于高并发高性能场景下的数据缓存或者数据库存储
  • 特点:读写速度特别快,并发量非常高,相对而言不如RDBMS稳定,对事务性的支持不太友好
  • 开发:每种NoSQL都有自己的命令语法
  • 解决上面RDBMS的问题:使用高并发缓存实现读写分离
  • 读请求:读请求不读取MySQL,读取Redis
  • 写请求:写请求直接写入MySQL

  • 小结
  • RDBMS和NoSQL的应用特点分别是什么?
  • RDBMS
  • 场景:业务数据库
  • 特点:稳定性高、事务支持比较完善、小数据量性能好
  • NoSQL
  • 场景:高并发高性能的数据存储
  • 特点:稳定性和安全性相对不如RDBMS,支持高并发和高性能

知识点03:Redis的功能与应用场景

  • 目标:掌握Redis的功能与应用场景
  • 路径
  • step1:介绍
  • step2:功能特点
  • step3:应用场景
  • 实施
  • 介绍
  • 相关网站
  • 官方介绍
Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。 它支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted sets) 与范围查询, bitmaps, hyperloglogs 和 地理空间(geospatial) 索引半径查询。 Redis 内置了 复制(replication),LUA脚本(Lua scripting), LRU驱动事件(LRU eviction),事务(transactions) 和不同级别的 磁盘持久化(persistence), 并通过 Redis哨兵(Sentinel)和自动 分区(Cluster)提供高可用性(high availability)。
  • 定义:基于内存的分布式的NoSQL数据库
  • 所有数据存储在内存中,并且有持久化机制
  • 每次redis重启,会从文件中重新加载数据到内存,所有读写都只基于内存
  • 功能特点
  • 功能:提供高性能高并发的数据存储
  • 特点
  • 基于C语言开发的系统,与硬件的交互性能更好
  • 基于内存实现数据读写,读写性能更快
  • 分布式的:扩展性和稳定性更好
  • KV结构数据库:支持事务、拥有各种丰富的数据结构
  • KV结构
  • 缺点:两列,不能满足复杂的业务存储
  • 优点:Value可以支持多种类型,满足不同需求的存储
  • String、List、Set、Hash、Zset:掌握这五种类型的读写命令
  • 应用场景
  • 缓存:用于实现大数据量高并发的大数据量缓存【临时性存储】
  • 网站架构中:接受高并发的缓存读写请求
  • 数据库:用于实现高性能的小数据量读写【永久性存储】
  • 大数据平台中:高性能:一般用于作为实时计算结果的存储

  • 消息中间件:消息队列【MQ】:用于实现消息传递,一般不用Redis
  • 小结
  • Redis的功能与应用场景是什么?
  • 功能:实现基于高性能和高并发的数据存储【基于内存】
  • 应用
  • 缓存:高并发来接受高并发的读写,大数据量,临时性存储,允许数据丢失
  • 数据库:高性能来接受数据的读写,小数据量,永久性存储,不允许数据丢失

知识点04:Redis的Linux版单机部署

  • 目标:实现Redis的Linux版单机部署
  • 实施
  • Windows版本安装及远程工具使用请参考随堂资料《Redis的Windows版安装及远程工具的使用.pdf》
  • 上传redis-3.2.8源码
cd /export/software/
rz
  • 解压
tar -zxvf redis-3.2.8.tar.gz -C /export/server/
  • 安装依赖
yum -y install gcc-c++ tcl
  • 如果已经安装过,执行命令结果如下:

  • 编译安装
#进入源码目录
cd /export/server/redis-3.2.8/
#编译
make
#安装,并指定安装目录
make PREFIX=/export/server/redis-3.2.8-bin install
  • 修改配置
  • 复制配置文件
cp /export/server/redis-3.2.8/redis.conf /export/server/redis-3.2.8-bin/
  • 创建目录
#redis日志目录
mkdir -p /export/server/redis-3.2.8-bin/logs
#redis数据目录
mkdir -p /export/server/redis-3.2.8-bin/datas
  • 修改配置
cd  /export/server/redis-3.2.8-bin/
vim redis.conf
## 61行,配置redis服务器接受链接的网卡
bind node1
## 128行,redis是否后台运行,设置为yes
daemonize yes
## 163行,设置redis服务日志存储路径
logfile "/export/server/redis-3.2.8-bin/logs/redis.log"
## 247行,设置redis持久化数据存储目录
dir /export/server/redis-3.2.8-bin/datas/
  • 创建软连接
cd /export/server
ln -s redis-3.2.8-bin redis
  • 配置环境变量
vim /etc/profile
# REDIS HOME
export REDIS_HOME=/export/server/redis
export PATH=:$PATH:$REDIS_HOME/bin
source /etc/profile
  • 启动
  • 端口:6379
  • 启动服务端
  • 启动命令
/export/server/redis/bin/redis-server /export/server/redis/redis.conf
  • 启动脚本
vim /export/server/redis/bin/redis-start.sh
#!/bin/bash 
REDIS_HOME=/export/server/redis
${REDIS_HOME}/bin/redis-server ${REDIS_HOME}/redis.conf
chmod u+x /export/server/redis/bin/redis-start.sh 
  • 启动客户端
/export/server/redis/bin/redis-cli -h node1 -p 6379
  • 关闭客户端
  • exit:退出客户端
  • 关闭服务端
  • 方式一:客户端中
shutdown
  • 方式二:Linux命令行
kill -9 redis的pid
  • 方式三:通过客户端命令进行关闭
bin/redis-cli -h node1 -p 6379  shutdown
  • 测试
node1:6379> keys *
(empty list or set)
node1:6379> set s1 hadoop
OK
node1:6379> keys *
1) "s1"
node1:6379> get s1
"hadoop"
node1:6379> 
  • 远程工具的使用:参考Windows安装文档
  • 小结
  • 实现Redis的Linux版单机部署
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
打赏
0
0
0
0
111
分享
相关文章
分布式爬虫框架Scrapy-Redis实战指南
本文介绍如何使用Scrapy-Redis构建分布式爬虫系统,采集携程平台上热门城市的酒店价格与评价信息。通过代理IP、Cookie和User-Agent设置规避反爬策略,实现高效数据抓取。结合价格动态趋势分析,助力酒店业优化市场策略、提升服务质量。技术架构涵盖Scrapy-Redis核心调度、代理中间件及数据解析存储,提供完整的技术路线图与代码示例。
分布式爬虫框架Scrapy-Redis实战指南
【📕分布式锁通关指南 02】基于Redis实现的分布式锁
本文介绍了从单机锁到分布式锁的演变,重点探讨了使用Redis实现分布式锁的方法。分布式锁用于控制分布式系统中多个实例对共享资源的同步访问,需满足互斥性、可重入性、锁超时防死锁和锁释放正确防误删等特性。文章通过具体示例展示了如何利用Redis的`setnx`命令实现加锁,并分析了简化版分布式锁存在的问题,如锁超时和误删。为了解决这些问题,文中提出了设置锁过期时间和在解锁前验证持有锁的线程身份的优化方案。最后指出,尽管当前设计已解决部分问题,但仍存在进一步优化的空间,将在后续章节继续探讨。
489 131
【📕分布式锁通关指南 02】基于Redis实现的分布式锁
|
1月前
|
Springboot使用Redis实现分布式锁
通过这些步骤和示例,您可以系统地了解如何在Spring Boot中使用Redis实现分布式锁,并在实际项目中应用。希望这些内容对您的学习和工作有所帮助。
191 83
Redis分布式锁如何实现 ?
Redis分布式锁主要依靠一个SETNX指令实现的 , 这条命令的含义就是“SET if Not Exists”,即不存在的时候才会设置值。 只有在key不存在的情况下,将键key的值设置为value。如果key已经存在,则SETNX命令不做任何操作。 这个命令的返回值如下。 ● 命令在设置成功时返回1。 ● 命令在设置失败时返回0。 假设此时有线程A和线程B同时访问临界区代码,假设线程A首先执行了SETNX命令,并返回结果1,继续向下执行。而此时线程B再次执行SETNX命令时,返回的结果为0,则线程B不能继续向下执行。只有当线程A执行DELETE命令将设置的锁状态删除时,线程B才会成功执行S
【📕分布式锁通关指南 03】通过Lua脚本保证redis操作的原子性
本文介绍了如何通过Lua脚本在Redis中实现分布式锁的原子性操作,避免并发问题。首先讲解了Lua脚本的基本概念及其在Redis中的使用方法,包括通过`eval`指令执行Lua脚本和通过`script load`指令缓存脚本。接着详细展示了如何用Lua脚本实现加锁、解锁及可重入锁的功能,确保同一线程可以多次获取锁而不发生死锁。最后,通过代码示例演示了如何在实际业务中调用这些Lua脚本,确保锁操作的原子性和安全性。
93 6
【📕分布式锁通关指南 03】通过Lua脚本保证redis操作的原子性
【YashanDB知识库】ycm托管数据库时,数据库非OM安装无法托管
### 简介 在检查数据库安装时,发现未使用yasboot安装,导致无yasom和yasagent进程及缺少相关目录,无法通过ycm托管和监控。为解决此问题,需先将数据库托管到yasom中,再托管到ycm中。具体步骤包括生成配置文件、安装yasom和yasagent、修改并执行托管配置。最终确保数据库能被正常托管和监控。经验总结:应按规范使用yasboot安装数据库,避免后续问题。 (239字符)
|
1月前
|
【📕分布式锁通关指南 04】redis分布式锁的细节问题以及RedLock算法原理
本文深入探讨了基于Redis实现分布式锁时遇到的细节问题及解决方案。首先,针对锁续期问题,提出了通过独立服务、获取锁进程自己续期和异步线程三种方式,并详细介绍了如何利用Lua脚本和守护线程实现自动续期。接着,解决了锁阻塞问题,引入了带超时时间的`tryLock`机制,确保在高并发场景下不会无限等待锁。最后,作为知识扩展,讲解了RedLock算法原理及其在实际业务中的局限性。文章强调,在并发量不高的场景中手写分布式锁可行,但推荐使用更成熟的Redisson框架来实现分布式锁,以保证系统的稳定性和可靠性。
51 0
【📕分布式锁通关指南 04】redis分布式锁的细节问题以及RedLock算法原理
【YashanDB 知识库】ycm 托管数据库时,数据库非 OM 安装无法托管
【YashanDB 知识库】ycm 托管数据库时,数据库非 OM 安装无法托管
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等