Java篇-Redis的基本应用( 一 )

redis.png

一 : NoSQL 简介

泛指非关系型数据库,意思是Not only SQL 不仅仅是是SQL,是一种全新的数据库概念,
随着互联网web2.0网站的兴起,非关系型的数据库现在成了一个极其热门的新领域,非关系数据库产品的发展非常迅速,而传统的关系型数据库在应付web2.0网站,特别超大规模和高并发的SNS(社交网络服务)类型的web2.0纯动态网站已经显得力不从心.

传统关系数据库难以克服的问题

  • High performance-对数据库高并发读写的需求

web2.0网站要根据用户个性化信息来实时生成动态页面提供动态信息,所以基本无法使用动态页面静态化技术,隐藏数据库并发负载非常高,往往要达到每秒上万次读写请求,关系数据库应付上万次读写请求,硬盘IO已经无法承受,其实对于普通的BBS网站,往往也存在对高并发写请求的需求,例如网站的实时统计在线用户状态,就热门帖子的点击次数,投票计数等,因此这是一个相当普遍的需求.

  • Hunge Storage - 对海量数据的高效存储和访问的需求

类似Facebook,twitter,Friendfeed 这样的SNS网站,每天用户产生海量的用户动态,以Friendfeed为例,一个月就到达了2.5亿条用户动态,对于关系数据库来说,在一张2.5亿条记录的表里面进行SQL查询,效率是极其低下的,还有像大型web网站登录系统,例如腾讯,盛大,动辄数以亿计的账号,关系数据库也很难对付.

  • High Scalability && HighAvailability- 对数据库的高可扩展性和高可用性的需求

在基于web的架构当中,数据库是最难进行横向扩展的,当一个应用系统的用户量和访问量与日俱增的时候,你的数据库却没有像web Server 和 app Server 那样简单的通过添加更多的硬件和服务节点来扩展性能和负载能力,对于很多需要提供24小时不间断服务的网站来说,对数据库系统进行升级和扩展是非常痛苦的事情,往往需要停机维护和数据迁移,为什么数据库不能通过不断的添加服务器节点来扩展呢

NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用难题

二 : 主流NoSQL产品及类型

NoSql数据库的四大分类 :

  • 键值(key-Value)存储数据库

相关产品 : Tokyo Cabinet/Tyrant, Redis,Voldemort,Berkeley DB
典型应用 : 内容缓存,主要用于处理大量数据的高访问负载.
数据类型 : 一系列键值对
优势 : 快速查询
劣势 : 存储的数据缺少结构化

  • 列存存储数据库

相关产品 : Cassandra,HBase,Riak
典型应用 : 分布式的文件系统
数据类型 : 以列簇式存储,将同一数据存在一起
优势 : 查找速度快,可扩展性强,更容易进行分布式扩展
劣势 : 功能相对局限

  • 文档型数据库

相关产品 : CouchDB,MongoDB
典型应用 : Web应用(与key-Value类似,Value是结构化的)
数据类型 : 一些了键值对
优势 : 数据结构要求不严格
劣势 : 查询性能不高,而且缺乏统一的查询语法

  • 图形数据库

相关数据库 : Neo4J,InfoGird,Infinite Graph
典型应用 : 社交网络
优势 : 利用图结构相关算法
劣势 : 需要对这个图做计算才能得出结果,不容易做分布式的集群方案

三 : NoSQL特点

在数据存取上具备关系型数据库无法比拟的性能优势

  • 易扩展

NoSQL 数据库种类繁多,但是一个共同的特点都是去掉关系数据库的关系型特性,数据之间无关系,这样就非常容易扩展,也无形之间在架构层面上带来了可扩展的能力

  • 大数据量,高性能

NoSQL数据库都具有非常高的读写性能,尤其是在大数据量下,同样表现优秀,这得益于它的无关系型,数据库的结构简单

  • 灵活的数据模型

NoSQL 无需事先为要存储的数据建立字段,随时可以存储自定义的数据格式,而在关系数据库里,增删字段是一件非常麻烦的事情,如果是非常大量的表,增加字段简直就是找死,这点在大数据量的web2.0时代尤其明显

  • 高可用性

NoSQL在不太影响性能的情况,就可以方便的实现高可用的架构,比如Cassanra,HBase模型,通过赋值模型也能实现高可用.

总结 : NoSQL的非关系特性使其成为了后web2.0时代的宠儿.是一项全新的数据库革命性运动.

四 : Redis 简述

Redis是用C语言开发的一个开源的高性能键值对(key-Value) 数据库.它通过提供多种键值数据类型来适应不同场景下的存储需求,目前为止Redis支持的键值数据类型如下 :

  • 字符串类型
  • 散列类型
  • 列表类型
  • 集合类型
  • 有序集合类型
    : 官方提供测试数据, 50个并发执行100000个请求,读的速度是110000次/s,写的速度是81000次/s.数据仅供参考,根据服务器配置会有不同结果

五 : redis 的应用场景

  • 缓存 (数据查询,短连接,新闻内容,商品内容等等)(最多使用)
  • 聊天室的在线好友列表
  • 任务队列 (秒杀,抢购,12306等等)
  • 应用排行榜
  • 网站访问统计
  • 数据过期处理(可以精确到毫秒)
  • 分布式集群架构中的session分离

六 : Redis在Linux下的安装

步骤一 :

安装redis编译的c环境,yum install gcc-c++

步骤二 :

将redis-3.0.0.tar.gz 上传到Linux系统中

步骤三 :

解压到/usr/local下 `tar -xvf redis.3.0.0.tar.gz -C /usr/local

步骤四 :

进入redis-3.0.0.tar.gz目录 使用make 命令 编译 redis

步骤五 :

在redis-3.0.0目录中 使用make PREFIX=/usr/local/redis install命令安装 redis 到 /usr/local/redis中

步骤六 :

拷贝redis-3.0.0中的redis.conf到安装目录redis中

步骤七 :

启动 redis 在bin下执行命令redis-server redis.conf

步骤八 :

如需远程连接redis,需配置redis端口6379在linux防火墙中开发
/sbin/iptables -I INPUT -p tcp --dport 6379 -j ACCEPT
/etc/rc.d/init.d/iptables save

redis

​启动后看到如上欢迎页面,但此窗口不能关闭,窗口关闭就认为redis也关闭了(类​似Tomcat通过bin下的startup.bat的方式)
​解决方案:可以通过修改配置文件 配置redis后台启动,即服务器启动了但不会创建控制台窗口
​将redis.conf文件中的daemonize从false修改成true表示后台启动
​使用命令查看6379端口是否启动ps -ef | grep redis

后端启动命令 :

在redis目录下
./bin/redis-server ./redis.conf

Redis停止

① : 强制结束程序,强行终止Redis进程可能会导致redis持久化数据丢失
② : 正确停止Redis的方式应该是向Redis发送shutdown命名
在redis目录下
.bin/redis-cli shutdown

连接客户端

在redis的安装目录中有redis的客户端,即redis-cli(Redis Command Line Interface)它是Redis自带的基于命令行Redis客户端
在redis目录下
./bin/redis-cli

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351