首页 > 代码库 > redis

redis

       Redis是Remote Dictionary Server(远程数据服务)的缩写,由意大利人antirez(Salvatore Sanfilippo)开发的一款内存高速缓存数据库,该软件使用C语言编写,它的数据模型为key-value。

操作都是原子性的(要么执行成功,要么不执行)


(1)redis和memcache比较
1.Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
2.Redis支持master-slave(主-从)模式应用
3.与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
4.Redis单个value的最大限制是1GB,memcached只能保存1MB的数据。

memcached,对于缓存对象大小有要求,单个对象不得大于1MB,且不支持复杂的数据类型,譬如SET等。



操作命令

get

set

info查看性能

redis有五种数据类型,string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)


#安装

yum install -y redis


#源码

cd /usr/local/src/

wget sha1sum hash redis-3.2.0.tar.gz sha1 0c1820931094369c8cc19fc1be62f598bc5961ca http://download.redis.io/releases/redis-3.2.0.tar.gz

#完整性:与 redis-hashes 对照

tar zxvf redis-3.2.0.tar.gz

cd redis-3.2.0


yum install -y epel-release


#启动

systemctl start redis.service

systemctl stop redis.service

systemctl status redis.service

systemctl restart redis.service

#随系统启动服务

systemctl enable redis.service

查看状态 :

# ss -nlp|grep redis

或者

# ps -ef | grep redis




#使用redis

redis-cli

redis-cli -h 127.0.0.1 -p 6379

redis-cli -h 127.0.0.1 -p 6379 -a password


6、Redis开启远程登录连接
原来是redis默认只能localhost登录,所以需要开启远程登录。解决方法如下:
在redis的配置文件redis.conf中,找到bind localhost注释掉。
注释掉本机,局域网内的所有计算机都能访问。
band localhost 只能本机访问,局域网内计算机不能访问。
bind 局域网IP 只能局域网内IP的机器访问, 本地localhost都无法访问。
我没有注释掉bind 127.0.0.1,而是将bind 127.0.0.1 改成了bind 0.0.0.0。

然后要配置防火墙 开放端口6379


启用redis的密码验证功能requirepass参数即可



Redis集群搭建

要想搭建一个最简单的Redis集群,那么至少需要6个节点:3个Master和3个Slave。为什么需要3个Master呢?如果你了解过Hadoop/Storm/Zookeeper这些的话,你就会明白一般分布式要求基数个节点,这样便于选举(少数服从多数的原则)



通过MySQL自动同步刷新Redis,原文地址

缓存最要注意的就是一致性问题。


redis 本身有持久化,为什么还要写进 mysql 呢?

1. 场景不一样, redis 的持久化是附加功能, mysql 的持久化是核心功能 
2. redis 的 flushdb 、 flushall 太犀利了,用 redis 来持久化数据总感觉不靠谱 
3. 持久化机制不一样,举个例子来说,当数据量达到 10G 的时候,你改了几条数据, mysql 只增量地持久化这几条数据;而 redis 只知道自己该持久化了,然后把 10G 数据完整地从内存 dump 到磁盘,是不是很过瘾

4.redis 的持久化,特别是 AOF 一点也不靠谱,对性能影响太大, 开过之后再也不想开了. RDB 会丢数据.

5.mysql做一些后期统计

redis是高性能内存缓存,容量依赖于物理内存。如果你物理内存只有2G,却想用Redis存20G的东西,这是错误的用法。

而mysql对内存依赖没Redis严重,但mysql对硬盘会有一定程度的依赖。如果硬盘性能不好,mysql在保存大于物理内存数量的数据时,性能也不会好。




Memcached,对于缓存对象大小有要求,单个对象不得大于1MB,且不支持复杂的数据类型,譬如SET等。



本文出自 “尽力而为” 博客,请务必保留此出处http://yanjiu.blog.51cto.com/673670/1922654

redis