Redis部署和基础命令

一、Redis基本概念

1.1 Redis简介

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

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

1.2 Redis的优点

1)具有极高的数据读写速度:数据读取的速度最高可达到 110000 次/s,数据写入速度最高可达到 81000 次/s;

2)支持丰富的数据类型:支持 key-value、Strings、Lists、Hashes、Sets 及 Sorted Sets 等数据类型操作;

3)支持数据的持久化:可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用;

4)原子性:Redis 所有操作都是原子性的;

5)支持数据备份:即 master-salve 模式的数据备份。

1.3 使用场景

Redis作为基于内存运行的数据库,是一个高性能的缓存,一般应用在Session缓存、队列、排行榜、计数器、最近最热文章、最近最热评论、发布订阅等。
Redis 适用于数据实时性要求高、数据存储有过期和淘汰特征的、不需要持久化或者只需要保证弱一致性、逻辑简单的场景。

我们通常会将部分数据放入缓存中,来提高访问速度,然后数据库承担存储的工作。

1.4 适合放入缓存中的数据

●即时性。例如查询最新的物流状态信息。
●数据一致性要求不高。例如门店信息,修改后,数据库中已经改了,五分钟后缓存中才是最新的,但不影响功能使用。
●访问量大且更新频率不高,例如网站首页的广告信息,访问量大,但是不会经常变化。

1.5 Redis快速的原因

1)redis基于内存运行,数据操作都是内存中完成的;

2)数据读写采用单线程模式,避免了多线程切换的CPU性能消耗,同时也不用考虑各种锁的问题;

3)采用IO多路复用模型,可以使线程处理更多的网络连接请求,提高并发能力。

1.6 Redis数据类型

字符型(string): 普通字符串

哈希(hash): 键值对的 键值对

列表 (linked lists): 类似于 数组

集合(set): 无序

有序集合(sorted set): 排行榜

二、Redis安装部署

环境准备

#开机自动关闭防火墙
systemctl disable firewalld --now#永久关闭selinux
setenforce 0
sed -i 's/enforcing/disabled/' /etc/selinux/config

修改内核参数

vim /etc/sysctl.conf
vm.overcommit_memory = 1
net.core.somaxconn = 2048#vm.overcommit_memory:该配置项用于设置内存超额分配策略。
#当值为 0 时,表示内核会根据实际情况动态分配内存,但这可能导致内存超额分配,当系统内存不足时,可能会引发OOM(Out of Memory)错误。
#将其设置为 1 可以禁用内存超额分配,确保只有在内存充足的情况下才能进行内存分配。这对于确保系统稳定性和可靠性是有帮助的。#net.core.somaxconn:该配置项用于设置系统中允许的最大挂起连接数。
#当系统接收到大量并发连接请求时,如果系统的连接队列已满,则新的连接请求会被拒绝。
#通过增加 net.core.somaxconn 的值,可以增加系统的连接队列大小,从而提高系统处理并发连接请求的能力。sysctl -p
#刷新配置文件

安装redis

1)安装依赖
[root@centos7 ~]#yum -y install gcc jemalloc-devel
#安装依赖包centos
[root@centos7 ~]#yum -y install gcc jemalloc-devel systemd-devel
#如果支持systemd需要安装下面包
ubentu
[root@ubuntu1804 ~]#apt -y install make gcc libjemalloc-dev libsystemd-dev2)下载安装包
[root@localhost ~]#cd  /data
[root@localhost ~]#wget http://download.redis.io/releases/redis-5.0.7.tar.gz3)解压
[root@centos7 ~]#tar xvf redis-5.0.7.tar.gz4)编译安装
[root@centos7 ~]#cd redis-5.0.7/[root@centos7 redis-5.0.7]#make PREFIX=/apps/redis install #指定redis安装目录[root@centos7 redis-5.0.7]#make USE_SYSTEMD=yes PREFIX=/apps/redis install
#如果支持systemd,需要执行下面5)配置变量
[root@centos7 ~]#echo 'PATH=/apps/redis/bin:$PATH' > /etc/profile.d/redis.sh
[root@centos7 ~]#. /etc/profile.d/redis.sh6)准备配置文件及目录
[root@centos7 ~]#mkdir /apps/redis/{etc,log,data,run}
#创建配置文件、日志、数据等目录[root@centos7 redis-5.0.7]#cp redis.conf /apps/redis/etc/
#源码包中自带 配置文件7)准备用户 修改权限
[root@centos7 ~]#useradd -r -s /sbin/nologin redis[root@centos7 ~]#chown -R redis.redis /apps/redis/
#设置目录权限
[root@centos7 ~]#ln -sv /apps/redis/bin/redis-* /usr/bin/
#设置软连接8)准备service文件
[root@centos7 ~]#vim /usr/lib/systemd/system/redis.service
[Unit]
Description=Redis persistent key-value database
After=network.target[Service]
ExecStart=/apps/redis/bin/redis-server /apps/redis/etc/redis.conf --supervised systemd
ExecStop=/bin/kill -s QUIT $MAINPID
#Type=notify 如果支持systemd可以启用此行
User=redis
Group=redis
RuntimeDirectory=redis
RuntimeDirectoryMode=0755[Install]
WantedBy=multi-user.target9)启动redis
[root@centos7 ~]# systemctl daemon-reload
[root@centos7 ~]# systemctl start  redis

redis配置文件修改

vim /apps/redis/etc/redis.confbind 127.0.0.1
0.0.0.0               #69行 ,添加监听的主机地址,0.0.0.0表示监听任意地址
protected-mode no     
#89行,将本机访问保护模式设置no。如果开启了,那么在没有设定bind ip且没有设密码的情况下,Redis只允许接受本机的响应
port 6379             #93行,Redis默认的监听6379端口
daemonize yes         #137行,设置为守护进程。后台启动
pidfile /apps/redis/run/redis_6379.pid
#159行,指定PID文件
logfile  /apps/redis/log/redis6379.log
#172行,指定日志文件
dir /apps/redis/data
#264行,指定持久化文件所在目录
requirepass abc123	 
#508行,增加一行,设置redis密码

ss -natp |grep redis

三、Redis基础命令

3.1 set和get命令

setget命令用于设置和获取键值对的

set用于存放数据

set key value [EX seconds] [PX milliseconds] [NX|XX]#key 为键名
#value为键值
127.0.0.1:6379> set name cxk

get用于获取数据

127.0.0.1:6379> get name

3.2 keys 命令

keys命令用于查询键,支持通配符*?。

#先赋值
127.0.0.1:6379> set k1 1
127.0.0.1:6379> set k2 2
127.0.0.1:6379> set k3 3
127.0.0.1:6379> set k4 4
#查看当前数据库中所有键
keys *

127.0.0.1:6379> KEYS k*				
#查看当前数据库中以 k 开头的数据127.0.0.1:6379> KEYS k?				
#查看当前数据库中以 k 开头后面包含任意一位的数据127.0.0.1:6379> KEYS k??				
#查看当前数据库中以 k 开头 k 开头后面包含任意两位的数据

3.3 del命令

删除当前数据库的指定键。


127.0.0.1:6379> del k1127.0.0.1:6379> get k1

3.4 exists命令

判断键是否存在,1表示键存在,0表示键不存在。

3.5 type命令

查看键的数据类型

3.6 expire 命令

已存在的键设置过期时间

3.7 ttl 命令

查看键的生命周期时间,-1表示永不过期,-2表示已过期。

3.8 rename 命令

重命名键名,会覆盖已存在的键的值。

#命令格式
rename 源key 目标key

3.9 renamenx 命令

重命名键名,如果新键已存在则不执行重命名操作即不会覆盖

#命令格式
renamenx 源key 目标key

3.10 dbsize 命令

统计当前库的键的数量

3.11  FLUSHALL

强制清空当前redis服务器所有数据库中的所有key,即删除所有数据,此命令慎用!

127.0.0.1:6379> FLUSHALL OK#生产建议修改配置 /etc/redis.conf 
rename-command FLUSHALL ""
#rename-command 在6.2.4版淘汰了

3.11 SHUTDOWN

# 停止所有客户端

如果有至少一个保存点在等待,执行 SAVE 命令

如果 AOF 选项被打开,更新 AOF 文件

关闭 redis 服务器(server)

如果持久化被打开的话, SHUTDOWN 命令会保证服务器正常关闭而不丢失任何数据。

另一方面,假如只是单纯地执行 SAVE 命令,然后再执行 QUIT 命令,则没有这一保证 —— 因为在执行SAVE 之后、执行 QUIT 之前的这段时间中间,其他客户端可能正在和服务器进行通讯,这时如果执行 QUIT 就会造成数据丢失。

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

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

相关文章

python爬虫之scrapy基于管道持久化存储操作

python爬虫之scrapy基于管道持久化存储操作 本文基于python爬虫之基于终端指令的持久化存储和python爬虫之数据解析操作而写 scrapy持久化存储 基于管道: 编码流程: 1、数据解析 2、在item类中定义相关属性 3、将解析的数据封装存储到item类型的对象 4、…

Linux内核 -- 内存管理之scatterlist结构使用

Linux Kernel Scatterlist 使用指南 1. 简介 scatterlist 结构在 Linux 内核中主要用于 DMA(直接内存访问)操作中的内存管理。它允许将不连续的物理内存片段表示为一个逻辑上的连续块,从而使 DMA 操作可以高效地处理这些不连续的内存片段。…

【问题记录】VsCode中以管理员权限运行Powershell

问题展示 今天在尝试运行nodemon命令的时候出问题,显示没法识别,经过分析发现是管理员权限的问题,由于是在vscode里面进行开发,因此特此进行配置。 方法一 直接在vscode命令行中输入如下命令: Start-Process powers…

IDEA如何创建原生maven子模块

文件 -> 新建 -> 新模块 -> Maven ArcheTypeMaven ArcheType界面中的输入框介绍 名称:子模块的名称位置:子模块存放的路径名创建Git仓库:子模块不单独作为一个git仓库,无需勾选JDK:JDK版本号父项:…

Linux网络命令:网络工具socat详解

目录 一、概述 二、基本用法 1、基本语法 2、常用选项 3、获取帮助 三、用法示例 1. 监听 TCP 端口并回显接收到的数据 2. 通过 TCP 端口转发数据到 UNIX 套接字 3. 将文件内容发送到 TCP 端口: 4. 使用伪终端进行串行通信 5、启动一个TCP服务器 6、建…

Hi3861鸿蒙开发环境搭建

1.1 安装配置Visual Studio Code 打开Download Visual Studio Code - Mac, Linux, Windows选择下载安装Windows系统的Visual Studio Code。 下载后进行安装。Visual Studio Code安装完成后,通过内置的插件市场搜索并安装开发所需的插件如图所示: 1.2 安…

实时消息推送系统,写得太好了!

websocket 协议是在 http 协议上的一种补充协议,是 html5 的新特性,是一种持久化的协议。其实 websocket 和 http 关系并不是很大,不过都是属于应用层的协议,接下来我们就开始实战。 websocket 定时推送 本教程基于 springboot …

symbol数据类型以及应用场景

在js中,Symbol是一种基本数据类型,是在ECMAScript 6 (ES6) 中引入的新特性。表示独一无二 Symbol的定义 Symbol是不完整的构造函数,创建symbol对象时不需要new操作符,原因是通过 new 实例化的结果是一个 object 对象,而不是原始类型的 symbol。 var s…

STL--栈(stack)

stack 栈是一种只在一端(栈顶)进行数据插入(入栈)和删除(出栈)的数据结构,它满足后进先出(LIFO)的特性。 使用push(入栈)将数据放入stack,使用pop(出栈)将元素从容器中移除。 使用stack,必须包含头文件: #include<stack>在头文件中,class stack定义如下: namespace std…

Druid 连接池在很多方面表现出色,但在实际应用中也可能会遇到一些缺陷或问题。

Druid 连接池是阿里巴巴开源的一个功能强大的数据库连接池&#xff0c;它具有高性能、可靠性、可管理性、安全性和扩展性等特点。然而&#xff0c;尽管 Druid 连接池在很多方面表现出色&#xff0c;但在实际应用中也可能会遇到一些缺陷或问题。 1. **连接耗尽问题**&#xff1…

13 - matlab m_map地学绘图工具基础函数 - 介绍创建管理颜色映射的函数m_colmap和轮廓图绘制颜色条的函数m_contfbar

13 - matlab m_map地学绘图工具基础函数 - 介绍创建管理颜色映射的函数m_colmap和轮廓图绘制颜色条的函数m_contfbar 0. 引言1. 关于m_colmap2. 关于m_contfbar3. 结语 0. 引言 本篇介绍下m_map中用于创建和管理颜色映射函数&#xff08;m_colmap&#xff09;和 为轮廓图绘制颜…

基于深度学习的电影推荐系统

1 项目介绍 1.1 研究目的和意义 在电子商务日益繁荣的今天&#xff0c;精准预测商品销售数据成为商家提升运营效率、优化库存管理以及制定营销策略的关键。为此&#xff0c;开发了一个基于深度学习的商品销售数据预测系统&#xff0c;该系统利用Python编程语言与Django框架&a…

SQLite 命令行客户端 + Windows 批处理应用

SQLite 命令行客户端 Windows 批处理应用 下载 SQLite 客户端1. Bat 辅助脚本1. 执行SQL.bat执行 2. 导出Excel.bat执行效果 3. 导出HTML.bat执行效果 4. 清空-订单表.bat5. 订单表.bat 2. 测试 SQL1. 创建订单表.sql2. 插入订单表.sql3. 查询订单表.sql4. 清空订单表.sql5. 删…

Qt Qwt 图表库详解及使用

文章目录 Qt Qwt 图表库详解及使用一、Qwt 概述二、安装 Qwt1. 下载和编译 Qwt2. 在项目中使用 Qwt三、Qwt 的基本使用1. 创建一个简单的折线图2. 添加图例和自定义样式四、Qwt 的交互功能1. 启用缩放和平移2. 启用数据点选择五、Qwt 的高级特性1. 实时数据更新2. 多轴绘图六、…

nvm 管理多版本 node

1、下载 先不安装node 下载 nvm 1.1.10-setup.zip 解压&#xff1a;nvm&#xff1a;https://nvm.uihtm.com/ 新建nodejs/node、nodejs/nvm文件夹用于存放node版本和nvm安装路径 安装nvm&#xff1a;上述链接有安装教程 查看是否安装成功&#xff1a;重新打开cmd 输入 nvm nv…

Hyper-V克隆虚拟机教程分享!

方法1. 使用导出导入功能克隆Hyper-V虚拟机 导出和导入是Hyper-V服务器备份和克隆的一种比较有效的方法。使用此功能&#xff0c;您可以创建Hyper-V虚拟机模板&#xff0c;其中包括软件、VM CPU、RAM和其他设备的配置&#xff0c;这有助于在Hyper-V中快速部署多个虚拟机。 在…

深入理解基本数据结构:数组详解

引言 在计算机科学中&#xff0c;数据结构是存储、组织和管理数据的方式。数组作为最基础的数据结构之一&#xff0c;广泛应用于各种编程场景。在这篇博客中&#xff0c;我们将详细探讨数组的定义、特点、操作及其在不同编程语言中的实现。 什么是数组&#xff1f; 数组是一种…

原生android的内存性能提升方面的方案大致设计

一 测试目标&#xff1a; 以满足用户设备的内存性能和不杀后台为目标。 1&#xff1a;满足用户设备的内存性能是指不出现因为内存原因导致的安卓设备死机&#xff0c;卡顿等问题。 2&#xff1a;满足不杀后台是指整个设备使用时&#xff0c;不出现后台app被杀。 通常是估算如果…

构造函数注入@RequiredArgsConstructor

Api(tags "用户管理接口") RequiredArgsConstructor RestController RequestMapping("users") public class UserController {private final IUserService userService;PostMappingApiOperation("新增用户")public void saveUser(RequestBody U…

输入框输入值之后,检索表格中是否存在输入框中的值,存在就让当前文字为红色

this.searchValue为输入框的值 createKeywordHtml_content(data) { if (data undefined) { return data; } if (typeof data ! string) { data String(data) } let value data.replace(this.searchValue, <span style"color:#FF5555">$&</span>…