NoSQL与Memcached、Redis、MongoDB概述

一、NoSQL介绍

非关系型数据库(而mysql、oracle、sqlserver都是关系型数据库)

1. 特点

  • 数据之间无关系,随意扩展
  • 数据存储简单,可以存在内存中,读写速度快
  • 不需要建表、字段。自定义格式

2. 分类

A. 键值(Key-Value)数据库:redis、memcached、riak

redis/memcached 适合存储用户信息,比如会话、配置文件、参数、购物车等,这些信息一般和ID(键)挂钩

B. 面向文档(Document-Oriented)数据库:MongoDB、CouchDB、RavenDB

MongoDB将数据以文档形式存储,每个文档都是一系列数据项的集合,每个数据项都有一个名称与对应的值,值既可以是简单的数据类型,如文字、字符串、数字和日期等,也可以是复杂的类型,如有序列表和关联对象。数据存储的最小单位是文档,同一个表中存储的文档属性可以是不同的,数据可以使用XML、JSON或JSONB等多种形式

C. 列存储(Wide Column Store/Column-Family)数据库:Cassandra、HBase

D. 图(Graph-Oriented)数据库:Neo4J、Infinite Graph、OrientDB

二、Memcached介绍

国外Live Journal团队开发,通过缓存数据库查询结果,减少数据库的访问次数(写入减少不了),从而提高动态Web站点性能。数据存在内存中,重启服务器即数据消失

1. 特点

  • 基于c/s架构,协议简单
  • 基于libevent的事件处理
  • 自主内存存储处理(slab allocation)
  • 数据过期方式:Lazv Expiration和LRU

2. Memcationed流程图

3. Slab allocation原理

  • 将分配的内存分割成各种尺寸的块(chunk),把尺寸相同的分成组,即chunk的集合,每个集合称为slab
  • Memcached的内存分配以Page为单位,Page默认值为1M,可以在启动时通过参数-l来指定
  • Slab由多个Page组成

一个Chunk最大不能超过1M,即一个Page

一个Slab可能有多个Page

原理图:

4. Growth factor

Memcached在启动时可以通过-f参数可以指定Growth Factor因子(即Chunk之间的的增长比例),默认为1.25,通过memcached-tool 可以查看指定的memcached实际的不同slab状态

命令:memcached-tool 127.0.0.1:11211 display

5. Memcached数据过期方式

  • Lazy Expiration:memcached内部不会监视是否过期,而是get时查看记录的时间戳,检查记录是否过期。这种技术称为lazy expiration。优点:memcached不会在过期监视上耗费CPU时间
  • LRU:memcached优先使用已超时的记录空间,会发生追加新记录空间不足的情况。从最近未被使用的记录中搜索,并将其空间分配给新的记录(即删除最近使用最少的记录的机制)。从缓存的使用角度看,该模型很理想

三、Redis介绍

属于key-value存储系统,和memcached相似,但是支持数据持久化(重启服务器,数据还是存在)

A. value类型:

string、hash、lists(链表)、sets(集合)、sorted sets(有序集合)

B. 文件格式:

RDB(全量数据)把内存中的数据写入磁盘,下次读取文件时,进行加载

aof(增量请求)内存中的数据有序化为操作请求,用于读取文件进行replay得到数据,相当于mysql的二进制日志

C. 存储方式:

内存存储、磁盘存储、log文件

四、MongoDB介绍

  • 由C++语言编写,是一套基于分布式文件存储的开源数据库系统,属于NoSQL
  • 高负载的情况下,可以添加更多的节点,保证服务器性能
  • 旨在为Web应用提供可扩展的高性能数据存储解决方案
  • 数据存储为一个文档,数据结构由键值对(key=>value)组成,文档类型于JSON对象。字段值可以包含其它文档,数组及文档数组

和关系型数据库对比:

SQL 说明 MongoDB 说明
database 数据库 database 数据库
table collection 集合
row 记录行 document 文档
column 字段 field
index 索引 index 索引
table joins 表连接
primary key 主键 primary 自动将_id字段设置为主键
时间: 2024-10-10 20:32:24

NoSQL与Memcached、Redis、MongoDB概述的相关文章

Memcached, Redis, MongoDB区别

mongodb和memcached不是一个范畴内的东西.mongodb是文档型的非关系型数据库,其优势在于查询功能比较强大,能存储海量数据.mongodb和memcached不存在谁替换谁的问题. 和memcached更为接近的是redis.它们都是内存型数据库,数据保存在内存中,通过tcp直接存取,优势是速度快,并发高,缺点是数据类型有限,查询功能不强,一般用作缓存.在我们团队的项目中,一开始用的是memcached,后来用redis替代. 相比memcached: 1.redis具有持久化机

DockerFile部署lnmp+memcached+redis+mongodb开发环境for Redis(五)

本文源链接地址:https://www.93bok.com 1.下载基础镜像centos docker pull centos:6 2.查看一下大小 docker images REPOSITORY TAG IMAGE ID CREATED SIZE centos 6 70b5d81549ec 2 months ago 195MB 3.创建文件夹存放Redis的Dockerfile,以及源码包等等,为后期docker-compose做准备 mkdir -p /data/docker/lnmp-t

DockerFile部署lnmp+memcached+redis+mongodb开发环境for MongoDB(六)

本文源链接地址:https://www.93bok.com 1.下载基础镜像centos docker pull centos:6 2.查看一下大小 docker images REPOSITORY TAG IMAGE ID CREATED SIZE centos 6 70b5d81549ec 2 months ago 195MB 3.创建文件夹存放Mongodb的Dockerfile,以及源码包等等,为后期docker-compose做准备 mkdir -p /data/docker/lnmp

Memcached, Redis, MongoDB区别、特点、使用场景

https://blog.csdn.net/qq_37968902/article/details/79190440 https://my.oschina.net/liyurong/blog/1921898 https://www.cnblogs.com/timxgb/p/9578254.html 更改它的环境变量,最大并发量,启动服务的用户端口等,在memcached.service内指定的环境变量文件 telnet测试连接memcached 原文地址:https://www.cnblogs.

DockerFile部署lnmp+memcached+redis+mongodb开发环境for PHP(三)

本文源链接地址:https://www.93bok.com 1.下载基础镜像centos docker pull centos:6 2.查看一下大小 docker images REPOSITORY TAG IMAGE ID CREATED SIZE centos 6 70b5d81549ec 2 months ago 195MB 3.创建文件夹存放PHP的Dockerfile,以及源码包等等,为后期docker-compose做准备 mkdir -p /data/docker/lnmp-tes

java高级软件架构师实战视频教程 Spring+Mybatis+SpringMVC+Ehcache+Memcached+Redis+Nginx+Varnish+ActiveMQ+Keepalived+MySQL+MongoDB

java高级软件架构师实战阶段1视频教程 迅雷下载  百度云 第001节:整体课程概览第002节:分模块.分工程管理第003节:多模块多Web应用合并War包第004节:Git基本原理和安装配置使用第005节:TortoiseGit的本地使用第006节:Egit的本地使用第007节:远程使用以及冲突解决第008节:基本业务功能和数据字典第009节:搭建基础的开发环境第010节:Spring+Mybatis实现DAO第011节:Mybatis的分页实现第012节:Service的实现以及模块化第0

redis、memcached、mongoDB 对比与安装

一.redis.memcached.mongoDB 对比 Memcached 和 Redis都是内存型数据库,数据保存在内存中,通过tcp直接存取,速度快,并发高.Mongodb是文档型的非关系型数据库,其优势在于查询功能比较强大,能存储海量数据. Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态.数据库驱动网站的速度.Memcached 的分布式不是在服务器端实现的,而是在客户端应用中

(转)Memcache,Redis,MongoDB(数据缓存系统)方案对比与分析

Memcache,Redis,MongoDB(数据缓存系统)方案对比与分析 数据库表数据量极大(千万条),要求让服务器更加快速地响应用户的需求. 二.解决方案: 1.通过高速服务器Cache缓存数据库数据 2.内存数据库 (这里仅从数据缓存方面考虑,当然,后期可以采用Hadoop+HBase+Hive等分布式存储分析平台) 三.主流解Cache和数据库对比: 上述技术基本上代表了当今在数据存储方面所有的实现方案,其中主要涉及到了普通关系型数据库(MySQL/PostgreSQL),NoSQL数据

nosql数据库之Redis概念及基本操作

一.概述 redis是一种nosql数据库(非关系型数据库),他的数据是保存在内存中,同时redis可以定时把内存数据同步到磁盘,即可以将数据持久化,并且他比memcached支持更多的数据结构(string,list列表[队列和栈],set[集合],sorted set[有序集合],hash(hash表)).相关参考文档:http://redisdoc.com/index.html Redis的持久化 Redis持久化会在磁盘上依赖两个文件(数据文件:rdb:日志文件:aof) redis实现

第一课 MongoDB 概述与安装

1.课程大纲 本次课主要介绍 MongoDB 背景知识和 MongoDB 的安装与配置,让大家对 MongoDB 有一个初认识. 其基本的知识点包含: NoSQL数据库概述 MongoDB 数据库简单介绍 Linux 下安装 MongoDB 数据库 Mac 和 Windows 下安装 MongoDB 数据库 2.课程简单介绍 MongoDB是由MongoDB.inc研发的一款NoSQL类型的文档型数据库,MonogoDB名字来源于英文单词humongous,这个单词的意思是巨大无比.暗喻Mong