redis-day1

1 Redis 概述

  REmote DIctionary Server(Redis)是一个基于key-value键值对的持久化数据库存储系统。redis和大名鼎鼎的Memcached缓存服务软件很像,但是Redis支持的数据存储类型比Memcached更丰富,包括strings(字符串)、lists(列表)、sets(集合)和sorted sets(有序集合)等

  这些数据类型支持push/pop、add/remove及取交集、并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached缓存服务一样,为了保证效率,数据都是缓存在内存中提供服务。和memcached不同的是,redis持久化缓存服务还会周期性的把更新的数据写入到磁盘以及把修改的操作记录追加到文件里记录下来,比Memcached更有优势的是,redis还支持master-slave(主从)同步,这点很类似关系型数据库MySQL主从复制功能

  Redis是一个开源的使用C语言编写、支持网络、可基于内存亦可持久化的日志型、key-value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持

  Redis软件的出现,在一定程度上弥补了memcached这类key-value内存缓存服务的不足,在部分场合可以对关系数据库起到很好的补充作用。redis提供了Python,Ruby,Erlang,PHP客户端,使用起来很方便。Redis官方文档如下:

  https://redis.io/documentation

  http://redis.cn/

  1.1 Redis优点

  • 与memcached不同,Redis可以持久化存储数据
  • 性能很高:Redis能支持超过10W美妙的读写频率
  • 丰富的数据类型:Redis支持二进制的Strings,Lists,Hashes,Sets及sorted Sets等数据类型
  • 原子:Redis的所有操作都是原子性,同时Redis还支持对几个操作全并后的原子性执行
  • 丰富的特性:Redis还支持publish/subscribe(发布/订阅),通知,key过期等等特性
  • Redis支持异机主从复制

  1.2 缺点

  • 系统运行有毛刺
  • 不同命令延迟差别极大
  • 内存管理开销大
  • buffer io造成OOM

  1.3 Redis的数据类型

  • String 字符串
  • List 列表
  • Set 集合
  • Sorted set 有序集合

2 Redis的安装及使用

  Redis的生产经验教训

  • 要进行Master-slave主从同步配置,在出现服务故障时可以切换
  • 在master禁用数据持久化,只需在slave上配置数据持久化
  • 物理内存+虚拟内存不足,这个时候dump一直死这,时间久了机器挂掉。这个情况就是灾难!64-128G内存,SSD硬盘
  • 当Redis物理内存使用超过内存总容量的3/时就会开始比较危险了,就开始做SWAP,内存碎片打!
  • 当达到最大内存时,会清空带有过期时间的key,及时key未到过期时间
  • redis与DB同步写的问题,先写DB,厚些redis,因为写内存基本上没有问题

  2.1 redis环境部署

Master:10.0.0.1 Centos6.5 Redis-Master

  2.2 安装

#Master
[root@Redis-Master downloads]# wget http://download.redis.io/releases/redis-3.2.4.tar.gz
[root@Redis-Master downloads]# tar zxf redis-3.2.4.tar.gz 
[root@Redis-Master downloads]# cd redis-3.2.4
[root@Redis-Master redis-3.2.4]# make PREFIX=/usr/local/redis install
#查看目录
[root@Redis-Master redis-3.2.4]# ls /usr/local/redis/bin/
redis-benchmark  redis-check-aof  redis-check-rdb  redis-cli  redis-sentinel  redis-server
#只有这一个bin目录
#redis-server:Redis服务器的daemon启动程序
redis-cli:Redis命令行操作工具。当然,你也可以用telnet根据其纯文本协议来操作
redis-benckmark:Redis性能测试工具,测试Redis在你的系统及你的配置下的读写性能
redis-check-aof:对更新日志appendonly.aof检查,是否可用,类似检查mysql binlog的工具
redis-check-dump:用于本地数据库rdb文件的检查

  2.3 配置并启动redis服务

1、配置环境变量
[root@Redis-Master /]# echo 'PATH=/usr/local/redis/bin/:$PATH' >>/etc/profile
[root@Redis-Master /]# source /etc/profile
2、拷贝配置文件
[root@Redis-Master /]# cd /tmp/downloads/redis-3.2.4
[root@Redis-Master redis-3.2.4]# mkdir /usr/local/redis/conf
[root@Redis-Master redis-3.2.4]# cp redis.conf /usr/local/redis/conf/
3、启动
[root@Redis-Master /]# echo "vm.overcommit_memory = 1" >>/etc/sysctl.conf 
[root@Redis-Master /]# sysctl -p #以防后台保存失败
[root@Redis-Master /]# redis-server /usr/local/redis/conf/redis.conf &
#vm.overcommit_memory该参数有三个值,分别是:
0:当用户空间请求更多的内存时,内核尝试估算出剩余可用的内存
1:当设这个参数值为1时,内核允许超量使用内存知道用完为止,主要用于科学计算
2:当设这个参数值为2时,内核会使用一个绝不过量使用内存的算法,即系统整个内存地址空间不能超过swap+50%的RAM值,50%参数的设定是在overcommit_ratio中设定
4、关闭
[root@Redis-Master /]# redis-cli shutdown save

  2.4 通过客户端来操作redis数据库

1、存值
[root@Redis-Master /]# redis-cli 
127.0.0.1:6379> set id 001
OK
2、取值
127.0.0.1:6379> get id #可以get ket,无法get value
"001"
3、删除
127.0.0.1:6379> del id #删除key
(integer) 1
4、查看是否存在
127.0.0.1:6379> EXISTS id
(integer) 0 #0为不存在
5、取所有
127.0.0.1:6379> keys *

#redis默认有16个库,0为开头

#远程连接
[root@Redis-Master /]# redis-cli -h 10.0.0.1 -p 6379 #可以设置密码,跟mysql很像
10.0.0.1:6379>

#telnet和nc都可以操作

  2.5 redis的安全账户密码及授权权限

[root@Redis-Master /]# cat /usr/local/redis/conf/redis.conf |grep requirepass
# If the master is password protected (using the "requirepass" configuration
# requirepass foobared
requirepass 123.com
格式:[ requirepass ] [ password ]
#123.com就是密码
#重启redis

#测试
127.0.0.1:6379> set 1 daniel
(error) NOAUTH Authentication required.
#提示没认证
127.0.0.1:6379> auth 123.com
OK
#登录
127.0.0.1:6379> set 1 daniel
OK
#再次测试,成功

#或者
[root@Redis-Master /]# redis-cli -a 123.com
127.0.0.1:6379>
#可以直接输入密码后进入


#命令重命名
[root@Redis-Master /]# grep rename-command /usr/local/redis/conf/redis.conf 
# security of read only slaves using 'rename-command' to shadow all the
# rename-command CONFIG b840fc02d524045429941cc15f59e41cb7be6c52
# rename-command CONFIG ""
rename-command set "se"
#格式 [ rename-command ] [ CONFIG ] [ "" ]
#测试
[root@Redis-Master /]# redis-cli -a 123.com
127.0.0.1:6379> set 2 cat
(error) ERR unknown command 'set'
127.0.0.1:6379> se 2 cat
OK
#set无法使用,se可以

  2.7 在php环境中安装redis的客户端扩展

[root@RS02 downloads]# wget https://codeload.github.com/phpredis/phpredis/zip/develop
[root@RS02 downloads]# unzip develop 
[root@RS02 downloads]# cd phpredis-develop/
[root@RS02 phpredis-develop]# /usr/local/php5.6.33/bin/phpize
[root@RS02 phpredis-develop]# ./configure --with-php-config=/usr/local/php5.6.33/bin/php-config
[root@RS02 phpredis-develop]# make && make install

#修改php.ini,重启php
[root@RS02 php5.6.33]# sed -i 's#; extension_dir = "./"#extension_dir = "/usr/local/php5.6.33/lib/php/extensions/no-debug-non-zts-20131226/"#g' /usr/local/php5.6.33/lib/php.ini 
[root@RS02 php5.6.33]# echo "extension = redis.so" >>/usr/local/php5.6.33/lib/php.ini
[root@RS02 php5.6.33]# /usr/local/php5.6.33/sbin/php-fpm

#出现这个信息就算正确

  2.8 开发php程序实战redis服务

#开启redis的远程连接
[root@Redis-Master /]# sed -i 's/bind 127.0.0.1/#bind 127.0.0.1/g' /usr/local/redis/conf/redis.conf
#重启
[root@RS02 php5.6.33]# cat /usr/local/nginx/html/index.php 
<?php
	$redis = new Redis();
	$redis->connect('10.0.0.1',6379) or die ("heh");
	$redis->auth('123.com');
	$redis->set('100','DANIEL');
	$var = $redis->get('100');
	echo "$var
";
?>
[root@Redis-Master /]# curl 10.0.0.81
DANIEL
成功

  2.9 开发python程序实战操作redis服务

原文地址:https://www.cnblogs.com/wazy/p/8545438.html