当前位置:   article > 正文

Redis的安装方法与基本操作_redis数据库安装

redis数据库安装

目录

前言

一、REDIS概述

二、REDIS安装

1、编译安装

2.yum安装

三、Redis的目录结构

四、基础命令解析

五、在一台服务器上启动多个redis

六、数据库的基本操作

(一)登录数据库

(二)基础命令

七、Redis持久化

(一)RDB持久化

(二)AOF持久化

总结



前言

Redis是一个开源的内存数据结构存储系统,也可以用作数据库、缓存和消息中间件。它支持多种数据结构,包括字符串(strings)、哈希(hashes)、列表(lists)、集合(sets)、有序集合(sorted sets)等。
Redis的特点包括:

高性能:Redis将数据存储在内存中,因此具有非常快速的读写速度。
持久化:Redis支持两种持久化方式,即RDB(Redis Database)和AOF(Append-Only File)。

RDB是将数据以快照的形式保存到磁盘上,通常用于备份和恢复数据。
AOF是将每个写操作追加到文件中,以日志的形式记录,通过重新执行这些写操作可以恢复数据。


多种数据结构:Redis支持多种数据结构,使得它可以灵活地应用于不同的场景。
发布/订阅模式:Redis支持发布/订阅模式,可以将消息发布到多个订阅者。
高可用性:Redis支持主从复制和哨兵机制,可以实现高可用性和故障转移。
支持事务:Redis可以通过MULTI、EXEC、WATCH等命令实现事务的功能,保证多个命令的原子性。
分布式:Redis Cluster可以将数据分布在多个节点上,提高系统的可扩展性和容错性。

Redis广泛应用于缓存、计数器、队列、排行榜等场景,具有高性能、高可用性和灵活性的特点,成为了很多互联网公司的首选技术之一。
 


一、REDIS概述

REDIS属于非关系型数据库,采用内存存储的方式(速度快,但不 能长久保存)

Redis全称Remote Dictionary Server 远程字典服务
官网:https://www.redis.net.cn/

 1.内存存储、持久化、   键值对存储、监听端口号:6379
 数据类型:
        字符串(string)
        哈希值(hash)
        列表(list)
        集合(set)
        位图(bitmap)

2.类型:
    文档型数据库(Document-oriented database)如MongoDB;
    列族数据库(Column-family database)如HBase、Cassandra等;
    图形数据库(Graph database)如Neo4j、ArangoDB等;
    键值对数据库(Key-value database)如Redis、Memcached等;
    对象数据库(Object-oriented database)如db4o等。

3.应用场景:
    缓存:Redis最常用的应用场景就是缓存,它可以缓存各种类型的数据,如数据库查询结果、API返回结果等,以提高应用程序的响应速度和并发性能。
    分布式锁:Redis的分布式锁可以确保在分布式系统中对某个资源的互斥访问,避免多个节点出现并发操作的问题。
    计数器:Redis支持对计数器的操作,能够方便地实现各种计数器的功能,如网站访问次数计数、订单数量计数等。
    会话管理:Redis可以用来管理会话信息,实现会话的状态存储和共享,避免了单点故障的问题。
    消息队列:Redis支持发布订阅模式,可以作为一个轻量级的消息队列使用,实现异步消息处理和任务派发等功能。

二、REDIS安装

1、编译安装

配置环境:设置防火墙、selinux、图形化、配置IP确保联网

  1. [root@localhost ~]# systemctl stop firewalld
  2. [root@localhost ~]# setenforce 0
  3. setenforce: SELinux is disabled
  4. [root@localhost ~]# vim /etc/sysconfig/network-scripts/ifcfg-ens33
  5. [root@localhost ~]# systemctl restart network
  6. [root@localhost ~]# ping www.baidu.com
  7. PING www.a.shifen.com (220.181.38.150) 56(84) bytes of data.
  8. 64 bytes from 220.181.38.150 (220.181.38.150): icmp_seq=1 ttl=128 time=51.6 ms
  9. 64 bytes from 220.181.38.150 (220.181.38.150): icmp_seq=2 ttl=128 time=32.7 ms
  10. 64 bytes from 220.181.38.150 (220.181.38.150): icmp_seq=3 ttl=128 time=111 ms
  11. 64 bytes from 220.181.38.150 (220.181.38.150): icmp_seq=4 ttl=128 time=114 ms
  12. ^C
  13. --- www.a.shifen.com ping statistics ---
  14. 4 packets transmitted, 4 received, 0% packet loss, time 3004ms
  15. rtt min/avg/max/mdev = 32.740/77.544/114.197/36.007 ms
  16. [root@localhost ~]#

下载wget http://download.redis.io/releases/redis-5.0.8.tar.gz

  1. [root@localhost ~]# wget http://download.redis.io/releases/redis-5.0.8.tar.gz
  2. --2023-08-08 23:05:12-- http://download.redis.io/releases/redis-5.0.8.tar.gz
  3. 正在解析主机 download.redis.io (download.redis.io)... 45.60.125.1
  4. 正在连接 download.redis.io (download.redis.io)|45.60.125.1|:80... 已连接。
  5. 已发出 HTTP 请求,正在等待回应... 200 OK
  6. 长度:1985757 (1.9M) [application/octet-stream]
  7. 正在保存至: “redis-5.0.8.tar.gz”
  8. 100%[==============================================================================>] 1,985,757 46.3KB/s 用时 59s
  9. 2023-08-08 23:06:11 (32.7 KB/s) - 已保存 “redis-5.0.8.tar.gz” [1985757/1985757])
  10. [root@localhost ~]# ls
  11. anaconda-ks.cfg initial-setup-ks.cfg redis-5.0.8.tar.gz 公共 模板 视频 图片 文档 下载 音乐 桌面
  12. [root@localhost ~]#

解压此处大家可自行选择路径,编译安装 make && make install

  1. [root@localhost ~]# mkdir redis
  2. [root@localhost ~]# tar -xf redis-5.0.8.tar.gz -C redis
  3. [root@localhost ~]# cd redis/
  4. [root@localhost redis]# ls
  5. redis-5.0.8
  6. [root@localhost redis]# cd redis-5.0.8/
  7. [root@localhost redis-5.0.8]# make && make install

编译安装结束后我们进入配置文件redis.conf修改daemonize yes改为后台启动

在我们的redis-5.0.8目录启动REDIS命令:redis-server redis.conf 登录redis-cli

  1. [root@localhost redis-5.0.8]# vim redis.conf
  2. [root@localhost redis-5.0.8]# redis-server redis.conf
  3. 8921:C 08 Aug 2023 16:34:33.301 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
  4. 8921:C 08 Aug 2023 16:34:33.301 # Redis version=5.0.8, bits=64, commit=00000000, modified=0, pid=8921, just started
  5. 8921:C 08 Aug 2023 16:34:33.301 # Configuration loaded
  6. [root@localhost redis-5.0.8]# netstat -anput |grep redis
  7. tcp 0 0 127.0.0.1:6379 0.0.0.0:* LISTEN 8922/redis-server 1

2.yum安装

1.和编译安装一样配置环境

2.安装epel源前需要去看看我们的yum如下图所示,yum -y install epel-release

  1. [root@localhost yum.repos.d]# ls
  2. back CentOS-Media.repo
  3. CentOS-Base.repo CentOS-Sources.repo
  4. CentOS-CR.repo CentOS-Vault.repo
  5. CentOS-Debuginfo.repo CentOS-x86_64-kernel.repo
  6. CentOS-fasttrack.repo
  7. [root@localhost yum.repos.d]# yum -y install epel-release
  8. 已加载插件:fastestmirror, langpacks
  9. Loading mirror speeds from cached hostfile
  10. * base: mirrors.bfsu.edu.cn
  11. * extras: mirrors.ustc.edu.cn
  12. * updates: mirrors.bfsu.edu.cn
  13. base | 3.6 kB 00:00
  14. extras | 2.9 kB 00:00
  15. updates | 2.9 kB 00:00
  16. (1/4): base/7/x86_64/group_gz | 153 kB 00:00
  17. (2/4): extras/7/x86_64/primary_db | 250 kB 00:00
  18. (3/4): base/7/x86_64/primary_db | 6.1 MB 00:05
  19. (4/4): updates/7/x86_64/primary_db | 22 MB 00:10
  20. 正在解决依赖关系
  21. --> 正在检查事务
  22. ---> 软件包 epel-release.noarch.0.7-11 将被 安装
  23. --> 解决依赖关系完成
  24. 依赖关系解决
  25. ==============================================================
  26. Package 架构 版本 源 大小
  27. ==============================================================
  28. 正在安装:
  29. epel-release noarch 7-11 extras 15 k
  30. 事务概要
  31. ==============================================================
  32. 安装 1 软件包
  33. 总下载量:15 k
  34. 安装大小:24 k
  35. Downloading packages:
  36. 警告:/var/cache/yum/x86_64/7/extras/packages/epel-release-7-11.noarch.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID f4a80eb5: NOKEY
  37. epel-release-7-11.noarch.rpm 的公钥尚未安装
  38. epel-release-7-11.noarch.rpm | 15 kB 00:00
  39. file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7 检索密钥
  40. 导入 GPG key 0xF4A80EB5:
  41. 用户ID : "CentOS-7 Key (CentOS 7 Official Signing Key) <security@centos.org>"
  42. 指纹 : 6341 ab27 53d7 8a78 a7c2 7bb1 24c6 a8a7 f4a8 0eb5
  43. 软件包 : centos-release-7-9.2009.0.el7.centos.x86_64 (@anaconda)
  44. 来自 : /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
  45. Running transaction check
  46. Running transaction test
  47. Transaction test succeeded
  48. Running transaction
  49. 正在安装 : epel-release-7-11.noarch 1/1
  50. 验证中 : epel-release-7-11.noarch 1/1
  51. 已安装:
  52. epel-release.noarch 0:7-11
  53. 完毕!
  54. [root@localhost yum.repos.d]#

安装yum -y install redis

  1. [root@localhost yum.repos.d]# yum -y install redis
  2. 已加载插件:fastestmirror, langpacks
  3. Loading mirror speeds from cached hostfile
  4. epel/x86_64/metalink | 5.9 kB 00:00
  5. * base: mirrors.bfsu.edu.cn
  6. * epel: mirrors.bfsu.edu.cn
  7. * extras: mirrors.huaweicloud.com
  8. * updates: mirrors.bfsu.edu.cn
  9. epel | 4.7 kB 00:00
  10. (1/3): epel/x86_64/group_gz | 99 kB 00:00
  11. (2/3): epel/x86_64/updateinfo | 1.0 MB 00:00
  12. (3/3): epel/x86_64/primary_db | 7.0 MB 00:03
  13. 正在解决依赖关系
  14. --> 正在检查事务
  15. ---> 软件包 redis.x86_64.0.3.2.12-2.el7 将被 安装
  16. --> 正在处理依赖关系 libjemalloc.so.1()(64bit),它被软件包 redis-3.2.12-2.el7.x86_64 需要
  17. --> 正在检查事务
  18. ---> 软件包 jemalloc.x86_64.0.3.6.0-1.el7 将被 安装
  19. --> 解决依赖关系完成
  20. 依赖关系解决
  21. ==============================================================
  22. Package 架构 版本 源 大小
  23. ==============================================================
  24. 正在安装:
  25. redis x86_64 3.2.12-2.el7 epel 544 k
  26. 为依赖而安装:
  27. jemalloc x86_64 3.6.0-1.el7 epel 105 k
  28. 事务概要
  29. ==============================================================
  30. 安装 1 软件包 (+1 依赖软件包)
  31. 总下载量:648 k
  32. 安装大小:1.7 M
  33. Downloading packages:
  34. 警告:/var/cache/yum/x86_64/7/epel/packages/jemalloc-3.6.0-1.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID 352c64e5: NOKEY
  35. jemalloc-3.6.0-1.el7.x86_64.rpm 的公钥尚未安装
  36. (1/2): jemalloc-3.6.0-1.el7.x86_64.rpm | 105 kB 00:00
  37. (2/2): redis-3.2.12-2.el7.x86_64.rpm | 544 kB 00:00
  38. --------------------------------------------------------------
  39. 总计 686 kB/s | 648 kB 00:00
  40. file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-7 检索密钥
  41. 导入 GPG key 0x352C64E5:
  42. 用户ID : "Fedora EPEL (7) <epel@fedoraproject.org>"
  43. 指纹 : 91e9 7d7c 4a5e 96f1 7f3e 888f 6a2f aea2 352c 64e5
  44. 软件包 : epel-release-7-11.noarch (@extras)
  45. 来自 : /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-7
  46. Running transaction check
  47. Running transaction test
  48. Transaction test succeeded
  49. Running transaction
  50. 正在安装 : jemalloc-3.6.0-1.el7.x86_64 1/2
  51. 正在安装 : redis-3.2.12-2.el7.x86_64 2/2
  52. 验证中 : redis-3.2.12-2.el7.x86_64 1/2
  53. 验证中 : jemalloc-3.6.0-1.el7.x86_64 2/2
  54. 已安装:
  55. redis.x86_64 0:3.2.12-2.el7
  56. 作为依赖被安装:
  57. jemalloc.x86_64 0:3.6.0-1.el7
  58. 完毕!

3.启动systemctl start redis

  1. [root@localhost yum.repos.d]# systemctl start redis
  2. [root@localhost yum.repos.d]# netstat -anput |grep redis
  3. tcp 0 0 127.0.0.1:6379 0.0.0.0:* LISTEN 9483/redis-server 1
  4. [root@localhost yum.repos.d]#

三、Redis的目录结构

/var/lib/redis 持久化文件存储目录

/var/log/redis

日志文件存储目录
/var/run/redis PID文件存储目录
    /etc/redis.conf主配置文件 
 bind 127.0.0.1修改监听地址
port 6379修改监听端口号
pidfile 指定通过该配置文件启动reids进程后的PID文件名称
 loglevel定义日志级别
 logfile定义日志存储路径
 databases 指定默认数据库数量
save定义单位时间内key的改变次数
dbfilename定义存储RDB持久化数据的文件名称
dir定义RDB与AOF文件的存储目录
appendonly AOF的启停

appendfilename

定义AOF持久化文件的名称
 appendfsync定义AOF数据同步间隔
 requirepass设置登录redis的密码

 

四、基础命令解析

redis-server redis启动命令
redis-cli

redis登录命令

-h:    redis服务器IP

-p:    指定访问端口号

-a:    指定登录密码

-n:    指定数据库编号

redis-check-rdb 检查RDB文件
redis-check-aof 检查AOF文件

五、在一台服务器上启动多个redis

1.列如我是采用yum的方式安装的redis,直接使用systectl start redis启动

  1. [root@localhost yum.repos.d]# systemctl start redis
  2. [root@localhost yum.repos.d]#
  3. [root@localhost yum.repos.d]# netstat -anput |grep redis
  4. tcp 0 0 127.0.0.1:6379 0.0.0.0:* LISTEN 10942/redis-server
  5. [root@localhost yum.repos.d]#

2.接下来将redis的主配置文件复制到/opt目录下(可以以端口号命名,方便操作)

  1. [root@localhost redis-5.0.8]# ls
  2. 00-RELEASENOTES dump.rdb redis.conf sentinel.conf
  3. BUGS INSTALL runtest src
  4. CONTRIBUTING Makefile runtest-cluster tests
  5. COPYING MANIFESTO runtest-moduleapi utils
  6. deps README.md runtest-sentinel
  7. [root@localhost redis-5.0.8]# cp redis.conf /opt/redis_6380.conf
  8. [root@localhost redis-5.0.8]# cd /opt/
  9. [root@localhost opt]# ls
  10. redis_6380.conf rh

3.来到/opt目录在redis的配置文件中修改redis的端口vim /redis_6380.conf

4.启动端口号为6380的redis并且验证服务是否启动

  1. [root@localhost opt]# redis-server /opt/redis_6380.conf
  2. 11126:C 08 Aug 2023 18:25:18.898 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
  3. 11126:C 08 Aug 2023 18:25:18.898 # Redis version=5.0.8, bits=64, commit=00000000, modified=0, pid=11126, just started
  4. 11126:C 08 Aug 2023 18:25:18.898 # Configuration loaded
  5. [root@localhost opt]# netstat -anput |grep redis
  6. tcp 0 0 127.0.0.1:6379 0.0.0.0:* LISTEN 10942/redis-server
  7. tcp 0 0 127.0.0.1:6380 0.0.0.0:* LISTEN 11127/redis-server
  8. [root@localhost opt]#

5.按照此方法可以启动多个redis

六、数据库的基本操作

(一)登录数据库
本地登录

监听回环地址           redis-cli

监听本地网卡地址    redis-cli -h IP - 端口号

远程登录redis-cli -h IP -p 端口号

1、本地登录  redis-cli

2、远程登录 (这里我们需要2台主机并且都安装redis),我想用主机2登录主机1

在主机1的配置文件中修改bind监听地址为主机1的IP,并且设置一个密码,重启服务

: 

 在主机2上远程登录1命令redis-cli -h 192.168.73.10 -p 6379之后输入我们在主机1上设置的密码

  1. [root@localhost redis-5.0.8]# redis-cli -h 192.168.73.10 -p 6379
  2. 192.168.73.10:6379> set k1 v1
  3. (error) NOAUTH Authentication required.
  4. 192.168.73.10:6379> auth 123.com
  5. OK
(二)基础命令

在redis中我们可以使用帮助信息 help 命令字  、tab补齐

库操作: 切换  select 数据库编号

set 设置键值对 set key value

keys * 查看所有键的名称
keys 键名称   查看一个键是否存在

get 取出键值对
get 键       键不存在则返回空

del 删除键值对

 flushall  清空所有数据库中的数据(慎用)

rename 重命名键名称

不论更名后的键是否存在都会覆盖原有键,并将改名前的键的值赋予改名后的键
rename oldkey newkey

 renamenx  重命名键名称
 假如改名后键名称存在则更改不成功
 renamenx oldkey newkey

move
    移动键值对到指定数据库
    move key dbnumber
    假如目标数据库中存在同名键则移动失败

 ttl查看键值对的生命周期
 ttl key   (-1 永久-2已过期)

expire
    设置键值对的存储周期
    expire key seconds

七、Redis持久化

Redis的持久化原理主要包括两种方式:RDB持久化和AOF持久化。

(一)RDB持久化


RDB持久化:RDB持久化是通过将Redis的数据集快照保存到硬盘上的一个二进制文件中实现的。当执行RDB持久化时,Redis会fork一个子进程来处理久化工作,该子进程会将当前数据集的副本保存到一个临时文件中,待保存完成后,再替换原来的RDB文件。RDB持久化的优点是可以生成一个紧凑的二进制文件,适合用于备份和恢复数据。缺点是在发生故障时,可能会丢失最后一次持久化后的数据。

RDB模式  默认持久化
dump.rdb数据库启动时会读取
触发条件:redis进程退出、宕机、redis程序崩溃
手动保存(触发RDB)    save

在配置文件中我们可以看到dump.rdp

  1. [root@localhost redis-5.0.8]# ls
  2. 00-RELEASENOTES dump.rdb redis.conf sentinel.conf
  3. BUGS INSTALL runtest src
  4. CONTRIBUTING Makefile runtest-cluster tests
  5. COPYING MANIFESTO runtest-moduleapi utils
  6. deps README.md runtest-sentinel

dump.rdp中存储着我们库里的数据,会自动记录,也可以通过save命令手动触发。

(二)AOF持久化

AOF持久化:AOF持久化是通过将Redis的操作日志追加到一个文件中实现的。当执行AOF持久化时,Redis会将每个写操作(包括读操作)以类似于写日志的方式追加到AOF文件的末尾。当Redis重启时,会重新执行AOF文件中的操作日志来恢复数据集的状态。AOF持久化的优点是可以提供更好的数据安全性,因为操作日志可以追加到文件中,避免数据丢失。缺点是AOF文件通常比RDB文件大,并且恢复数据集的速度比RDB持久化慢。

 AOF模式AOF模式
appendonly.aof默认进程启动时读取
开启appendonly  yes   可以与RDB同时使用

在配置文件redis.conf中手动开启此功能,保存退出,重启服务

 此时查看配置文件就会出现新生成的文件,里面会记录我们在数据库的操作与MySQL的二进制文件有些类似

我们查一下里面的内容

 我们去数据库进行一些操作后再来看此文件

在Redis的配置文件中,可以通过设置"save"选项来控制RDB持久化的频率,通过设置"appendonly"选项来启用AOF持久化。此外,Redis还支持将RDB持久化和AOF持久化结合使用,以提供更好的数据安全性和恢复速度。


总结

今天很高兴和大家分享这些内容,今天主要是要对我们redis的安装进行一个操作,对于主配置文件来说是要记忆的,很多功能需要从中开启,最后要了解持久化的原理。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/402426
推荐阅读
相关标签
  

闽ICP备14008679号