Memcache&Redis构建缓存服务器

技术分享  / 只看大图  / 倒序浏览   ©

#楼主# 2020-2-16

跳转到指定楼层

马上注册,分享更多源码,享用更多功能,让你轻松玩转云大陆。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
前言

许多Web应用都将数据保存到 RDBMS中,应用服务器从中读取数据并在浏览器中表现。但随着数据量的增大、访问的会合,就会出现RDBMS的负担加重、数据库响应恶化、 网站表现耽误等重大影响。Memcached/redis是高性能的分布式内存缓存服务器,通过缓存数据库查询结果,淘汰数据库访问次数,以进步动态Web等应用的速度、 进步可扩展性。
RDBMS即关系数据库管理体系(Relational Database Management System)
一、简介

为弥补关系型数据库的不敷,各种各样的NoSQL数据库应运而生。
1、nosql产品: redis,mongodb,memcached.

NOSQL名词解释:非关系型数据库:
①.以键值对的方式存储数据---(Key-Value)的形式
②.缓存数据库
2、NoSQL的优点/缺点

优点:- 高可扩展性- 分布式计算- 低资本- 架构的灵活性,半结构化数据- 没有复杂的关系缺点:- 没有标准化- 有限的查询功能(到目前为止)- 最终一致是不直观的程序
缓存服务器作用: 加快访问速度 ,缓解数据库压力
3、关系型数据库与非关系型数据库的区别:

1.SQL Server| 2.Oracle|3.mysql 等。
1.关系型数据库:优点:1、易于维护:都是使用表结构,格式一致;2、使用方便:SQL语言通用,可用于复杂查询;3、复杂操作:支持SQL,可用于一个表以及多个表之间非常复杂的查询。缺点:1、读写性能比力差,尤其是海量数据的高服从读写;2、固定的表结构,灵活度稍欠;3、高并发读写需求,传统关系型数据库来说,硬盘I/O是一个很大的瓶颈。=============================================================================2.非关系型数据库严格上不是一种数据库,应该是一种数据结构化存储方法的集合,可以是文档大概键值对等。优点:1、格式灵活:存储数据的格式可以是key,value形式、文档形式、图片形式等等,使用灵活,应用场景广泛,而关系型数据库则只支持基础范例。2、速度快:nosql可以使用硬盘大概随机存储器作为载体,而关系型数据库只能使用硬盘;3、高扩展性;4、资本低:nosql数据库部署简单,根本都是开源软件。缺点:1、不提供sql支持,学习和使用资本较高;3、数据结构相对复杂,复杂查询方面稍欠。memcached和redis区别

memcachedredis存储方式key-values可以存5种数据范例可以存视频图片Redis可以通过模块存图片线程多线程(锁)单线程(内存足够快)吞吐量稍高稍低功能只能做缓存(只要宕机,关闭,数据全部丢失)能做缓存,也能持久化存储本身不支持集群,不支持高并发(可以使用第三方,但是兼容性不高)可以主从,集群,哨兵(高可用)适用场景没有什么用的数据,数据量过大,访问激增对于数据范例要求较高,持久化二、memcached

1、特点

1.内置内存存储方式-----------为了进步性能,memcached中保存的数据都存储在memcache内置的内存存储空间中。由于数据仅存在于内存中,重启操作体系会导致全部数据消失
2.简单key/value存储---------------服务器不关心数据本身的意义及结构,只要是可序列化数据即可。存储项由“键、过期时间、可选的标志及数据”四个部门组成;
3.不互相通信的分布式 -------------  memcached尽管是“分布式”缓存服务器,但服务器端并没有分布式功能。 各个memcached不会互相通信以共享信息。那么,怎样进行分布式呢? 这完全取决于客户端的实现。
185120fkvgac2ke8ok0ykn.png
2、服务框架

185121qvvw7v1vnuvusj1h.png
原理
1、检查客户端的请求数据是否在memcached中,如有,直接把请求数据返回,不再对数据库进行任何操作,路径操作为①②③⑦。
2、假如请求的数据不在memcached中,就去查数据库,把从数据库中获取的数据返回给客户端,同时把数据缓存一份到memcached中(memcached客户端不负责,需要程序明确实现),路径操作为①②④⑤⑦⑥。
3.保持缓存的“新鲜性”,每当数据发生变化的时候(比如,数据有被修改,或被删除的情况下),要同步的更新缓存信息,确保用户不会在缓存取到旧的数据。
3、设置安装Memcached

memcached能存放多少数据,取决于服务器本身的内存有多大。
1.安装----准备一台服务器ip:192.168.94.132[root@memcached ~]# yum -y install memcached2.修改设置文件[root@memcached ~]# vim /etc/sysconfig/memcachedPORT="11211"USER="memcached"MAXCONN="1024"CACHESIZE="64"OPTIONS="192.168.94.132"[root@memcached ~]# systemctl start memcached  #启动3.测试:[root@memcached ~]# yum install -y telnet   #安装telent[root@memcached ~]# telnet 192.168.94.132 11211Trying 192.168.94.132...Connected to 192.168.94.132.Escape character is '^]'.set name 0 30 4   #设置名称为name的keyduan              #给name的值STORED            #出现stoped表示已经存储成功。get name          #查询key值VALUE name 0 4duanEND参数解释:name:key的名字 自己定义0:key的id号,需要和其他的key不一样60:缓存过期时间,单元为秒,0为永远8:字符串最大长度memcache退出:Ctrl+]telnet退出:Ctrl+D然后把ip地址发给开发职员,开发会使用api接口连接memcached.安装php支持memcached的扩展模块:
[root@memcached ~]# rpm -Uvh https://mirror.webtatic.com/yum/el7/epel-release.rpm[root@memcached ~]# rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm[root@memcached ~]# yum -y install php70w.x86_64 php70w-cli.x86_64 php70w-common.x86_64 php70w-gd.x86_64 php70w-ldap.x86_64 php70w-mbstring.x86_64 php70w-mcrypt.x86_64 php70w-mysql.x86_64 php70w-pdo.x86_64 php70w-devel zlib-devel[root@memcached ~]# yum -y install php70w-fpm[root@memcached ~]# yum install -y make gcc zlib-devel libmemcached-devel git下载PHP Memcache 扩展包[root@memcached ~]# git clone https://github.com/websupport-sk/pecl-memcache   #php7的mem扩展[root@memcached ~]# cd pecl-memcache/[root@memcached pecl-memcache]# /usr/bin/phpizeConfiguring for:PHP Api Version:         20151012Zend Module Api No:      20151012Zend Extension Api No:   320151012[root@memcached pecl-memcache]# ./configure --with-php-config=/usr/bin/php-config[root@memcached pecl-memcache]# make && cp modules/memcache.so  /usr/lib64/php/modules/[root@memcached pecl-memcache]# vim /etc/php.ini;   extension=msql.soextension=memcache.so[root@memcached pecl-memcache]# systemctl start php-fpm测试环境准备:[root@memcached ~]# yum -y install httpd mariadb mariadb-server[root@memcached ~]# vim /var/www/html/index.php[root@memcached ~]# vim /etc/httpd/conf/httpd.conf修改下列设置,支持phpDirectoryIndex index.html index.php[root@memcached ~]# systemctl start httpd[root@memcached ~]# systemctl stop firewalld[root@memcached ~]# setenforce 0[root@memcached ~]# mysqladmin password"Duan@123"[root@memcached ~]# mysql -uroot -p"Duan@123"mysql> create database employees;mysql> use employeesmysql> create table salaries(emp_no int,salary int);mysql> insert into salaries values(1001,6666),(1002,7777),(1003,8888);mysql> flush privileges;浏览器访问测试:
第一出现mysql,之后都是memcached
185122cma0e7rykrm19kmw.png
三、Redis服务

1、介绍

redis是一个开源的、使用C语言编写的、支持网络交互的、可基于内存也可持久化的Key-Value数据库
redis的官网:redis.io
注:域名后缀io属于国家域名,是british Indian Ocean territory,即英属印度洋领地
2、redis的特点:

1.丰富的数据结构  -----string,list,set,zset,hash等数据结构的存储2.支持持久化3.支持事务   ---------------事务是指“一个完整的动作,要么全部执行,要么什么也没有做”。4.支持主从3、缓存

1.范例
1).数据缓存
2).页面缓存(Smarty)
在开发网站的时候假如有一些数据在短时间之内不会发生变化,而它们还要被频仍访问,为了进步用户的请求速度和降低网站的负载,就把这些数据放到一个读取速度更快的介质上(大概是通过较少的计算量就可以获得该数据) ,该行为就称作对该数据的缓存。
该介质可以是文件、数据库、内存,内存经常用于数据缓存
2.形式
页面缓存经常用在内存管理体系里边
数据缓存经常用在页面的具体数据里边
redis和memcache比力
1).Redis不仅仅支持简单的k/v范例的数据,同时还提供了list,set,zset,hash等数据结构的存储
2).Redis支持master-slave(主-从)模式应用
3).Redis支持数据的持久化
四、安装Redis

1、安装单机版redis

环境:centos7.5  ip:192.168.94.134[root@redis-master ~]# mkdir -p /data/application     ---创建工作目录[root@redis-master ~]# wget http://download.redis.io/releases/redis-4.0.9.tar.gz   ---下载redis[root@redis-master ~]# tar xzf redis-4.0.9.tar.gz -C /data/application/    ---解压[root@redis-master ~]# cd /data/application/[root@redis-master application]# mv redis-4.0.9/ redis [root@redis-master application]# cd redis/[root@redis-master redis]# yum install -y gcc make  #安装编译工具[root@redis-master redis]# make注:假如报错请将刚才解压的安装包删撤除,再次重新解压并进行make安装即可。[root@redis-master redis]# cp redis.conf redis.conf.bak[root@redis-master redis]# vim redis.conf     ---修改如下bind 192.168.94.134  #只监听内网IPdaemonize yes     #开启背景模式将on改为yestimeout 300      #连接超时时间port 6379                      #端口号dir /data/application/redis/  #当地数据库存放持久化数据的目录该目录-----需要存在pidfile /var/run/redis_6379.pid  #定义pid文件logfile /var/log/redis.log  #定义log文件requirepass    #设置暗码(假如设置了暗码,登陆时没有输入暗码,需要在Redis中  auth 暗码 )设置redis为systemctl启动[root@redis-master redis]# vim /lib/systemd/system/redis.service[Unit]Description=RedisAfter=network.target[Service]ExecStart=/data/application/redis/src/redis-server /data/application/redis/redis.conf  --daemonize noExecStop=/data/application/redis/src/redis-cli -h 127.0.0.1 -p 6379 shutdown[Install]WantedBy=multi-user.target=====================参数详解:• [Unit] 表示这是基础信息 • Description 是形貌• After 是在那个服务后面启动,一般是网络服务启动后启动• [Service] 表示这里是服务信息 • ExecStart 是启动服务的命令• ExecStop 是停止服务的指令• [Install] 表示这是是安装相关信息 • WantedBy 是以哪种方式启动:multi-user.target表明当体系以多用户方式(默认的运行级别)启动时,这个服务需要被自动运行。===================启动服务:[root@redis-master system]# systemctl daemon-reload[root@redis-master system]# systemctl start redis[root@redis-master system]# ss -lnta  #查看6379端口是否启动登陆redis[root@redis-master redis]# vim /etc/profilePATH=$PATH:/data/application/redis/src/[root@redis-master redis]# source /etc/profile[root@redis-master redis]# redis-cli -h 192.168.94.134 -p 6379192.168.94.134:6379> ping     ---测试redis是否可以用PONG192.168.94.134:6379> set name newrain    #设置key--name,并设置值OK192.168.94.134:6379> get name    #获取到key"newrain"192.168.94.134:6379>单机版redis已经部署完成。将ip和端口发给开发就可以了。redis的相关工具
redis-benchmark     #用于进行redis性能测试的工具redis-check-dump    #用于修复出题目标dump.rdb文件redis-cli           #redis的客户端redis-server        #redis的服务端redis-check-aof     #用于修复出题目标AOF文件redis-sentinel      #用于集群管理2、数据持久化

开启持久化功能后,重启redis,数据会自动通过持久化文件规复!!
redis持久化 – 两种方式
一、redis提供了两种持久化的方式,分别是RDB(Redis DataBase)和AOF(Append Only File)。RDB(Redis DataBase):是在不同的时间点,将redis存储的数据生成快照并存储到磁盘等介质上;特点:1.周期性2.不影响数据写入  #RDB会启动子进程,备份全部数据。当前进程,继续提供数据的读写。当备份完成,才更换老的备份文件。(老版本不会)3.高效     #一次性还原全部数据4.完整性较差 #故障点到上一次备份,之间的数据无法规复。====================================================================================AOF(Append Only File)则是换了一个角度来实现持久化,那就是将redis执行过的全部写指令记录下来,在下次redis重新启动时,只要把这些写指令从前到后再重复执行一遍,就可以实现数据规复了。特点:1.实时性2.完整性较好3.体积大  #记录数据的指令,删除数据的指令都会被记录下来。====================================================================================二、RDB和AOF两种方式也可以同时使用,在这种情况下,假如redis重启的话,则会优先采用AOF方式来进行数据规复,这是因为AOF方式的数据规复完整度更高。假如你没有数据持久化的需求,也完全可以关闭RDB和AOF方式,这样的话,redis将变成一个纯内存数据库,就像memcache一样。三、如何选择方式?缓存:不用开启任何持久方式双开:因RDB数据不实时,但同时使用两者时服务器只会找AOF文件,所以RDB留作万一的手段。redis持久化 – 如何选择RDB和AOF对于我们应该选择RDB还是AOF,官方的建议是两个同时使用。这样可以提供更可靠的持久化方案。写入速度快 ------------AOF写入速度慢 ------------RDB3、持久化设置(快照模式)

1、RDB默认开启:[root@redis-master src]# cd ..[root@redis-master redis]# vim redis.conf#dbfilename:持久化数据存储在当地的文件dbfilename dump.rdb#dir:持久化数据存储在当地的路径dir /data/application/redis/##snapshot触发的时机,save    ##如下为900秒后,至少有一个变更操作,才会snapshot  ##对于此值的设置,需要谨慎,评估体系的变更操作密集程度  ##可以通过“save “”来关闭snapshot功能  #save时间,以下分别表示更改了1个key时间隔900s进行持久化存储;更改了10个key300s进行存储;更改10000个key60s进行存储。save 900 1save 300 10save 60 10000##当snapshot时出现错误无法继续时,是否阻塞客户端“变更操作”,“错误”大概因为磁盘已满/磁盘故障/OS级别异常等  stop-writes-on-bgsave-error yes  ##是否启用rdb文件压缩,默认为“yes”,压缩每每意味着“额外的cpu消耗”,同时也意味这较小的文件尺寸以及较短的网络传输时间  rdbcompression yes 2、客户端使用命令进行持久化save存储:方式一[root@redis-master src]# redis-cli -h 192.168.94.134 -p 6379 save   #前台进行存储  指的是当前终端的前背景OK方式二redis-cli -h ip -p port bgsave  #背景进行存储注意:每次快照持久化都是将内存数据完整写入到磁盘一次,并不是增量的只同步新数据。假如数据量大的话,而且写操作比力多,必然会引起大量的磁盘io操作,大概会严重影响性能。save方式:持久化前面的全部数据(rdb模式没开时,后续的数据不会进行备份)3、AOF默认关闭--开启[root@redis-master src]# cd ..[root@redis-master redis]# vim redis.conf修改如下:appendonly yes1、此选项为aof功能的开关,默认为“no”,可以通过“yes”来开启aof功能,只有在“yes”下,aof重写/文件同步等特性才会生效2、指定aof文件名称appendfilename appendonly.aof  3、指定aof操作中文件同步计谋,有三个合法值:always everysec no,默认为everysecappendfsync everysec  4、在aof-rewrite期间,appendfsync是否暂缓文件同步,"no"表示“不暂缓”,“yes”表示“暂缓”,默认为“no”no-appendfsync-on-rewrite no  5、触发aof rewrite的最小文件尺寸 auto-aof-rewrite-min-size 64mb6、当Aof log增长超过指定比例时,重写log file, 设置为0表示不自动重写Aof 日志,重写是为了使aof体积保持最小,而确保保存最完整的数据。auto-aof-rewrite-percentage 100修改完设置文件后重启生效4、redis主从设置

主从简介
1、主从 – 用法
像MySQL一样,redis是支持主从同步的,而且也支持一主多从以及多级从结构。
主从结构,一是为了纯粹的冗余备份,二是为了提升读性能,比如很消耗性能的SORT就可以由从服务器来负担。
redis的主从同步是异步进行的,这意味着主从同步不会影响主逻辑,也不会降低redis的处理性能。
主从架构中,可以考虑关闭主服务器的数据持久化功能,只让从服务器进行持久化,这样可以进步主服务器的处理性能。
在主从架构中,从服务器通常被设置为只读模式,这样可以避免从服务器的数据被误修改。但是从服务器仍然可以接受CONFIG等指令,所以还是不应该将从服务器直接暴露到不安全的网络环境中。
2、主从同步原理
主从 – 同步原理
从服务器会向主服务器发出SYNC指令,当主服务器接到此命令后,就会调用BGSAVE指令来创建一个子进程专门进行数据持久化工作,也就是将主服务器的数据写入RDB文件中。在数据持久化期间,主服务器将执行的写指令都缓存在内存中。
在BGSAVE指令执行完成后,主服务器会将持久化好的RDB文件发送给从服务器,从服务器接到此文件后会将其存储到磁盘上,然后再将其读取到内存中。这个动作完成后,主服务器会将这段时间缓存的写指令再以redis协议的格式发送给从服务器。
另外,要说的一点是,即使有多个从服务器同时发来SYNC指令,主服务器也只会执行一次BGSAVE,然后把持久化好的RDB文件发给多个下游。在redis2.8版本之前,假如从服务器与主服务器因某些原因断开连接的话,都会进行一次主从之间的全量的数据同步;而在2.8版本之后,redis支持了服从更高的增量同步计谋,这大大降低了连接断开的规复资本。
主服务器会在内存中维护一个缓冲区,缓冲区中存储着将要发给从服务器的内容。从服务器在与主服务器出现网络瞬断之后,从服务器会实验再次与主服务器连接,一旦连接成功,从服务器就会把“盼望同步的主服务器ID”和“盼望请求的数据的偏移位置(replication offset)”发送出去。主服务器接收到这样的同步请求后,首先会验证主服务器ID是否和自己的ID匹配,其次会检查“请求的偏移位置”是否存在于自己的缓冲区中,假如两者都满足的话,主服务器就会向从服务器发送增量内容。
增量同步功能,需要服务器端支持全新的PSYNC指令。这个指令,只有在redis-2.8之后才具有。
3、部署三台机器redis---主从同步
redis-master----192.168.94.134redis-slave-1-----192.168.94.133redis-slave-2-----192.168.94.1351.首先三台服务器将redis部署完成。2.编辑master的redis设置文件:[root@redis-master ~]# cd /data/application/redis/[root@redis-master redis]# vim redis.conf#bind 127.0.0.1bind 0.0.0.0protected-mode no2.修改slave的设置文件(两台机器一样):[root@redis-slave-1 ~]# cd /data/application/redis/[root@redis-slave-1 redis]# vim redis.conf      ---修改如下:#bind 127.0.0.1bind 0.0.0.0protected-mode no# slaveof  slaveof 192.168.94.134 63793.重启三台redissystemctl restart redis  #忘了看前面systemctl stop firewalld && setenforce 0测试
1.在master上面执行[root@redis-master ~]# redis-cli127.0.0.1:6379> pingPONG127.0.0.1:6379> set name duanOK127.0.0.1:6379> get name"duan"2.分别在slave-1和slave-2上面执行:[root@redis-slave-1]# ./redis-cli 127.0.0.1:6379> pingPONG127.0.0.1:6379> get name"duan"127.0.0.1:6379>[root@redis-slave-2]# redis-cli 127.0.0.1:6379> pingPONG127.0.0.1:6379> get name"duan"查看复制状态master执行:127.0.0.1:6379> info replication# Replicationrole:masterconnected_slaves:2slave0:ip=192.168.94.133,port=6379,state=online,offset=323490,lag=1slave1:ip=192.168.94.135,port=6379,state=online,offset=323490,lag=1---------------------------------------------slave上面执行127.0.0.1:6379> info replication# Replicationrole:slavemaster_host:192.168.94.134master_port:6379master_link_status:upmaster_last_io_second主从同步部署完成!
5.redis-sentinel---哨兵模式

1、哨兵简介:Redis Sentinel
Sentinel(哨兵)是用于监控redis集群中Master状态的工具,其已经被集成在redis2.4+的版本中是Redis官方保举的高可用性(HA)办理方案。
2、作用
1):Master状态检测
2):假如Master异常,则会进行Master-Slave切换,将其中一个Slave作为Master,将之前的Master作为Slave
3):Master-Slave切换后,master_redis.conf、slave_redis.conf和sentinel.conf的内容都会发生改变,即master_redis.conf中会多一行slaveof的设置,sentinel.conf的监控目标会随之变更
3、工作模式
1):每个Sentinel以每秒钟一次的频率向它所知的Master,Slave以及其他 Sentinel 实例发送一个 PING 命令
2):假如一个实例(instance)距离最后一次有效回复 PING 命令的时间超过 down-after-milliseconds 选项所指定的值, 则这个实例会被 Sentinel 标记为主观下线。
3):假如一个Master被标记为主观下线,则正在监视这个Master的全部 Sentinel 要以每秒一次的频率确认Master简直进入了主观下线状态。
4):当有足够数量的 Sentinel(大于等于设置文件指定的值)在指定的时间范围内确认Master简直进入了主观下线状态, 则Master会被标记为客观下线
4、主观下线和客观下线
主观下线:Subjectively Down,简称 SDOWN,指的是当前 Sentinel 实例对某个redis服务器做出的下线判断。
客观下线:Objectively Down, 简称 ODOWN,指的是多个 Sentinel 实例在对Master Server做出 SDOWN  判断,并且通过 SENTINEL is-master-down-by-addr 命令互相交流之后,得出的Master  Server下线判断,然后开启failover
5、设置哨兵模式
1.每台机器上修改redis主设置文件redis.conf文件设置:bind 0.0.0.0   ---已经操作2.每台机器上修改sentinel.conf设置文件:修改如下设置[root@redis-master src]# cd ..[root@redis-master redis]# vim sentinel.confsentinel monitor mymaster 10.0.0.137 6379 2 #当集群中有2个sentinel认为master死了时,才能真正认为该master已经不可用了。 (slave上面写的是master的ip,master写自己ip)sentinel down-after-milliseconds mymaster 3000   #单元毫秒sentinel failover-timeout mymaster 10000   #若sentinel在该设置值内未能完成failover(故障转移)操作(即故障时master/slave自动切换),则认为本次failover失败。protected-mode no  #关闭加密模式--新添加到sentinel设置文件中假如Redis加了暗码,哨兵设置文件中也要指定3.每台机器启动哨兵服务:[root@redis-master redis]# redis-sentinel /data/application/redis/sentinel.conf注意:在生产环境下将哨兵模式启动放到背景执行:     redis-sentinel /data/application/redis/sentinel.conf &
185122a2q2or83xcxkof1o.png
将master的哨兵模式退出,再将redis服务stop了,在两台slave上面查看其中一台是否切换为master:(没有优先级,为随机切换)
[root@redis-master ~]# systemctl stop redis在slave机器上面查看:
185123gihg75ziqfgiqgiu.png
登陆slave服务器查看有没有切换
[root@real_server1 ~]# redis-cli 127.0.0.1:6379> info replication# Replicationrole:slavemaster_host:192.168.94.135master_port:6379master_link_status:up登陆当前master机器查看:
[root@linux ~]# redis-cli 127.0.0.1:6379> info replication# Replicationrole:masterconnected_slaves:1slave0:ip=192.168.94.133,port=6379,state=online,offset=43552,lag=1另外一台机器stop了,所以没有表现五、Redis缓存测试(基于LAMP)

基于上面的Redis主从:编辑Redis主:[root@redis-master ~]# redis-cli 127.0.0.1:6379> info replication# Replicationrole:masterconnected_slaves:2slave0:ip=192.168.94.133,port=6379,state=online,offset=5814,lag=0slave1:ip=192.168.94.135,port=6379,state=online,offset=5814,lag=1# 部署mariadb[root@redis-master ~]# yum install -y mariadb mariadb-server mariadb-devel[root@redis-master ~]# systemctl start mariadb[root@redis-master ~]# mysqladmin -uroot password 123456[root@redis-master ~]# mysql -uroot -p123456mysql> create database test;mysql> use testmysql> create table t1(id int,name varchar(50));mysql> insert into t1 values(1,"tom"),(2,"jack");mysql> flush privileges;# 部署apache[root@redis-master ~]# yum install -y httpd[root@redis-master ~]# vim /etc/httpd/conf/httpd.confDirectoryIndex index.html index.php# 部署php[root@redis-master ~]# rpm -Uvh https://mirror.webtatic.com/yum/el7/epel-release.rpm[root@redis-master ~]# rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm[root@redis-master ~]# yum install php70w.x86_64 php70w-cli.x86_64 php70w-common.x86_64 php70w-gd.x86_64 php70w-ldap.x86_64 php70w-mbstring.x86_64 php70w-mcrypt.x86_64 php70w-mysql.x86_64 php70w-pdo.x86_64 php70w-devel zlib-devel php70w-fpm php70w-pecl-redis  -y[root@redis-master ~]# vim /etc/php.ini878 date.timezone =Asia/Shanghaidisplay_errors = Off,把Off修改为On[root@redis-master ~]# systemctl start php-fpm httpd[root@redis-master ~]# vim /var/www/html/index.php测试访问:
第一次头部是mysql,之后刷新一直是Redis
185123t88wi89e7ihba8n1.png
redis--快照
快照,主要涉及的是redis的RDB持久化相关的设置用如下的指令来让数据保存到磁盘上,即控制RDB快照功能:save  举例save 900 1 //表示每15分钟且至少有1个key改变,就触发一次持久化save 300 10 //表示每5分钟且至少有10个key改变,就触发一次持久化save 60 10000 //表示每60秒至少有10000个key改变,就触发一次持久化假如想禁用RDB持久化的计谋,只要不设置任何save指令就可以,大概给save传入一个空字符串参数也可以达到相同效果,就像这样:save ""假如用户开启了RDB快照功能,那么在redis持久化数据到磁盘时假如出现失败,默认情况下,redis会停止接受全部的写请求。这样做的好处在于可以让用户很明确的知道内存中的数据和磁盘上的数据已经存在不一致了。假如redis不顾这种不一致,独断专行的继续接收写请求,就大概会引起一些灾难性的后果。假如下一次RDB持久化成功,redis会自动规复接受写请求。当然,假如你不在乎这种数据不一致大概有其他的手段发现和控制这种不一致的话,你完全可以关闭这个功能,以便在快照写入失败时,也能确保redis继续接受新的写请求。设置项如下:stop-writes-on-bgsave-error yes对于存储到磁盘中的快照,可以设置是否进行压缩存储。假如是的话,redis会采用LZF算法进行压缩。假如你不想消耗CPU来进行压缩的话,可以设置为关闭此功能,但是存储在磁盘上的快照会比力大。rdbcompression yes在存储快照后,我们还可以让redis使用CRC64算法来进行数据校验,但是这样做会增加大约10%的性能消耗,假如你盼望获取到最大的性能提升,可以关闭此功能。rdbchecksum yes设置快照文件的名称,默认设置:dbfilename dump.rdb设置这个快照文件存放的路径。默认设置就是当前文件夹:dir ./安全:为redis加密:
可以要求redis客户端在向redis-server发送请求之前,先进行暗码验证。当你的redis-server处于一个不太可信的网络环境中时,相信你会用上这个功能。由于redis性能非常高,所以每秒钟可以完成多达15万次的暗码实验,所以你最好设置一个足够复杂的暗码,否则很容易被黑客破解。requirepass 1122334这里我们通过requirepass将暗码设置成“1122334”。Redis设置文件详解

Redis设置文件详解
分享淘帖
回复

使用道具

您的回复是对作者最大的奖励

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关于作者

穿越鬼咒岚

新手猿

  • 主题

    3

  • 帖子

    3

  • 关注者

    0

Archiver|手机版|小黑屋|云大陆 | 赣ICP备18008958号-4|网站地图
Powered by vrarz.com!  © 2019-2020版权所有云大陆