一.NoSql数据库(Not Only Sql):

  1.又称为非关系型数据库,主流的NoSql数据库有:

    Redis,Hbase,MongoDB

  2.NoSql产生的背景:

    1.1.数据库的高并发的读写:

      比如在双十一期间,那时的并发量就及其的高

    1.2.海量数据的效率:

      哪怕是加上索引,分区,关系型数据库的效率也是力不从心(几十亿条,甚至几百亿条数据时候)

    1.3.高扩展和可用性:

      使用分布式的时候,关系型的数据库扩展性就不行了

  3.它和关系型数据库的区别:

    01.不支持事务的ACDI特性

    02.不需要实时的读写

    03.不支持sql语句

    04.出道时间短,其所涵盖的功能并不是很完善

    05.基于分布式,扩展方便

    06.无需sql解析,读写效率更高

    07.降低服务器成本

    08.存储数据的格式是key,value 数据类型灵活

    09.数据没有耦合性,容易扩展

  4.CAP定理

    1.1 定理的概念:

      指的是在一个分布式系统中,Consistency(一致性)、Availability(可用性),Paretion tolerance(分区容错性)

    ***三者不可共存***

    1.2.CAP定理是NoSql数据库的基石

      一致性(C):在分布式系统中的所有数据备份,在同一时刻是否同样的值。

      可用性(A):在集群中一部分节点故障后,集群整体是否还能响应客户端的读写请求。

      分区容错性(P):在网络分区的前提下,保证数据的容错机制!意味着发生了分区的情况,必须就当前操作在C和A之间做出选择。

    1.3.三者不可能共存,最大只能满足两个

      CA:一致性(C)可用性(A)
        让我们想起来了 关系型数据库中事务的ACID特性
          满足者:关系型数据库

      CP:一致性(C)分区容错性(P)
          满足者:分布式数据库

      AP:可用性(A) 分区容错性(P)
          满足者:NoSql

      1.4..什么是分布式数据库

      分布式数据库系统通常使用较小的计算机系统,每台计算机可单独放在一个地方,每台计算机中都可能有DBMS的一份完整拷贝副本,或者部分拷贝副本,并具有自己局部的数据库,位于不同地点的许多计算机通过网络互相连接,共同组成一个完整的、全局的逻辑上集中、物理上分布的大型数据库。

    1.5:BASE定理

      1.什么是BASE定理

        BASE定理就是为了解决关系数据库强一致性引起的问题而引起的可用性降低而提出的解决方案。

       2.组成部分

        基本可用(Basically Available)可用性的要求不是很高!

        软状态(Soft state)数据不需要实时的保持一致!

          比如说1台机器做了修改,其他并不要求实时进行同步更新!

          最终一致(Eventually consistent)数据最终保持一致即可!

二:初识Redis

  2.1.Redis介绍

    1.开源的NoSql数据库

    2.C语言编写

    3.基于内存运行,并且支持持久化

    4.Key value存储

    5.是主流的Nosql数据库之一

  2.2.Redis优点

    1.内存使用方便

    2.数据读写快速高效

    3.持久化性能相比其他NoSql数据库更好

    4.扩展性和移植性强

    5.分布式中不可或缺的一员

  2.3:Redis的安装

    在解压之前,让我们先了解一些关于linux的解/压缩命令

                    tar

                 -c: 建立压缩档案
                 -x:解压
                 -t:查看内容
                 -r:向压缩归档文件末尾追加文件
                 -u:更新原压缩包中的文件

      这五个是独立的命令,压缩解压都要用到其中一个,可以和别的命令连用但只能用其中一个。下面的参数是根据需要在压缩或解压档案时可选的。

                 -z:有gzip属性的
                 -j:有bz2属性的
                 -Z:有compress属性的
                 -v:显示所有过程
                 -O:将文件解开到标准输出                 

                 -f: 使用档案名字,(切记,这个参数是最后一个参数,后面只能接档案名)

    01. 把从官网上下载的 redis-3.2.10.tar.gz 通过 xftp上传到linux操作系统中的指定位置

    02. tar  -zxvf  redis-3.2.10.tar.gz 解压到文件中去

    03.解压完后,进入解压出来的文件夹后 输出  make

    04. 安装 make install  PREFIX="安装路径"

    05. 如果在安装的位置看到一个bin目录 说明安装成功了

      如果make指令报错

      make[1]: 进入目录“/software/redis-3.2.10/src”

          CC adlist.o

       /bin/sh: cc: 未找到命令

      make[1]: *** [adlist.o] 错误 127

      make[1]: 离开目录“/software/redis-3.2.10/src”

      make: *** [all] 错误 2

    这个问题是:缺少c++组件

    执行:yum install gcc-c++ (后面一直y就好)

    ***1.如果yum安装过程中出现镜像的问题

          解决办法:

    1. 清空自带的yum源: rm -rf /etc/yum.repos.d/*

     2. 创建本地yum源:vim /etc/yum.repos.d/xx.repo(后缀名必须是以 repo结尾的,xx是文件名,自拟!)

     3. 编辑文件xx.repo

[local]

name=local

baseurl=file:///mnt

gpgcheck=

     4. 挂载光盘

      光盘的挂载点必须是  上面的baseurl

        mount  /dev/cdrom   /mnt/

        只有挂载只有才有 /mnt/目录

    5. 实现永久挂载光盘

      vim /etc/fstab

      在文件中的最后一行输入

      /dev/cdrom     /mnt iso9660 defaults 0  0

    6. 让文件立即生效

      mount -a

    7. 可以使用yum了~~~~~

      ***2.如果遇到   CC adlist.o

      In file included from adlist.c:34:0:

    zmalloc.h:50:31: 致命错误:jemalloc/jemalloc.h:没有那个文件或目录

     #include <jemalloc/jemalloc.h>

    解决办法:

      make MALLOC=libc

  2.4:运行redis

    在bin目录下运行指令:./redis-server  ../redis.conf

  2.5:配置redis.conf文件

    在redis-3.2.10这个目录下输入指令:vim redis.conf

初始Redis的更多相关文章

  1. 初始Redis与简单使用

    初始Redis: redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(so ...

  2. 【Redis篇】初始Redis与Redis安装

    一.前述 Redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统.和Memcache类似,但很大程度补偿了Memcache的不足,它支持存储的value类型相对更多,包括st ...

  3. 初始redis数据库

    redis就是一个类似于存储在内存中的大字典 安装: windows下安装redis: 你需要在你的环境下安装: pip install redis 以上是在你的全局环境安装, 你如果用的是虚拟环境你 ...

  4. redis集群之REDIS CLUSTER

    redis集群之REDIS CLUSTER 时间 2016-04-11 17:05:00  NoSQL_博客园 原文  http://www.cnblogs.com/zhanchenjin/p/537 ...

  5. 《Redis开发与运维》读书笔记

    一.初始Redis 1.Redis特性与优点 速度快.redis所有数据都存放于内存:是用C语言实现,更加贴近硬件:使用了单线程架构,避免了多线程竞争问题 基于键值对的数据结构,支持的数据结构丰富.它 ...

  6. redis介绍(3)RDB和AOF原理解析

    简单科普一下redis的概念:(会的可忽略) Redis的概念 redis基于内存的Key Value类型的NoSQL数据库. Redis的特点 1. Redis是一个高性能的Key/Value数据库 ...

  7. Redis开发与运维学习笔记

    <Redis开发与运维>读书笔记   一.初始Redis 1.Redis特性与优点 速度快.redis所有数据都存放于内存:是用C语言实现,更加贴近硬件:使用了单线程架构,避免了多线程竞争 ...

  8. 非关系型数据库redis

    Redis初始 redis中不区分字母的大小写 查看端口 ss tnlp 安装 编译安装(需要先配置epel源) yum install -y redis 编译安装 wget https://down ...

  9. scrapy分布式Spider源码分析及实现过程

    分布式框架scrapy_redis实现了一套完整的组件,其中也实现了spider,RedisSpider是在继承原scrapy的Spider的基础上略有改动,初始URL不在从start_urls列表中 ...

随机推荐

  1. vue前端知识点整理

    1. 说一下Vue的双向绑定数据的原理 vue 实现数据双向绑定主要是:采用数据劫持结合发布者-订阅者模式的方式,通过 Object.defineProperty() 来劫持各个属性的 setter, ...

  2. Metadata GC Threshold导致的full gc分析

    gc log 两次full gc 均是Metadata GC导致, OpenJDK -Bit Server VM ( :: by (Red Hat -) Memory: 4k page, physic ...

  3. sudo: unable to execute ./script.sh: no such file or directory

    I just had this exact problem, it turned out to be a text file encoding problem. For me to fix it wh ...

  4. go get fatal: could not read Username for 'https://code.xxx.org': terminal prompts disabled

    用go get下载私有代码库的时候,莫名其妙产生了以下错误,公有代码库没有影响. chenchideMacBook-Pro:~ chenchi$ go get code.xxx.org/adarch/ ...

  5. 微信小程序——购物车结算

    项目需要做个购物车结算功能,先分析需求: 1.全选,反选的功能.当选中的个数 = 购物车的数量时,勾选全选按钮,反之则取消选中全选按钮: 2.改变选中状态时,计算总价和总数量: 3.单个产品的数量加减 ...

  6. 使用Go语言+Protobuf协议完成一个多人聊天室

    软件环境:Goland Github地址 一.目的 之前用纯逻辑垒完了一个可登入登出的在线多人聊天室(代码仓库地址),这次学习了Protobuf协议,于是想试着更新下聊天室的版本. 主要目的是为了掌握 ...

  7. 16个富有创意的HTML5 Canvas动画特效集合

    HTML5技术正在不断的发展和更新,越来越多的开发者也正在加入HTML5阵营,甚至在移动开发上HTML5的地位也是越来越重要了.HTML5中的大部分动画都是通过Canvas实现,因为Canvas就像一 ...

  8. 蜕变成蝶~Linux设备驱动中的阻塞和非阻塞I/O

    今天意外收到一个消息,真是惊呆我了,博客轩给我发了信息,说是俺的博客文章有特色可以出本书,,这简直让我受宠若惊,俺只是个大三的技术宅,写的博客也是自己所学的一些见解和在网上看到我一些博文以及帖子里综合 ...

  9. 【PostgreSQL】资料索引(来源:德哥)

    PostgreSQL 多应用场景实践 - 沙箱实验 https://github.com/digoal/blog/blob/master/201805/20180524_02.md 一.GIS < ...

  10. 异常:Project configuration is not up-to-date with pom.xml 解决方案

    错误描述,在导入Maven项目后出现下面错误: Description Resource Path Location Type Project configuration is not up-to-d ...