【Redis】NoSQL数据库和redis简介

生活中,最使人疲惫的往往不是道路的遥远,而是心中的郁闷;最使人痛苦的往往不是生活的不幸,而是希望的破灭;最使人颓废的往往不是前途的坎坷,而是自信的丧失;最使人绝望的往往不是挫折的打击,而是心灵的死亡。所以我们要有自己的梦想,让梦想的星光指引着我们走出落漠,走出惆怅,带着我们走进自己的理想。

导读:本篇文章讲解 【Redis】NoSQL数据库和redis简介,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

一、NoSQL数据库

1、NoSQL的定义
NoSQL意为Not Only SQL(不仅仅是SQL),泛指非关系型数据库
区别于关系数据库,它并不依赖于业务逻辑来存储有关联的数据,而是以key-value键值对的形式进行数据存储,大大增加了数据库的扩展能力

2、NoSQL数据库的作用

  • 作为缓存使用,提高访问速度,减少IO的读操作
  • 减少CPU和IO的压力,直接通过内存读取数据

3、NoSQL数据库的特点

  • 不遵循SQL的标准
  • 不支持ACID
    A (Atomicity) 原子性
    C (Consistency) 一致性
    I (Isolation) 独立性
    D (Durability) 持久性
  • 远超SQL的性能

4、适用场景

  • 对数据有高并发的读写,例如电商的秒杀操作
  • 需要读写海量的数据
  • 对数据有高可扩展性要求

5、不适用场景

  • 需要事务的支持
  • 基于sql的结构化查询存储,处理复杂的关系,需要即席查询(即席查询(Ad Hoc)是用户根据自己的需求,灵活的选择查询条件)

6、常见NoSQL数据库

  • Redis
  • MongoDB

二、redis数据库简介

1、概念
redis是一种开源的key-value存储系统
它存储的value支持五种数据格式:包括string(字符串)、list(列表)、set(集合)、zset(sort set,有序集合)和hash(哈希类型)

2、redis可以把数据存储在内存中,也可以周期性地把数据写入到磁盘中(持久化),另外还实现了master-slave(主从)同步

3、redis有16个数据库,类似于数组的下标,默认使用0号库
我们可以通过select 15来切换到第16个库,所有的库密码相同

与memcached的差别:

  • memcached支持单一类型,redis支持多种数据类型
  • memcached不能像redis一样支持持久化
  • memcached使用多线程+锁的机制,redis使用单线程+多路IO复用的技术

4、安装redis与简单使用
进入redis官网:下载地址
找到稳定的最新版redis,下载到本地,然后将压缩包上传到Linux虚拟机中,然后开始我们的安装

  • 安装C语言编译环境,使用命令
    yum install gcc
    安装完成之后,使用命令查看gcc版本
    gcc --version
    在这里插入图片描述

  • 使用解压命令将压缩包解压到指定路径
    在这里插入图片描述
    注意 这里要有一个-C这个参数,否则可能会出现Not found in archive这个错误
    在这里插入图片描述

  • 使用make命令进行编译
    在这里插入图片描述

  • 使用make PREFIX=xxx(指定路径) install命令进行安装
    在这里插入图片描述

  • 进入安装目录的bin路径下进行查看
    reids-benchmark:性能测试工具
    redis-check-aof:修复有问题的aof文件
    redis-check-dump:修复有问题的dump.rdb
    redis-sentinel:redis集群使用
    redis-server:redis服务器启动命令
    redis-cli:redis客户端

  • 尝试前台启动redis(不推荐,因为退出后redis服务端也会关闭)
    如果遇到报错
    在这里插入图片描述
    这时候就要输入命令,建立一个/usr/bin/redis-server到/opt/decade/redis/bin/redis-server的软链接,你在运行/usr/bin/redis-server的时候就是在运行/opt/decade/redis/bin/redis-server
    ln -s /opt/decade/redis/bin/redis-server /usr/bin/redis-server
    就可以正常启动redis了
    在这里插入图片描述

  • 尝试后台启动redis
    首先我们将redis解压目录下的redis.conf复制一份放到某个路径下,我这里是/opt/decade/
    cp redis.conf /opt/decade/redis.conf
    使用vi redis.conf修改复制出来的那个redis.conf,调整daemonize配置项,由NO改为YES(输入vi redis之后,可以使用/要查找的内容来快速找到要找的内容)
    daemonize是用来指定redis是否要用守护线程的方式启动,这样一来redis就会在后台运行了
    在这里插入图片描述
    然后我们回到redis的安装目录,使用指定的配置文件启动redis,可以看到,redis在后台运行了
    在这里插入图片描述

  • 尝试启动客户端
    使用redis-cli命令启动客户端在这里插入图片描述

  • 关闭redis
    直接使用kill -9 redis进程号
    在客户端输入shutdown
    使用redis-cli shutdown
    使用redis-cli -p redis端口号 shutdown
    在这里插入图片描述

如有错误,欢迎指正!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/136755.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!