四、NOSQL之Redis持久化缓存服务基础实战第三部
1.NOSQL的理解
NOSQL是不仅仅是SQL,说的就是sql的补充,但是不能替代SQL。
nosql库:memcached、memcachedb、redis
2.redis 简介
Redis是一个基于key-value键值对的持久化数据库存储系统,redis和memcached缓存服务很像,但是redis支持的数据存储类型更丰富,包括string(字符串)、list(链表)、set(集合)、zset(有序集合)等。
Redis持久化缓存还会周期性的把更新的数据写入到磁盘以及把修改的操作记录追加到文件里记录下来,比memcached更有优势的是,redis还支持maser-slave(主从)同步,这和mysql很像。
3.redis优点
- 性能高:每秒支持100K读写;数据库一般也就几百
- 丰富的数据类型:Redis支持String、lists、Hashes等
- 原子:所有操作都是原子性的
- 丰富的特性:Redis还支持publish/subscribe通知,key过期
- redis支持异机主从复制
- 可以持久化存储数据
4.redis的数据类型
常用的5种:string、hash、list 、set、sorted set
5.redis的应用场景
Mysql数据库实际上是适合进行海量数据存储的,加上通过Memcached将热点数据存放到内存cache里,达到加速数据访问的目的,绝大部分公司都曾经使用过这样的架构,但是随着业务数据量的不断增加,和访问量的持续增长,很多问题就会暴露。
1.需要不断的对mysql进行拆库拆表,memcached也需要不断扩容,扩容和维护工作占据大量开发运维时间。
2.memcached与mysql数据库数据一致性问题是个老大难
3.memcached数据命中率低或者down机,会导致大量访问直接穿透到数据库,导致mysql无法支撑访问。
4.跨机房cach同步一致性问题
场景:
1.Redis最佳场景是内存
2. memcached的替代场景
3.除了key/value之外的更多数据类型支持时,使用Redis
4.当存储的数据不能被剔除时,使用Redis更合适。
5.支持负载均衡的场景(主从式,可以看成是数据库)
6.redis的安装步骤
1) cd /home/oldboy/tools/
2) wget -q http://download.redis.io/releases/redis-2.8.9.tar.gz -- -q表示 不显示的下载
3) ls redis-2.8.9.tar.gz
4) tar zxf redis-2.8.9.tar.gz
5) cd redis-2.8.9
6)less README ---可以读readme
7)make MALLOC=jemalloc --编译
8)make PREFIX=/application/redis-2.8.9 install --编译安装
9)ln -s /application/redis-2.8.9/ /application/redis --建立软连接
10)ll /application/ --查看
11)tree /application/redis 目录展示
在bin目录下有5个文件:
redis-server:Redis服务器的daemon启动程序
redis-cli:Redis命令行操作工具
redis-benchmark:Redis性能测试工具,测试Redis在你的系统及你的配置下的读写性能
redis-check-aof:更新日志检查
redis-check-dump:用于本地数据库检查
12) export PATH=/application/redis/bin/:$PATH --环境变量配置
13). /etc/profile --环境变量生效
14)which redis-server --查看命令是否生效
15)mkdir /application/redis/conf --创建redis配置文件的生效目录
16)cp redis.conf /application/redis/conf/ --将下载的文件中的配置文件放到创建的配置目录里面
17)redis-server /application/redis/conf/redis.conf & --启动redis
18)killall redis-server --杀死进程
19)sysctl vm.overcommit_memory=1 ---当内存小的时候,需要执行此命令
20)redis-server /application/redis/conf/redis.conf & ---启动redis
21)lsof -i:6379 --通过端口查看是否生效
22)redis-cli shutdown --关闭redis
7.通过客户端测试redis服务
连接本地服务器命令:redis-cli
127.0.0.1:6379> set no001 djw
OK
127.0.0.1:6379> get no002
"oldboy"
127.0.0.1:6379> get no001
"djw"
[root@djw3 application]# redis-cli -h 192.168.0.102 -p 6379 get no002
"oldboy"
[root@djw3 application]# redis-cli del no002
(integer) 1
[root@djw3 application]# redis-cli -h 192.168.0.102 -p 6379 get no002
(nil)
[root@djw3 application]# telnet 192.168.0.102 6379
Trying 192.168.0.102...
Connected to 192.168.0.102.
Escape character is '^]'.
get no001
$3
djw
7.redis数据类型(常见的是五种:String字符串、Hash哈希、List列表数据、Set集合、Sorted set排序集合)
其实这些了解下,开发、DBA一般会有自己的模式进行数据的定义,例如“object-type:id:field”就是不错的注意,像这样 user:1000:password,运维只要搭建好平台就行。
字符串类型:如果是字符串类型,就是一个持久的memcached服务器了,也可以是二进制文件,比如图片,值的长度不能超过1GB。
[root@djw3 ~]# redis-cli set mykey "my blnary safe value"
OK
[root@djw3 ~]# redis-cli get mykey
"my blnary safe value"
可以计数:
[root@djw3 ~]# redis-cli set djw 100
OK
[root@djw3 ~]# redis-cli incr djw
(integer) 101
[root@djw3 ~]# redis-cli incr djw
(integer) 102
[root@djw3 ~]# redis-cli incr djw
(integer) 103
列表类型:
[root@djw3 ~]# redis-cli rpush messages "Hello have are you ?"
(integer) 1
[root@djw3 ~]# redis-cli rpush messages "fine thanks I'm having fun with Redis"
(integer) 2
[root@djw3 ~]# redis-cli rpush messages "I should look into this NOSQL thing ASAP"
(integer) 3
[root@djw3 ~]# redis-cli lrange messages 0 2
1) "Hello have are you ?"
2) "fine thanks I'm having fun with Redis"
3) "I should look into this NOSQL thing ASAP"
集合:
[root@djw3 ~]# redis-cli sadd myset a
(integer) 1
[root@djw3 ~]# redis-cli sadd myset b
(integer) 1
[root@djw3 ~]# redis-cli sadd myset c
(integer) 1
[root@djw3 ~]# redis-cli smembers myset
1) "c"
2) "b"
3) "a"
8.redis版本安装(可以是地址里面的版本进行了变化,我的安装并不是成功的,在make编译的时候报错,不必深究,知道有客户端即可)
1.wget https://github.com/nicolasff/phpredis/archive/master.zip --no-check-certificate
2.unzip master.zip
3. cd phpredis-master/
4. /application/php/bin/phpize
5. ./configure --with-php-config=/application/php/bin/php-config
6.make && make install
echo "extension = redis.so" >> /application/php/lib/php.ini
9.对于redis的使用,可在其配置文件中进行配置。具体场景可根据企业需求进行
[root@djw3 conf]# cd /application/redis/conf/redis.conf
四、NOSQL之Redis持久化缓存服务基础实战第三部的更多相关文章
- 【新手总结】在.Net项目中使用Redis作为缓存服务
最近由于项目需要,在系统缓存服务部分上了redis,终于有机会在实际开发中玩一下,之前都是自己随便看看写写,很零碎也没沉淀下来什么,这次算是一个系统学习和实践过程的总结. 和Redis有关的基础知识 ...
- 在.Net项目中使用Redis作为缓存服务
转自:http://www.cnblogs.com/hohoa/p/5771255.html 最近由于项目需要,在系统缓存服务部分上了redis,终于有机会在实际开发中玩一下,之前都是自己随便看看写写 ...
- Redis系列(四):Redis持久化和主从复制原理
一.持久化 所谓的持久化就是把内存中的数据写到磁盘中去,防止服务宕机后内存数据丢失.Redis4.0之前提供了两种持久化方式:RDB(默认) 和AOF,Redis4.x之后新增了一种混合持久化(本文所 ...
- 【docker构建】基于docker搭建redis数据库缓存服务
搭建redis服务 首先拉取镜像==>运行镜像为容器 # 先搜索下redis镜像 [root@VM_0_10_centos wordpress]# docker search redis # 拉 ...
- Linux实战教学笔记45:NoSQL数据库之redis持久化存储(一)
第1章 redis存储系统 1.1 redis概述 REmote DIctionary Server(Redis)是一个基于key-value键值对的持久化数据库存储系统.redis和大名鼎鼎的Mem ...
- Redis持久化(转载)
原文地址:http://www.jianshu.com/p/2f14bc570563?from=jiantop.com 数据持久化 Redis提供了将数据定期自动持久化至硬盘的能力,包括RDB和AOF ...
- 高并发简单解决方案————redis队列缓存+mysql 批量入库(ThinkPhP)
问题分析 问题一:要求日志最好入库:但是,直接入库mysql确实扛不住,批量入库没有问题,done.[批量入库和直接入库性能差异] 问题二:批量入库就需要有高并发的消息队列,决定采用redis lis ...
- Redis(二)、Redis持久化RDB和AOF
一.Redis两种持久化方式 对Redis而言,其数据是保存在内存中的,一旦机器宕机,内存中的数据会丢失,因此需要将数据异步持久化到硬盘中保存.这样,即使机器宕机,数据能从硬盘中恢复. 常见的数据持久 ...
- NoSQL:redis缓存数据库
一 Redis介绍 Redis和Memcached类似,也属于key-value nosql 数据库 Redis官网redis.io, 当前最新稳定版4.0.1 和Memcached类似,它支持存储的 ...
随机推荐
- vue.js实现自定义输入分页
效果如下: html: <input type="text" value="1" v-model="page.page_my_selected& ...
- Fedora 32大变化:将删除Python 2及其软件包
导读 虽然Fedora 30还没有上市,Fedora 32直到大约一年后才上市,但我们已经知道一个很大的变化:删除Python 2和包依赖它.随着Fedora 32将于2020年上半年推出,超过了Py ...
- 洛谷 P1043 数字游戏
题目传送门 解题思路: 跟石子合并差不多,区间DP(环形),用f[i][j][s]表示从i到j分成s段所能获得的最大答案,枚举断点k,则f[i][j][s] = min(f[i][j][s],f[i] ...
- echars的使用
1.首先引入echars的js文件 该文件可从echars官网下载 在某些图表中可能会引用ecStat.js文件 如线性回归散点图 我们直接下载引用即可 <head> <title& ...
- 学习spring的第二天
对昨天的查漏:关于<bean>标签的scope属性,是由它决定原型和单例的,而不是说你java代码中用到了单例模式就是单例了. 其二就是lazy-init属性,它对于scope=" ...
- 寒假day25
今天解决了部分数据爬取不下来的问题,同时进行了面试的准备
- GitHub上传家庭记账本
GitHub的使用参考之前的博客GitHub的初步了解和使用,并完成了相关的android个人家庭记账本的上传
- Linux环境创建交换分区
最近在准备在移动端跑一下深度学习训练好的模型,在RK3399的板子上安装scipy时报错.网上查了一下,由于内存不足导致,做个交换分区就搞定了.那么如何做交换分区呢.话不多说,直接开撸. ------ ...
- quartz 集成到Spring中
记录一下,防止忘记. 需要的jar包,quartz-2.2.3.jar,commons-collection-3.1.jar,spring-context-support-4.3.4.RELEASE. ...
- cmd 进入指定文件夹
1.通常情况下,我们要进入其他盘符下的任意目录,需要在CMD窗口运行两次命令:第一次,进入盘符,第二次进入指定目录 #进入D盘 d: #进入D盘下的anaconda目录 cd anacond 2.通过 ...