memcached 和 openresty 实现高速缓存机制

2024-01-15 04:08

本文主要是介绍memcached 和 openresty 实现高速缓存机制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

什么是memcached?

不支持持久化,没有安全机制。可以用telnet等工具直接连接memcached。memcached是多线程工作,而redis是单线程工作。各个memcached服务器之间互不通信,各自独立存取数据,不共享任何信息。服务器并不具有分布式功能,分布式部署取决于memcache客户端。
定义 :memcached是一个免费开源的、高性能的、具有分布式内存对象的缓存系统,通过减轻数据库负载来加速动态web应用。

实现步骤

  1. yum install memcached -y 安装软件包,并且开启systemctl start memcached,

通过telnet工具访问本地11211端口

set key flags exptime bytes [noreply] 
value 
  • key:键值 key-value 结构中的 key,用于查找缓存值。
  • flags:可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息 。
  • exptime:在缓存中保存键值对的时间长度(以秒为单位,0 表示永远)
  • bytes:在缓存中存储的字节数
  • noreply(可选): 该参数告知服务器不需要返回数据
  • value:存储的值(始终位于第二行)(可直接理解为key-value结构中的value)
    测试:在这里插入图片描述
  1. 给PHP添加memcache 模块
    链接: memcache模块 提取码: w64x
    软件包下载后tar zxf memcache-4.0.5.2.tgz 解压, yum install autoconf -y ,进入解压后的目录phpize生成configure文件 ./configure检测执行环境, make && make install 编译
  1. 编辑php的主配置文件
    在这里插入图片描述
    /etc/init.d/php-fpm reloa 重启服务
    php -m | grep memcache 检测该模块是否加上在这里插入图片描述
    测试:
    用两个测试文件进行测试: 链接: memcache.php提取码: hnax
    链接: example.php 提取码: d453
    将两个文件放到nginx的默认发布目录中
    在这里插入图片描述

在这里插入图片描述

openresty实现高速缓存机制

传统的客户端访问策略

在这里插入图片描述
访问流程:客户端通过http协议访问nginx(只能处理静态,动态php资源会调用php-pfm)nginx调用php进行处理,php将处理好的结果暂存在memcache,当外部又有相同处理请求时直接通过memcache将结果返回给php再返回给nginx,nginx再返回给客户端。

  • 问题所在:nginx特点:高并发,高性能。但是php动态资源请求是由外部的php处理,至于什么时候能处理完成,是由php决定,不由nginx决定。所以,最大的缺点是会造成nginx阻塞。

高速缓存策略

在这里插入图片描述
访问过程:客户端通过http协议访问nginx(只能处理静态,动态php资源会调用php-pfm)nginx调用php进行处理,php处理完成后将结果返回给nginx,而nginx内部恰好有memcache进行缓存,当有相同请求进来时,nginx就直接可以将结果返回给客户端,明显会有加速的过程,ngingx也不会被阻塞。

为什么使用openresty?

原生的nginx并不带memc和scrache模块,一般情况下还需要下载两个模块并重新编译nginx。这里我们就不再重新编译,我们直接使用openresty(自带memc、scrache模块)。

实现步骤

链接: openresty 提取码: 8g65

  1. tar zxf openresty-1.17.8.2.tar.gz 解压之后, 进入解压的目录./configure --prefix=/opt/openresty( 默认是安装到/usr/local/openresty目录下) 这里我指定安装目录为/opt/openresty,环境检测成功后make && make install
  2. 关闭nginx服务
  3. 将openresty目录下的bin目录写入到环境变量中,并source ~/.bash_profile使之生效
    在这里插入图片描述
  1. openresty 开启服务, 可以看到使用的是80 端口
    配置该配置文件 vim /opt/openresty/nginx/conf/nginx.conf
    在这里插入图片描述在这里插入图片描述

测试:
将原先nginx发布目录中的example.php 移动到openresty的发布目录
cp /usr/local/lnmp/nginx/html/example.php /opt/openresty/nginx/html/
当关闭缓存,即注释掉配置目录中的
在这里插入图片描述
重启服务(openresty -s reload)进行压测 ab -c 10 -n 1000 http://172.25.3.199/example.php (-c 10表示用户并发数为10, -n 1000 表示请求总数为1000)
在这里插入图片描述
当打开缓存,并重启服务,进行压测
在这里插入图片描述
测试结果:在这里插入图片描述
效果明显提升

这篇关于memcached 和 openresty 实现高速缓存机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/607590

相关文章

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

PostgreSQL中MVCC 机制的实现

《PostgreSQL中MVCC机制的实现》本文主要介绍了PostgreSQL中MVCC机制的实现,通过多版本数据存储、快照隔离和事务ID管理实现高并发读写,具有一定的参考价值,感兴趣的可以了解一下... 目录一 MVCC 基本原理python1.1 MVCC 核心概念1.2 与传统锁机制对比二 Postg

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM