设为首页 收藏本站
查看: 739|回复: 0

[经验分享] 基于redis缓存数据库实现lnmp架构高速访问

[复制链接]

尚未签到

发表于 2018-11-4 07:57:21 | 显示全部楼层 |阅读模式
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 redis@'172.25.88.%'>  mysql  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
DSC0000.png

  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>  cd /usr/share/nginx/html/
  vim index.php
php
  检测:lnp是否搭建成功
  出现php测试页~~~
php装载redis模块
server12:
yum install -y unzip  cd redis/
  unzip phpredis-master.zip
  cd phpredis-master
  yum install gcc -y yum install php-devel-5.3.3-38.el6.x86_64.rpm
  phpize     生成预编译环境
  ./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>  php -m |grep re
DSC0001.png

  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中读取了.
DSC0002.png                             DSC0003.png

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

  mysql> update test.test set name='lalala' where>  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)
  查看客户端的变化
DSC0004.png




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-630429-1-1.html 上篇帖子: NoSQL - redis 备份/主从 下篇帖子: redis主从复制和故障切换
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表