NoSQL&Redis
1.介绍NoSQL
NoSQL(Not Only SQL):不仅仅是SQL,是一项全新的数据库理念,泛指非关系型数据库,原来我们所使用的MySQL、Oracle、Microsoft SQL Server等都是关系行数据库。那么我们为什么需要NoSQL呢?随着互联网web2.0网站兴起,非关系型数据库发展迅速,传统的关系型数据库应付 web2.0 网站,特别是超大规模和高并发的 SNS 类型的 web2.0 动态网站已经力不从心,尤其是对数据库高并发读写的需求、对海量数据库的高效率存储和访问的需求、对数据库的高可扩展和高可用性的需求大大增加,使得NoSQL成为互联网的新宠儿~
1.1主流NoSQL产品
Tolyo Cabinet/Tyrant、Redis、Voldemort、Berkeley DB、Cassandra、HBase、Riak、CounchDB、MongoDB、Neo4J、InfoGrid、Infinite Graph
- 键值(key-value)存储数据库
- 相关产品:Tolyo Cabinet/Tyrant、Redis、Voldemort、Berkeley DB
- 典型应用:内容缓存,主要用于处理大量数据的高访问负载
- 数据模型:一系列键值对
- 优势:快速查询
- 劣势:存储的数据缺少结构化
- 列存储数据库
- 相关产品:Cassandra、HBase、Riak
- 典型应用:分布式的文件系统
- 数据模型:以列簇式存储,将同一列数据存在一起
- 优势:查找速度快,可扩展性强,更容易进行分布式扩展
- 劣势:功能相对局限
- 文档型数据库
- 相关产品:CounchDB、MongoDB
- 典型应用:Web应用
- 数据模型:一系列键值对
- 优势:数据结构要求不严格
- 劣势:查询性能不高,而且缺乏统一的查询语法
- 图形数据库
- 相关数据库:Neo4J、InfoGrid、Infinite Graph
- 典型应用:社交网络
- 数据模型:图结构
- 优势:利用图结构相关算法
- 劣势:需要对整个图做计算才能得出结果,不容易做分布式的集群方案
1.2NoSQL特点
1.易扩展
- NoSQL数据库种类繁多,但是一个共同特点都是去掉关系数据库的关系型特点。数据之间没有关系,也就无形中在架构层面上带来了可扩展的能力
2.大数据量,高性能
- NoSQL数据库都具有非常高的读写性能,尤其是在大数据量下,同样表现优秀。得益于它的无关性,数据库的结构简单
3.灵活的数据模型
- NoSQL 无需事先为存储的数据建立字段,随时可以存储自定义的数据格式。而在关系数据库里,增删字段是一件非常麻烦的事情。如果非常大数据量的表,增加字段简直就是一个噩梦。
4.高可用
- NoSQL 在不太影响性能的情况,就可以方便的实现高可用的框架。比如 Cassandra,HBase模型,通过复制模型也能实现高可用
2.什么是Redis
Redis 是用C语言开发的一个开源的高性能的键值对(key-value)数据库,因为是C语言开发所以需要在 Linux 下使用 gcc 来编译本次讲解操作都在 Linux下 因为在 Windows操作下不能保证很高的性能,目前 Redis 支持的键值数据类型如下:
- 字符串类型
- 散列类型
- 列表类型
- 集合类型
- 有序集合类型
这里不在介绍 Redis 的安装过程 大致过程需要搭建虚拟机环境,安装 Linux 系统,通过 SSH 将安装包传输进去 ,在进行解压,使用 make 命令进行编译 ,使用make PREFIX=/安装路径 /redis install 进行安装 因为直接 /安装路径/redis/bin/redis-server 启动执行程序会在前台,我们可以copy配置文件 redis.conf 到你/安装路径/redis下,修改 redis.conf 配置文件 daemonize 修改为 yes 就可变成后端启动
2.1Redis使用说明
- 使用后端模式启动
- Redis -> ./bin/redis-server redis.conf
- 查看 Redis端口默认6379
- ps -ef | grep -i redis
- 强制Redis 停止
- kill -9 端口号
- 正常停止
- cd /安装路径/redis
- ./bin/redis-cli shutdown
- 连接客户端
- ./bin/redis-cli
- 输入数据 set username haha
- 输出数据 get username
- 删除数据 del username
- 查看当前库中所有 key 值 keys *
- 值得注意的问题是要使用Jedis需要开放端口Centos7 开放的代码是
firewall-cmd --zone=public --add-port=6379/tcp --permanent
- Centos7以下开放的代码是
/sbin/iptables -I INPUT -p tcp --dport 6379 -j ACCEPT
/etc/rc.d/init.d/iptables save
NoSQL&Redis的更多相关文章
- (转)NoSQL——Redis在win7下安装配置的学习一
NoSQL——Redis在win7下安装配置的学习一 有些也是从网上看来的 1.下载安装 Redis它没有windows的官方版本,但是又非官方的版本,到官网上去下载相应的版本,我的电脑是win7 ...
- 转载 NoSQL | Redis、Memcache、MongoDB特点、区别以及应用场景
NoSQL | Redis.Memcache.MongoDB特点.区别以及应用场景 2017-12-12 康哥 码神联盟 本篇文章主要介绍Nosql的一些东西,以及Nosql中比较火的三个数据库Red ...
- NoSQL -- Redis使用
NoSQl简介: ubuntun CTRL+alt+F1 图形切换到命令行 CTRL+alt+F7 命令行切换到图形界面 redis介绍 + 实践 Redis是什么? Redis 安装 edis是当 ...
- NoSQL - Redis应用场景
问题的引入 DB(Oracle.MySQL.Postgresql等)+Memcached 这种架构模式在我们生产环境中十分常见,一般我们通过Memcached将热点数据加载到cache,应用 ...
- NoSQL&&Redis介绍
再说Redis之前,想先说一下NoSQL.在最早的单机时代,随着数据的增加一台机器可能放不下了.同时索引占用的内存空间也会越来越大.对请求的读写操作影响很大.于是就在数据库之前增加了一层保护层 — 缓 ...
- Redis学习笔记(1)—— NoSQL&Redis简介
一.NoSQL概述 1.1 什么是NoSQL NoSQL(NoSQL = Not Only SQL),意指“不仅仅是SQL”,是一项全新的数据库理念,泛指非关系型的数据库. 1.2 为什么需要NoSQ ...
- 二十三 NoSql&Redis及其安装
什么是Nosql not only sql , 不仅仅是sql,是一项全新的数据库理念,泛指非关系型的数据库. 为什么需要NoSql 解决以下问题: 1 High Performance 对数据库 ...
- NoSQL & Redis 介绍、缓存穿透 & 击穿 & 雪崩
1. NoSql 简介 2. Redis 简介 2.1 Redis 的起源 2.2 缓存过期 & 缓存淘汰 3. 缓存异常 1)缓存穿透 2)缓存击穿 3)缓存雪崩 4)总结 1. NoSQL ...
- db nosql redis / Redis Sentinel
s Redis基础原理和日常操作方法 http://itsm.cns*****.com/kindeditor/img/20170527/759128afca564051b491e6a51a5bad40 ...
随机推荐
- Python函数学习——匿名函数
匿名函数 匿名函数就是不需要显式的指定函数名. 关键字lambda表示匿名函数,冒号前面的n表示函数参数,可以有多个参数. 匿名函数有个限制,就是只能有一个表达式,不用写return,返回值就是该表达 ...
- Docker: connection reset by peer
想来,对docker的学习和实践,已经一年有余了,而我关于这样的文章,只有为数不多的几篇.今天借使用docker中发生的一种异常情况为例,写此篇幅. 这个是在centos7.0 ..netcore2. ...
- Python多进程库multiprocessing中进程池Pool类的使用
问题起因 最近要将一个文本分割成好几个topic,每个topic设计一个regressor,各regressor是相互独立的,最后汇总所有topic的regressor得到总得预测结果.没错!类似ba ...
- 网站性能压力测试工具--apache ab使用详解
ab是apache自带的压力测试工具.ab非常实用,它不仅可以对apache服务器进行网站访问压力测试,也可以对其它类型的服务器进行压力测试.比如nginx.tomcat.IIS等. 下面我们开始介绍 ...
- MongoDB的aggregate聚合
聚合框架中常用的几个操作: $project:修改输入文档的结构.可以用来重命名.增加或删除域,也可以用于创建计算结果以及嵌套文档.(显示的列,相当遇sql 的) $match:用于过滤数据,只输出符 ...
- leetcode — remove-element
/** * Source : https://oj.leetcode.com/problems/remove-element/ * * Created by lverpeng on 2017/7/12 ...
- Python机器学习笔记:sklearn库的学习
网上有很多关于sklearn的学习教程,大部分都是简单的讲清楚某一方面,其实最好的教程就是官方文档. 官方文档地址:https://scikit-learn.org/stable/ (可是官方文档非常 ...
- Asp.net Webform 使用Repository模式实现CRUD操作代码生成工具
Asp.net Webform 使用Repository模式实现CRUD操作代码生成工具 介绍 该工具是通过一个github上的开源项目修改的原始作者https://github.com/Supere ...
- 支付宝(alipay)即时到账收款接口开发中的那些事儿
不会做,看看也可以会,要做好就还是需要多学习 国庆回来就一直没状态,看完<银河护卫队>,印象最深的竟然是只有两句台词的呆萌groot,昨天才休息一天,大耍大吃,今天还是把昨天的知识学习一下 ...
- Spring之Bean的配置方式
在博客中为了演示容器Bean实例化时暴露出的几个接口,将UserBean配置在XML中,其实常见的Bean的配置有3种.1.基于xml配置Bean 2.使用注解定义Bean 3.基于java类提供Be ...