基于redis缓存数据库实现lnmp架构高速访问

how-缓存加速

使用nosql数据库:

如redis,mongodb,memcache

what-redis

redis 是一个高性能的 key-value 数据库。

1) redis 的出现,很大程度弥补了memcached 这类 key-value 存储的不足(只能存入内存).

2)它支持的数据类型比memcache多,包括了 Python,Ruby,Erlang,PHP 客户端...

3)Redis 的所有数据都是保存在内存中,两种同步模式

A>半持久化模式:RDB(全量同步)

i>RDB是Redis默认同步方式

ii>不定期的通过异步方式保存到磁盘上,快照最终结果( 快照二进制文件为dump.rdb)

iii>在恢复大数据集时的速度比 AOF 的恢复速度要快。

B>全持久化模式:(增量同步)

i>把每一次数据变化都写入到一个 append only file(aof)里面.

ii>没有RDB同步的快,但采用了高并发机制,对系统内存要求高.

iii>使用方式

#appendfsync always实时同步

appendfsync everysec每秒同步(推荐使用)

# appendfsync no

一般两种模式结合使用.

4)只保证最终数据一致性,适用于微博粉丝,秒杀,抢红包等场景,微博粉丝数量,一会儿加一减一的,要是这么微量但高频率的变化,每次都要写到数据库里,那数据库的负担就太重啦~

基于redis实现lnmp架构高速访问

sever11:

 yum install mysql-server -y

 mysql>grant select on test.* to [email protected]‘172.25.88.%‘ identified by ‘miao‘;

 mysql <test.sql 导入测试数据,可用select查看

server13:

tar zxf redis-3.2.5.tar.gz 

yum install gcc -y make && make install

cd utils/ ./install_server.sh

vim /etc/redis/6379.conf

62 bind 127.0.0.1 172.25.4.13  主redis的标准配置

/etc/init.d/redis_6379 restart

redis 端口打开,进入redis.

[[email protected] redis]# netstat -antlp Active Internet connections (servers and established) Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name tcp 0 0 172.25.4.13:6379 0.0.0.0:*

[[email protected] redis]# redis-cli 127.0.0.1:6379> del 1 (integer) 1

server12:

快速搭建lnmp架构

rpm -ivh php-5.3.3-38.el6.x86_64.rpm php-cli-5.3.3-38.el6.x86_64.rpm php-fpm-5.3.3-38.el6.x86_64.rpm php-cli-5.3.3-38.el6.x86_64.rpm php-pdo-5.3.3-38.el6.x86_64.rpm php-common-5.3.3-38.el6.x86_64.rpm php-mysql-5.3.3-38.el6.x86_64.rpm

/etc/init.d/php-fpm restart

cd /etc/php-fpm.d/

vim www.conf

39 user = nginx 41 group = nginx

vim /etc/nginx/conf.d/default.conf

 10         index  index.php index.html index.htm;

 30     location ~ \.php$ { 31         root           html; 32         fastcgi_pass   127.0.0.1:9000; 33         fastcgi_index  index.php; 34         fastcgi_param  SCRIPT_FILENAME  /usr/share/nginx/html/$fastcgi_script_name; 35         include        fastcgi_params; 36     }

nginx -s reload

cd /usr/share/nginx/html/

vim index.php

php<?

phpinfo()

?>

检测:lnp是否搭建成功

出现php测试页~~~

php装载redis模块

server12:

yum install -y unzip cd redis/unzip phpredis-master.zipcd phpredis-masteryum install gcc -y yum install php-devel-5.3.3-38.el6.x86_64.rpmphpize     生成预编译环境./configure make && make install

在 /usr/lib64/php/modules/ 出现redis模块

cd /etc/php.d cp mysql.ini redis.ini            仿照mysql模块定义redis插件

vim redis.ini

2 extension=redis.so

/etc/init.d/php-fpm reload

php -m |grep re

cp /mnt/redis/test.php index.php

vim index.php

3 $redis->connect(‘172.25.4.13‘,6379) or die ("could net connect redis server");

10$connect = mysql_connect(‘172.25.4.11‘,‘redis‘,‘westos‘);

检验

在宿主机浏览器访问,http://172.25.88.12/

第一次读取数据是从mysql库中读取,后来读取数据就从redis中读取了.

                           

这样读取数据存在隐患,当mysql中的数据发生变化时,用户读取还是redis中旧数据,所以需要考虑触发更新机制,如果想了解可以移步.......

server11: 

mysql> update test.test set name=‘lalala‘ where id=1;

serve13:

除非在更新数据库的同时,手动删除redis的数据,让redis再去mysql取一次数据(不推荐这种方式....)

redis-cli 

127.0.0.1:6379> get 1 "test1"127.0.0.1:6379> get 2"test2"127.0.0.1:6379> del 1             删除1,让redis再去数据库拿一次(integer) 1 127.0.0.1:6379> get 1 (nil) 

查看客户端的变化

时间: 2024-08-11 03:36:21

基于redis缓存数据库实现lnmp架构高速访问的相关文章

Python基础16 - RabbitMQ队列、Redis缓存数据库

@@@文章内容参照老男孩教育 Alex金角大王,武Sir银角大王@@@ RabbitMQ队列 下载安装http://www.rabbitmq.com/install-windows.html RabbitMQ 教程官网:http://www.rabbitmq.com/getstarted.html RabbitMQ:erlang语言 开发的. Python中连接RabbitMQ的模块:pika .Celery(分布式任务队列) .haigha可以维护很多的队列 几个概念说明: Broker:简单

快速搭建Redis缓存数据库

之前一篇随笔——Redis安装及主从配置已经详细的介绍过Redis的安装于配置.本文要讲的是如何在已经安装过Redis的机器上快速的创建出一个新的Redis缓存数据库. 一.环境介绍 1) Linux版本:Red Hat Enterprise Linux Server release 6.1 (Santiago) 2) Redis版本:Redis 2.6.16  64 bit 3) Redis安装路径:/usr/local/webserver/redis 二.安装步骤 1) 将/usr/loca

.NET基于Redis缓存实现单点登录SSO的解决方案

一.基本概念 最近公司的多个业务系统要统一整合使用同一个登录,这就是我们耳熟能详的单点登录,现在就NET基于Redis缓存实现单点登录做一个简单的分享. 单点登录(Single Sign On),简称为 SSO,是目前比较流行的企业业务整合的解决方案之一.SSO的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统. 普通的登录是写入session,每次获取session看看是否有登录就可记录用户的登录状态. 同理多个站点用一个凭证,可以用分布式session,我们可以用r

Redis缓存数据库服务器

Redis缓存数据库服务器Redis是一个开源的科技与内存也可持久化的日志型.Key-Value数据库Redis的存储分为内存存储.磁盘存储和Log文件三部分,配置文件中有三个参数对其进行配置. 优势:和Mecached相比,它更加安全也支持存储的value类型相对更多.Redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步 /var/log/redis_6379.log 日志文件/var/lib/redis/6379

redis缓存数据库

缓存数据库介绍 redis操作 缓存数据库介绍 NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,泛指非关系型的数据库,随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模和高并发的SNS类型的web2.0纯动态网站已经显得力不从心,暴露了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了非常迅速的发展.NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用难题. NoSQL数据库的

LAMP+Redis缓存数据库整合

LAMP在企业生产环境中,除了将MYSQL单独部署在其他服务器.由于MYSQL数据库压力会很大,还会对MYSQL实现主从复制及读写分离,同时会对PHP网站进行调优,通常PHP的优化手段包括:PHP代码本身优化.PHP配置文件优化.为PHP添加缓存模块,将PHP网站数据存入缓存等. 为了减轻MYSQL数据库的压力,这时就用到了Redis缓存数据库服务, LAMP+Redis工作机制:用户通过浏览器访问LAMP网站,并以用户名和密码登录到网站,默认Redis缓存中没有该用户名和密码对应列表,PHP程

Spring AOP + Redis缓存数据库查询

应用场景 我们希望能够将数据库查询结果缓存到Redis中,这样在第二次做同样的查询时便可以直接从redis取结果,从而减少数据库读写次数. 需要解决的问题 操作缓存的代码写在哪?必须要做到与业务逻辑代码完全分离. 如何避免脏读? 从缓存中读出的数据必须与数据库中的数据一致. 如何为一个数据库查询结果生成一个唯一的标识?即通过该标识(Redis中为Key),能唯一确定一个查询结果,同一个查询结果,一定能映射到同一个key.只有这样才能保证缓存内容的正确性 如何序列化查询结果?查询结果可能是单个实体

Redis缓存数据库详解

Redis最为常用的数据类型主要有以下五种: 1)String 2)Hash 3)List 4)Set 5)Sorted set 在具体描述这几种数据类型之前,我们先通过一张图了解下Redis内部内存管理中是如何描述这些不同数据类型的: 首先Redis内部使用一个redisObject对象来表示所有的key和value,redisObject最主要的信息如上图所示:type代表一个value对象具体是何种数据类型,encoding是不同数据类型在redis内部的存储方式,比如:type=stri

Redis缓存数据库的安装与配置(1)

1.安装 tarxf redis-3.2.5.tar.gz cd redis-3.2.5 make mkdir -p /usr/local/redis/bin src目录下这些文件作用如下 redis-server:Redis服务器的daemon启动程序 redis-cli:Redis命令行操作工具.你也可以用telnet根据其纯文本协议来操作 redis-benchmark:Redis性能测试工具,测试Redis在你的系统及你的配置下的读写性能. cp   redis-benchmark  r