`
liyonghui160com
  • 浏览: 778418 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

nginx openresty组件介绍

阅读更多

 

 

---------------------缓存:

 

1、php的fastcgi缓存 fastcgi_cache

见上面配置:php fastcgi的缓存:

http://www.360doc.com/content/15/0816/14/552866_492084033.shtml

https://zhangge.net/5042.html

https://github.com/FRiCKLE/ngx_cache_purge/

 

 

 

2、缓存代理页面 proxy_pass_cache

见上面配置:proxy代理缓存

实现:本地文件的形式

http://www.open-open.com/lib/view/open1431254539701.html

https://www.aliyun.com/zixun/content/3_12_518236.html

 

 

3、proxy_cache的配置,可以通过挂载一块内存作为缓存的存储空间。

参考http://nginx.org/cn/docs/http/ngx_http_proxy_module.html。 

 

4、nginx的ngx.var.dict+lock实现  减少对后段服务的访问。解决缓存失效风暴

实现:redis,mem

 

lua-resty-lock锁机制

for-cache-locks避免雪崩

https://github.com/openresty/lua-resty-lock#for-cache-locks

 

主动异步过期缓存

https://github.com/lloydzhou/lua-resty-cache

 

srcache-nginx-module

https://github.com/openresty/srcache-nginx-module

这个模块支持和另一个模块配合将页面缓存写入redis集群

https://segmentfault.com/a/1190000003874328

 

 

5、resty.lrucache  lua自身代码实现的cache

 

local lrucache = require "resty.lrucache"

 

-- we need to initialize the cache on the lua module level so that

-- it can be shared by all the requests served by each nginx worker process:

local c = lrucache.new(200)  -- allow up to 200 items in the cache

if not c then

return error("failed to create the cache: " .. (err or "unknown"))

end

 

function _M.go()

c:set("dog", 32)

c:set("cat", 56)

ngx.say("dog: ", c:get("dog"))

ngx.say("cat: ", c:get("cat"))

 

c:set("dog", { age = 10 }, 0.1)  -- expire in 0.1 sec

c:delete("dog")

end

 

 

文档:https://github.com/openresty/lua-resty-lrucache

 

 

 

注意:

修改系统内核的修改通过设置如下参数来设置内存阀值

sysctl -w vm.extra_free_kbytes=6436787

sysctl -w vm.vfs_cache_pressure=10000

 

 

分享到:
评论

相关推荐

    KONG OPENRESTY.pdf

    OpenResty 是一个基于 Nginx 的 Web 服务器,它提供了许多有用的功能,例如 Lua 脚本、SSL/TLS 支持、Websocket 支持等。OpenResty 是 Kong 的一个重要组件,它提供了 Kong 的核心功能。 Mashape 是 Kong 的背后...

    基于带有API的NGINX OpenResty的动态反向代理-Python开发

    Ceryx-坚固,可编程的HTTP(S)反向代理Ceryx是坚固,可编程的反向代理,用于为成千上万的SourceLair项目提供其独特的,启用HTTPS的公共URL。...代理Ceryx在后台使用NGINX OpenResty路由请求,基于

    ceryx:基于NGINX OpenResty和API的动态反向代理

    Ceryx在后台使用NGINX OpenResty来路由请求,该请求基于HTTP请求的Host标头或HTTPS请求中的。 Ceryx查询Redis后端,以确定它将每个请求路由到哪个目标。 API Ceryx API使用户可以通过任何HTTP客户端动态创建,更新...

    OpenResty1.25版本安装包

    在OpenResty中,LuaJIT是关键组件,它是一个即时编译器,将Lua代码编译成高效的机器码,提高了脚本执行速度。LuaJIT与Nginx结合,使得开发者可以通过Lua编写高性能的网络应用,包括API网关、负载均衡器、缓存系统等...

    nginx上传下载之openresty-1.15.8.2.tar.gz

    OpenResty的核心组件包括Nginx、LuaJIT和一系列定制的Nginx模块。Nginx是一个高性能的反向代理服务器,用于处理静态文件、缓存、负载均衡等任务。LuaJIT则是一个高效的Lua虚拟机,它优化了Lua代码的执行效率。结合...

    OpenResty与语⾳交互 — OpenResty及其组件的全栈开发.zip

    《OpenResty与语音交互 — OpenResty及其组件的全栈开发》 OpenResty是一款基于Nginx的开源Web平台,它集成了LuaJIT,使得开发者能够使用Lua语言来扩展Nginx的功能,实现高性能、高并发的Web服务。在语音交互领域,...

    openresty源码(openresty-1.19.9.1.tar.gz)

    而模块(如`src/http/modules/`目录下的文件)则是Nginx处理请求的核心组件,包括HTTP、SSL、rewrite等基础模块,以及OpenResty特有的lua模块,如`ngx_lua`,它实现了在Nginx内部运行Lua脚本的能力。 LuaJIT是...

    programming-openresty

    测试框架Test::Nginx被广泛应用于几乎所有OpenResty组件的测试套件组织中,包括ngx_http_lua模块、大多数lua-resty-* Lua库,以及像CloudFlare的Lua CDN和Lua SSL这样的成熟业务应用程序。这种测试框架能够有效地...

    Openresty二进制版本(openresty-1.19.9.1-win32.zip)

    通过以上介绍,我们可以看到OpenResty是如何将Nginx的高性能与Lua的灵活性结合,为企业级Web服务开发带来强大支持的。`openresty-1.19.9.1-win32.zip`的下载意味着Windows用户也能享受到这一强大工具的便利。

    openresty-1.19.3.1-win64.zip

    《OpenResty与Nginx:深入解析openresty-1.19.3.1-win64.zip》 OpenResty是一款基于Nginx的全功能Web平台,它将LuaJIT集成到Nginx核心中,允许开发者利用Lua语言进行高性能的Web开发和系统编程。"openresty-1.19....

    OpenResty与语⾳交互 — OpenResty及其组件的全栈开发.pdf

    OpenResty基于Nginx的单线程EventLoop模型,擅长处理网络I/O密集型任务,而OpenResty则将这一能力扩展到应用程序服务器领域。然而,对于计算密集型的语音服务,OpenResty面临的主要挑战是如何将计算任务与主线程事件...

    openresty源码包,包含pcre zlib openssl等依赖

    OpenResty是一款基于Nginx和LuaJIT的高性能Web平台,它集成了大量开源库,包括PCRE、ZLIB和OpenSSL等关键组件。这个源码包包含了这些依赖项,使得用户能够在本地环境中编译和搭建OpenResty,从而进行自定义的Web开发...

    openresty1.13.6.2

    OpenResty的核心组件包括Nginx,一个强大的反向代理服务器和负载均衡器,以及LuaJIT,一个高效的Lua虚拟机。通过将LuaJIT嵌入到Nginx中,OpenResty允许用户利用Lua语言的强大功能来编写复杂的HTTP应用,实现路由分发...

    OpenResty 最佳实践

    Nginx是OpenResty的核心组件。在文档中,介绍了Nginx的基本操作,例如新手起步、location匹配规则、静态文件服务、日志记录、反向代理、负载均衡等。同时,也提到了一些实际开发中需要注意的陷阱和常见错误。 文档...

    lua-nginx-redis:Redis,Lua,Nginx,OpenResty笔记和资料

    在IT领域,尤其是在Web开发和高性能服务中,`Nginx`、`Lua`和`Redis`是三个非常重要的技术组件。这篇笔记和资料集合涵盖了这些技术的深度学习和实践应用,结合`OpenResty`进一步提升了它们的功能。 首先,`Nginx`是...

    Apisix及OpenResty、Nginx的高并发探究.pptx

    Apache APISIX、OpenResty 和 Nginx 都是构建高性能、高并发 Web 应用的关键组件。本文将深入探讨这些技术的核心优势以及它们如何协同工作以实现卓越的性能。 **Apache APISIX** Apache APISIX 是一个动态、实时、...

    Openresty二进制版本(openresty-1.19.9.1-win64.zip)

    OpenResty的核心组件是Nginx,一个非常高效的反向代理服务器和负载均衡器。Nginx以其事件驱动、非阻塞I/O模型而著名,能够处理高并发的网络请求。在OpenResty中,Nginx与LuaJIT结合,使得开发者可以通过Lua脚本直接...

    openresty-1.11.2.1.tar.gz

    OpenResty是一个基于Nginx的高性能Web平台,它打包了LuaJIT库,以及其他大量开源组件,如 Lua 库、PCRE 和 OpenSSL,旨在帮助开发者构建动态、高并发的Web应用。OpenResty将Nginx的强大功能与Lua脚本语言的灵活性相...

    openresty-1.17.8.2-win64.zip

    在"openresty-1.17.8.2-win64.zip"这个压缩包中,我们可以期待找到以下组件: 1. **Nginx核心**:这是OpenResty的基础,提供了HTTP和TCP/UDP代理、负载均衡、缓存等功能,以及强大的静态文件处理能力。 2. **...

    OpenResty最佳实践

    在本篇最佳实践指南中,我们将介绍与OpenResty相关的多个知识点,包括其架构、组件、开发技巧以及性能优化等。 首先,我们来探讨Lua编程语言的基础。Lua是一种轻量级的脚本语言,非常适合嵌入到应用程序中提供灵活...

Global site tag (gtag.js) - Google Analytics