什么是NoSQL
非关系型数据库就是NoSQL ,关系型数据库代表MySQL
对于关系型数据库来说,是需要把数据存储到库、表、行、字段里,查询的时候根据条件一行行地去匹配 ,当量非常 大的时候就很耗费时间和资源,尤其是数据是需要从磁盘里去检索
NoSQL数据库存储原理非常简单(典型的数据类型为k-v ),不存在繁杂的关系链,比如mysq查询的时候,需要找到对应的库、表(通常是多个表)以及字段。
NoSQL数据是可以存储在内存里,从内存中查询数据速度会非常快
NoSQL在性能表现上虽然能优于关系型数据库,但是它并不能完全替代关系型数据库
NoSQL因为没有复杂的数据结构,扩展非常容易,支持分布式
k-v形式的: memcached、t redis适合储存用户信息,比如会话、配置文件、参数、购物车等等。这些信息一般都和ID(键)挂钩,这种情景下键值数据库是个很好的选择。。
文档数据库: mongodb 将数据以文档的形式储存。每个文档都是一系列数据项的集合。每个数据项都有一个名称与对应的值,值既可以是简单的数据类型, 如字符串、数字和日期等;也可以是复杂的类型,如有序列表和关联对象。数据存储的最小单位是文档,同一个表中存储的文档属性可以是不同的,数据可以使用XML、JSON或者JSONB等多种形式存储。
列存储 Hbase
图Neo4J、 Infinite Graph、OrientDB
memcached介绍
memcached对数据查询结果进行缓存,减少对关系型数据库访问,加速数据请求结果的反馈响应
数据存放在内存中,因为数据是存在内存当中的,如果一旦关机或断电等意外操作,会造成数据丢失,为了避免这种情况发生。需要对memcachd的数据做持久化存储,将数据存入磁盘
多线程服务处理请求,多cpu的服务器架构处理数据会很快
memcached基于c/s架构,协议简单。由一个客户端来链接服务端来存储数据
memcached基于libevent的事件处理(nginx也是基于libevent方式的)
libevent事件处理,自主内存存储处理(slab allocation)
Slab Allocation原理
将分配的内存分割成各种尺寸的块(chunk),并把尺寸相同的块分成组(chunk的集合),每个chunk集合被称为slab
Memcached的内存分配以Page为单位,Page默认值为1MB,可以在启动时通过-I参数来指定
Slab是由多个Page组成,Page按照指定大小切割成多个chunk
Griwth factor(增长因子)指定控制chunk的大小差异,在启动时使用-f来指定。默认值为1.25
数据过期方式
Lazy Expiration
Memcached内部不会监视记录是否过期,而是在get时查看记录的时间戳,检查记录是否过期。这种技术被称为lazy (惰性) expiration。 因此,Memcached不会在过期监视上耗费CPU时间。
LRU
Memcached会优先使用已超时的记录的空间, 但即使如此,也会发生追加新记录时空间不足的情况,此时就要使用名为LeastRecentlyUsed (LRU)机制来分配空间。顾名思义,这是删除“最近最少使用”的记录的机制。因此,当内存空间不足时( 无法从slab class获取到新的空间时),就从最近未被使用的记录中搜索,并将其空间分配给新的记录。从缓存的实用角度来看,这是非常理想的存储方式。
数据流请求关系
用户第一次请求会直接访问数据库内容,memcached同时缓存这次请求的结果,当用户下次访问请求时,再次使用该数据memcached会直接从缓存中向客户端发送结果
安装memcached
memcached我们可以使用yum来进行安装,如果需要使用更新的版本功能则需要官网下载编译安装包来安装
memcached依赖libevent这个依赖包,如果没有安装可以主动安装或在安装memcached时会自动安装上
[root@localhost ~]# yum list |grep memcached
libmemcached.i686 1.0.16-5.el7 base
libmemcached.x86_64 1.0.16-5.el7 base
libmemcached-devel.i686 1.0.16-5.el7 base
libmemcached-devel.x86_64 1.0.16-5.el7 base
memcached.x86_64 1.4.15-10.el7_3.1 base
memcached-devel.i686 1.4.15-10.el7_3.1 base
memcached-devel.x86_64 1.4.15-10.el7_3.1 base
opensips-memcached.x86_64 1.10.5-3.el7 epel
php-ZendFramework-Cache-Backend-Libmemcached.noarch
php-pecl-memcached.x86_64 2.2.0-1.el7 epel
python-memcached.noarch 1.48-4.el7 base
uwsgi-router-memcached.x86_64 2.0.17.1-1.el7 epel
[root@localhost ~]# rpm -qa libevent
libevent-2.0.21-4.el7.x86_64
[root@localhost ~]# yum install -y memcached
Loaded plugins: fastestmirror
base | 3.6 kB 00:00:00
epel/x86_64/metalink | 4.8 kB 00:00:00
epel | 3.2 kB 00:00:00
extras
省略-------------------
Running transaction
Installing : memcached-1.4.15-10.el7_3.1.x86_64 1/1
Verifying : memcached-1.4.15-10.el7_3.1.x86_64 1/1
Installed:
memcached.x86_64 0:1.4.15-10.el7_3.1
Complete!
定义memcached的启动配置参数
可以在memcached启动时来指定参数,可以在启动时指定这些配置。
查看memcached的进程,并了解memcached启动信息
-u是指定运行服务的用户,-p是监听的端口,-m预分配内存大小,-c最大产生进程数量
[root@localhost ~]# ps -aux |grep memcached
memcach+ 28555 0.0 0.0 344084 1672 ? Ssl 16:39 0:00 /usr/bin/memcached -u memcached -p 11211 -m 64 -c 1024
另一种方式指定memcached的启动参数配置,需要编辑/etc/sysconfig/memcached这个配置文件
PORT指定监听端口
USER指定运行用户
MAXCONN指定最大进程数
CACHESIZE指定启动时分配的内存使用量大小
OPTIONS指定主机,可以在启动时使用-I选项指定监听ip,更多选项可以使用memcached -h来查看参数帮助
[root@localhost ~]# vim /etc/sysconfig/memcached
PORT="11211"
USER="memcached"
MAXCONN="1024"
CACHESIZE="64"
OPTIONS=""
查看memcached的工作状态
使用memcached自带工具查看运行状态
curr_time是缓存的项目数,get_hits是查询的命中数,使用命中数除以项目数可以得出memcached的命中率
[root@localhost ~]# memcached-tool 127.0.0.1:11211 stats
#127.0.0.1:11211 Field Value
accepting_conns 1
auth_cmds 0
auth_errors 0
bytes 0
bytes_read 7
bytes_written 0
cas_badval 0
cas_hits 0
cas_misses 0
cmd_flush 0
cmd_get 0
cmd_set 0
cmd_touch 0
conn_yields 0
connection_structures 11
curr_connections 10
curr_items 0 存储项目数
decr_hits 0
decr_misses 0
delete_hits 0
delete_misses 0
evicted_unfetched 0
evictions 0
expired_unfetched 0
get_hits 0 命中查询
get_misses 0
hash_bytes 524288
hash_is_expanding 0
hash_power_level 16
incr_hits 0
incr_misses 0
libevent 2.0.21-stable
limit_maxbytes 67108864
listen_disabled_num 0
pid 28555
pointer_size 64
reclaimed 0
reserved_fds 20
rusage_system 0.018183
rusage_user 0.036366
threads 4
time 1538989698
total_connections 11
total_items 0
touch_hits 0
touch_misses 0
uptime 1759
version 1.4.15
使用nc命令来查看memcached服务状态
nc命令默认不会安装在系统中,需要我们进行yum安装,nc命令的包名为nmap-ncat
安装nc命令
[root@localhost ~]# yum install nmap-ncat
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
* epel: mirrors.tuna.tsinghua.edu.cn
Resolving Dependencies
--> Running transaction check
---> Package nmap-ncat.x86_64 2:6.40-13.el7 will be installed
--> Finished Dependency Resolution
Dependencies Resolved
----------------------------省略
Running transaction
Installing : 2:nmap-ncat-6.40-13.el7.x86_64 1/1
Verifying : 2:nmap-ncat-6.40-13.el7.x86_64 1/1
Installed:
nmap-ncat.x86_64 2:6.40-13.el7
Complete!
使用echo过滤出nc的stats状态的输出内容
使用nc命令我们也可以查找出memcached存储和查询的数量相关状态信息
[root@localhost ~]# echo stats |nc 127.0.0.1 11211
STAT pid 28555
STAT uptime 2144
STAT time 1538990083
STAT version 1.4.15
STAT libevent 2.0.21-stable
STAT pointer_size 64
STAT rusage_user 0.043580
STAT rusage_system 0.021790
STAT curr_connections 10
STAT total_connections 12
STAT connection_structures 11
STAT reserved_fds 20
STAT cmd_get 0
STAT cmd_set 0
STAT cmd_flush 0
STAT cmd_touch 0
STAT get_hits 0 命中查询数
STAT get_misses 0
STAT delete_misses 0
STAT delete_hits 0
STAT incr_misses 0
STAT incr_hits 0
STAT decr_misses 0
STAT decr_hits 0
STAT cas_misses 0
STAT cas_hits 0
STAT cas_badval 0
STAT touch_hits 0
STAT touch_misses 0
STAT auth_cmds 0
STAT auth_errors 0
STAT bytes_read 13
STAT bytes_written 1026
STAT limit_maxbytes 67108864
STAT accepting_conns 1
STAT listen_disabled_num 0
STAT threads 4
STAT conn_yields 0
STAT hash_power_level 16
STAT hash_bytes 524288
STAT hash_is_expanding 0
STAT bytes 0
STAT curr_items 0 项目缓存数
STAT total_items 0
STAT expired_unfetched 0
STAT evicted_unfetched 0
STAT evictions 0
STAT reclaimed 0
END
使用memstat命令工具查看memcached的状态信息
使用memstat命令需要安装一个安装包才能正常使用,安装包名为libmamcached,若安装了则不需要再次进行安装(安装memcached时已经安装过了的)
使用memstat命令也可以查看到memcached的运行状态信息
[root@localhost ~]# memstat --servers=127.0.0.1:11211
Server: 127.0.0.1 (11211)
pid: 28555
uptime: 2522
time: 1538990461
version: 1.4.15
libevent: 2.0.21-stable
pointer_size: 64
rusage_user: 0.053708
rusage_system: 0.021790
curr_connections: 10
total_connections: 13
connection_structures: 11
reserved_fds: 20
cmd_get: 0
cmd_set: 0
cmd_flush: 0
cmd_touch: 0
get_hits: 0 命中查询数
get_misses: 0
delete_misses: 0
delete_hits: 0
incr_misses: 0
incr_hits: 0
decr_misses: 0
decr_hits: 0
cas_misses: 0
cas_hits: 0
cas_badval: 0
touch_hits: 0
touch_misses: 0
auth_cmds: 0
auth_errors: 0
bytes_read: 30
bytes_written: 2072
limit_maxbytes: 67108864
accepting_conns: 1
listen_disabled_num: 0
threads: 4
conn_yields: 0
hash_power_level: 16
hash_bytes: 524288
hash_is_expanding: 0
bytes: 0
curr_items: 0 项目缓存数
total_items: 0
expired_unfetched: 0
evicted_unfetched: 0
evictions: 0
reclaimed: 0
memcached数据导出和应用请看我后续笔记内容