NoSQL(NoSQL = Not Only SQL),它指的是非关系型的数据库。随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模和高并发的SNS类型的web2.0纯动态网站已经显的力不从心,暴露了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了非常迅速的发展。

NoSQL的特点:

特点一:

是以key-value形式存储,和传统的关系型数据库不一样,不一定遵循传统数据库的一些基本要求,比如说遵循SQL标准、ACID属性、表结构等等,这类数据库主要有以下特点:非关系型的、分布式的、开源的、水平可扩展的。

特点二:

  1. 处理超大量的数据比Mysql等有优势。

  2. 运行在便宜的PC服务器集群上。

  3. 击碎了性能瓶颈。(MySQL的时候需要很多优化,但是NoSQL不需要,性能非常高)

特点三(性能方面):

  1. 对数据高并发读写。(对MySQL进行上万次读的请求可能顶得住,但是如果对MySQL进行上万次的写的时候,硬盘IO要求就比较高,效率就比较低下,但是NoSQL就比较方面。)

  2. 对海量数据的高效率存储和访问。

  3. 对数据的高可扩展和高可用性。(NoSQL可以增加一个服务器节点,使用NoSQL来做分布式比较简单,因为没有固定的表结构,所以更改比较方便)。

Redis的介绍:

  1. Redis是一个开源的,先进的key-value存储。它通常被称为数据结构服务器,因为键可以包含字符串,哈希,链表,集合和有序集合。

  2. Redis是一个key-value存储系统。它支持存储的value类型很多,包括string(字符串)、list(链表)、set(集合)、zset(有序集合)。这些数据类型都支持push/pop、add/remove及取交集和并集及更丰富的操作,Redis支持各种不同方式的序列。为了保证效率,都是缓存在内存中的,它也可以周期性的吧更新的数据写入磁盘或者吧修改操作写入追加的记录文件。

Redis的使用场合:

在新浪微博Redis的部署场景很多,大概分为如下2种:

  1. 应用程序直接访问Redis数据库。

  1. 应用程序直接访问Redis,只有当Redis访问失败时才访问MySQL

把大象装冰箱的过程:

Redis数据库提供多中灵活的数据结构和数据操作,为不同的大象构建不同的冰箱。

Redis具体的适用场景:

  1. 取最新N个数据库的操作

  2. 排行榜应用,取TOP N操作

  3. 需要精确设定过期时间的应用

  4. 计数器应用

  5. Uniq操作,获取某段时间所有数据排重值

  6. 实时系统,反垃圾系统。

  7. Pub/Sub构建实时消息系统(Redis独有的发布和订阅系统)

  8. 构建队列系统

  9. 缓存。

Redis的安装与部署

第一步:

Redis的官方下载站是:http://redis.io/download

最好使用Stable版本(稳定版本)。

第二步:编译源程序

tar zxvf redis-2.8.19.tar.gz

cd redis-2.8.19

make

cd src && make install  (注意权限问题)

网上安装方式:

$ wget http://download.redis.io/releases/redis-2.8.19.tar.gz

$ tar xzf redis-2.8.19.tar.gz

$ cd redis-2.8.19

$ make

步骤三:

移动文件,便于管理:

mkdir –p /usr/local/redis/bin

mkdir –p /usr/local/redis/etc

mv /home/toto/redis/redis-2.8.19/redis.conf/usr/local/redis/etc/

cd src

mv mkreleasehdr.sh redis-benchmarkredis-check-aof redis-check-dump redis-cli redis-server /usr/local/redis/bin/   (也就是说移动的是所有的可执行的文件)

第四步:启动Redis服务:

/usr/local/redis/bin/redis-server (或者到/usr/local/redis/bin目录下,执行:./redis-server)

可以指定配置文件:

/usr/local/redis/etc/redis.conf (可以在./redis-server后面加上这个配置文件)

Redis服务端的默认连接端口是6379 (mongodb的端口号是:27017和28017端口)

第五步:

客户端连接:/usr/local/redis/bin/redis-cli (cli是client的缩写)。

退出客户端的方式是通过exit或者通过quit的方式。

步骤六:

停止Redis实例

我们可以使用/usr/local/redis/bin/redis-cli然后再

shutdown

也可以使用pkill redis-server  或者kill -9来实现。

Redis的配置:

daemonize:如果需要在后台运行,把该项改为yes

pidfile:配置多个pid的地址默认在/var/run/redis.pid

bind:绑定ip,设置后只接受来自该ip的请求

port:监听端口,默认为6379

timeout:设置客户端连接时的超时时间,单位为秒

loglevel:分为4级,debug、verbose、notice、warning

logfile:配置log文件地址

databases:设置数据库的个数,默认使用的数据库为0

save:设置redis进行数据库镜像的频率。(备份数据)

rdbcompression:在进行镜像备份时,是否进行压缩

dbfilename:镜像备份文件的文件名

dir:数据库镜像备份的文件放置路径

slaveof:设置数据库为其它数据库的从数据库。

masterauth:主数据库连接需要的密码验证。

requirepass:设置登录时需要使用的密码。

maxclients:限制同时连接的客户数量。

maxmemory:设置redis能够使用的最大内存。

appendonly:开启append only模式。

appendfsync:设置对appendonly.aof文件进行同步的频率。

vm-enabled:是否开启虚拟内存支持。

vm-swap-file:设置虚拟内存的交换文件路径。

vm-max-memory:设置redis使用的最大物理内存大小。

vm-page-size:设置虚拟内存的页的大小

vm-pages:设置交换文件的总的page数量

vm-max-threads设置VMIO同时使用的线程数量。

glueoutputbuf:把小的输出缓存存放在一起。

hash-max-zipmap-entries:设置hash的临界值

activerehashing:重新hash

查看进程的方式:ps –ef | grep “redis”

查看端口的方式:netstat -tunpl | grep 6379

-------------------------------------------------------------------------------------------------------------------------------------------------------

redis服务器安装(其他方式)

用源码工程来编译安装

1/ 到官网下载最新stable版

2/ 解压源码并进入目录  tar -zxvf    redis-2.8.19.tar.gz  -C  ./redis-src/

3/ make

如果报错提示缺少gcc,则安装gcc :  yum install -y gcc

如果报错提示:Newer version ofjemalloc required

则在make时加参数:make MALLOC=libc

4/ 安装redis,指定安装目录,如 /usr/local/redis

make PREFIX=/usr/local/redis install

6/ 拷贝一份配置文件到安装目录下

切换到源码目录,里面有一份配置文件redis.conf,然后将其拷贝到安装路径下

cp redis.conf /usr/local/redis/

7/ 启动redis

cd /usr/local/redis

bin/redis-server redis.conf

8 连接redis

另开一个xshell,然后:

#cd /usr/local/redis/

[root@hadoop redis]# bin/redis-cli 

127.0.0.1:6379>

注意:为了让机器能够远程连接服务器上的redis,需要将redis.conf中的bind值改成访问机器的ip地址,不要用127.0.0.1

bin/redis-cli -h 192.168.106.81 -p 6379    通过这种方式可以连接到192.168.106.81这台服务器上的redis.   注意:若想让它能够被连同192.168.106.81这台服务器上的redis.conf的bind属性值要改成192.168.106.81

NoSQL数据库之Redis数据库:Redis的介绍与安装部署的更多相关文章

  1. 【redis】01Redis的介绍与安装部署

    单元目标: 1.NoSQL介绍 2.Redis的介绍 3.Redis适用场合 4.Redis的安装与部署 5.Redis的数据类型 6.Redis的常用命令 7.Redis的高级应用       通过 ...

  2. Redis在CentOS 7上的安装部署

    简介: Redis是一种高级key-value数据库.它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富.有字符串,链表,集 合和有序集合.支持在服务器端计算集合的并,交和补集( ...

  3. Kafka介绍及安装部署

    本节内容: 消息中间件 消息中间件特点 消息中间件的传递模型 Kafka介绍 安装部署Kafka集群 安装Yahoo kafka manager kafka-manager添加kafka cluste ...

  4. Storm介绍及安装部署

    本节内容: Apache Storm是什么 Apache Storm核心概念 Storm原理架构 Storm集群安装部署 启动storm ui.Nimbus和Supervisor 一.Apache S ...

  5. hue框架介绍和安装部署

    大家好,我是来自内蒙古的小哥,我现在在北京学习大数据,我想把学到的东西分享给大家,想和大家一起学习 hue框架介绍和安装部署 hue全称:HUE=Hadoop User Experience 他是cl ...

  6. Apache Solr 初级教程(介绍、安装部署、Java接口、中文分词)

    Python爬虫视频教程零基础小白到scrapy爬虫高手-轻松入门 https://item.taobao.com/item.htm?spm=a1z38n.10677092.0.0.482434a6E ...

  7. Redis介绍、安装部署、操作

    学习连接:http://www.runoob.com/redis/redis-tutorial.html 一.Redis介绍 Redis是NoSql的一种. NoSql,全名:Not Only Sql ...

  8. Linux+Redis实战教程_day01_Linux介绍与安装

    1.Linux介绍(了解) 1.1.Linux和Windows的区别 Linux是一款操作系统.正规开发 服务器项目部署都是放在Linux操作系统上. Windows一款操作系统,民用操作系统.娱乐. ...

  9. Redis的概述、优势和安装部署

    Redis概述 Redis是一个开源,先进的key-value存储,并用于构建高性能,可扩展的应用程序的完美解决方案. Redis从它的许多竞争继承来的三个主要特点: Redis数据库完全在内存中,使 ...

随机推荐

  1. 基于SSM框架实现简单的登录注册

    一.环境配置 工程目录 在pom.xml添加依赖 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi=& ...

  2. (转载)总结一下SQL语句中引号(')、quotedstr()、('')、format()在SQL语句中的用法

    总结一下SQL语句中引号(').quotedstr().('').format()在SQL语句中的用法以及SQL语句中日期格式的表示(#).('')在Delphi中进行字符变量连接相加时单引号用('' ...

  3. 多线程join(加入)

    package cn.itcast.thread;/* join方法. 加入 */ //老妈class Mon extends Thread{ public void run() { System.o ...

  4. HashSet与TreeSet

    1.TreeSet 是二差树实现的,Treeset中的数据是自动排好序的,不允许放入null值 2.HashSet 是哈希表实现的,HashSet中的数据是无序的,可以放入null,但只能放入一个nu ...

  5. 初识 Runtime

    前言 之前在看一些第三方源码的时候,时不时的能碰到一些关于运行时相关的代码.于是乎,就阅读了一些关于运行时的文章,感觉写的都不错,写此篇文章为了记录一下,同时也重新学习一遍. Runtime简介 Ru ...

  6. mysql catalog的名字

    def 算是一个一点卵用都没有的知识点 然后tmd各个版本不同 用这个语句查 SELECT * FROM information_schema.SCHEMATA where schema_name=' ...

  7. php序列化漏洞理解

    0x01什么是序列化 序列化就是将我们的 对象转变成一个字符串,保存对象的值方便之后的传递与使用. 0x02为什么要序列化 如果为一个脚本中想要调用之前一个脚本的变量,但是前一个脚本已经执行完毕,所有 ...

  8. 通讯协议序列化解读(一) Protobuf详解教程

    前言:说到JSON可能大家很熟悉,是目前应用最广泛的一种序列化格式,它使用起来简单方便,而且拥有超高的可读性.但是在越来越多的应用场景里,JSON冗长的缺点导致它并不是一种最优的选择. 一.常用序列化 ...

  9. Winform DevExpress控件库(一) DevExpress控件库的安装与新建第一个DevExpress项目

    前言:因为这段时间要接触到DevExpress控件库,而我本身甚至对winform的控件都了解甚少,所以处在学习中,写下博客主要是为了方便后期的回顾,当然也可以给一些新人第一次接触时做为学习的参考,以 ...

  10. Android开发学习之路--Java和Js互相调用

      随着前端的火热,以前开发的快速,越来越多的native app在其中融合了h5,就拿淘宝就是很多的h5组成的,一旦出现什么节日,他都可以不用通过更新app来实现界面的改变,而且android和io ...