黑马程序员技术交流社区

标题: [学习记录]Redis个人整理 [打印本页]

作者: python_shenshou    时间: 2018-9-21 16:05
标题: [学习记录]Redis个人整理
一.nosql介绍(not only sql)1.泛指非关系型的数据库
2.不支持SQL语法
3.存储结构跟传统关系型数据库中的那种关系表完全不同,nosql中存储的数据都是KV形式
4.NoSQL的世界中没有一种通用的语言,每种nosql数据库都有自己的api和语法,以及擅长的业务场景
5.NoSQL中的产品种类相当多:
        1)Mongodb
        2)Redis
        3)Hbase hadoop
        4)Cassandra hadoop

NoSQL和SQL数据库的比较:
1.适用场景不同:sql数据库适合用于关系特别复杂的数据查询场景,nosql反之
2.“事务”特性的支持:sql对事务的支持非常完善,而nosql基本不支持事务
3.两者在不断地取长补短,呈现融合趋势


二.Redis
1.Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。
2.Redis是 NoSQL技术阵营中的一员,它通过多种键值数据类型来适应不同场景下的存储需求,借助一些高层级的接口使用其可以胜任,如缓存、队列系统的不同角色
Redis特性:
1.Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
2.Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
3.Redis支持数据的备份,即master-slave模式的数据备份。

Redis 优势:
1.性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
2.丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
3.原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。
4.丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性

应用场景;
1.用来做缓存(ehcache/memcached)——redis的所有数据是放在内存中的(内存数据库)
2.可以在某些特定应用场景下替代传统数据库——比如社交类的应用
3.在一些大型系统中,巧妙地实现一些特定的功能:session共享、购物车
4.只要你有丰富的想象力,redis可以用在可以给你无限的惊喜…….

三.Redis安装
ubuntu下:
1.下载: wget http://download.redis.io/releases/redis-4.0.9.tar.gz
2.解压: tar xzf redis-4.0.9.tar.gz
3.移动,放到USR /本地⽬录下:sudo mv ./redis-4.0.9 /usr/local/redis/
4.进⼊Redis的⽬录: cd /usr/local/redis/
5.生成: sudo make
6.测试,这段运⾏时间会较⻓: sudo make test
7.安装,将redis的命令安装到/usr/local/bin/⽬录: sudo make install
8.安装完成后,我们进入目录/usr/local/bin中查看: cd /usr/local/bin
        redis-server redis服务器
        redis-cli redis命令行客户端
        redis-benchmark redis性能测试工具
        redis-check-aof AOF文件修复工具
        redis-check-rdb RDB文件检索工具
9.配置⽂件,移动到/etc/⽬录下: sudo cp /usr/local/redis/redis.conf /etc/redis/
修改配置:
1.sudo vi /etc/redis/redis.conf
2.修改项:
        1)绑定ip:如果需要远程访问,可将此⾏注释,或绑定⼀个真实ip
        bind 127.0.0.1
        2)端⼝,默认为6379
        port 6379
        3)是否以守护进程运⾏(如果以守护进程运⾏,则不会在命令⾏阻塞,类似于服务,如果以⾮守护进程运⾏,则当前终端被阻塞,设置为yes表示守护进程,设置为no表示⾮守护进程)
        daemonize yes
        4)数据⽂件
        dbfilename dump.rdb
        5)数据⽂件存储路径
        ir /var/lib/redis
        6)⽇志⽂件
        logfile "/var/log/redis/redis-server.log"
        7)数据库,默认有16个
        database 16
        8)主从复制,类似于双机备份
        slaveof


四.服务器端
开启服务器:redis-server
可以使⽤help查看帮助⽂档:redis-server --help
个人习惯:
ps aux | grep redis 查看redis服务器进程
sudo kill -9 pid 杀死redis服务器
sudo redis-server /etc/redis/redis.conf 指定加载的配置文件
查看指定端口:netstat -ap | grep 8080 或者 lsof -i:8888
数据库没有名称,默认有16个,通过0-15来标识,连接redis默认选择第一个数据库


五.客户端
进入客户端:redis-cli
运⾏测试命令:ping
切换数据库:select 10
删除当前数据库的所有数据:flushdb
删除所有数据库中的所有数据:flushall

六.数据结构
1.redis是key-value的数据结构,每条数据都是⼀个键值对
2.键的类型是字符串
3.键不能重复
值的类型分为五种;
字符串string
哈希hash
列表list
集合set
有序集合zset

数据操作行为:
保存,修改,获取,删除













欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2