Openresty部署项目,实现高并发

一、概念

  openresty是一个基于nginx的可伸缩的web平台,是一个强大的 Web 应用服务器,Web 开发人员可以使用 Lua 脚本语言调动 Nginx 支持的各种 C 以及 Lua 模块,更主要的是在性能方面OpenResty可以 快速构造出足以胜任 10K 以上并发连接响应的超高性能 Web 应用系统。

二、安装openresty

1、添加仓库执行命令

yum install yum-utils
yum-configg-manager --add-repo https://openresty.org/package/centos/openresty.repo
2、执行安装
yum install openresty -y
3、安装后默认目录如下
/usr/local/openresty

三、安装nginx

nginx默认已经安装好了。

在usr/local/openresty/nginx修改/usr/local/openresty/nginx/conf/nginx.conf,将配置文件使用的根设置为root,目的就是将来要使用lua脚本的 时候 ,直接可以加载在root下的lua脚本。

cd /usr/local/openresty/nginx/conf

vim nginx.conf

修改

启动openresty

cd /usr/local/openresty/nginx/sbin

./nginx

停止openresty

./nginx -s stop

重启openresty

./nginx -s reload

测试访问openresty是否可用,访问地址http://你的ip

四、部署项目

1、创建mysql数据库

2、创建redis数据库

3、创建/root/lua目录,在该目录下创建update_content.lua: 目的就是连接mysql 查询数据 并存储到redis中。update_content.lua代码如下:

-- 响应类型
ngx.header.content_type="application/json;charset=utf8"
-- json转换模块
local cjson = require("cjson")
-- mysql连接模块
local mysql = require("resty.mysql")
-- 获取所有请求参数
local uri_args = ngx.req.get_uri_args()
-- 获取请求参数中的id
local categoryid = uri_args["id"]

-- 创建数据库对象
local db = mysql:new()
-- 超时时间 1000毫秒
db:set_timeout(1000)
-- 连接数据库属性
local props = {
    host = "192.168.43.129",
    port = 33306,
    database = "dn",
    user = "root",
    password = "123456"
}
-- 连接数据库
local res = db:connect(props)
-- 定义查询语句
local select_sql = "select url,pic from tb_content where status ='1' and category_id='"..categoryid.."'"
res = db:query(select_sql)
db:close()

ngx.say("{\"res\":cjson.encode(res)}")

local redis = require("resty.redis")
local red = redis:new()
red:set_timeout(2000)

local ip = "192.168.43.129"
local port = 6379
red:connect(ip,port)
red:set("content_"..categoryid,cjson.encode(res))
red:close()

ngx.say("{\"flag\":true}")    

  之后再创建read_content.lua、read_new_content.lua、remove_content.lua。

read_content.lua代码如下:

--设置响应头类型
ngx.header.content_type="application/json;charset=utf8"
--获取请求中的参数ID
local uri_args = ngx.req.get_uri_args();
local id = uri_args["id"];
--引入redis库
local redis = require("resty.redis");
--创建redis对象
local red = redis:new()
--设置超时时间
red:set_timeout(2000)
--连接
local ok, err = red:connect("192.168.43.129", 6379)
--获取key的值
local rescontent=red:get("content_"..id)
--输出到返回响应中
ngx.say(rescontent)
--关闭连接
red:close()

read_new_content.lua代码如下:

ngx.header.content_type="application/json;charset=utf8"
local uri_args = ngx.req.get_uri_args();
local categoryid = uri_args["id"];
--获取本地缓存
local cache_ngx = ngx.shared.dis_cache;
--根据ID 获取本地缓存数据
local contentCache = cache_ngx:get('content_cache_'..categoryid);

if contentCache == "" or contentCache == nil
   then
    local redis = require("resty.redis");
    local red = redis:new()
    red:set_timeout(2000)
    red:connect("192.168.43.129", 6379)
    local rescontent=red:get("content_"..categoryid);
    if ngx.null == rescontent or rescontent == ""
      then
        local cjson = require("cjson");
        local mysql = require("resty.mysql");
        local db = mysql:new();
        db:set_timeout(2000)
        local props = {
            host = "192.168.43.129",
            port = 33306,
            database = "dn",
            user = "root",
            password = "123456"
        }
        local res = db:connect(props);
        local select_sql = "select url,pic from tb_content where status ='1' and category_id='"..categoryid.."'";
        res = db:query(select_sql);
        local responsejson = cjson.encode(res);
        red:set("content_"..categoryid,responsejson);
        -- ngx.say(" === ");
        ngx.say(responsejson);
        -- ngx.say(" === ");
        -- ngx.say("{\"响应来自\":\"mysql\"}")
        db:close();
    else
        cache_ngx:set('content_cache_'..categoryid, rescontent, 10*60);
        -- ngx.say("{\"响应来自\":\"redis缓存\"}")
        ngx.say(rescontent);
    end
    red:close();
else
    ngx.say(contentCache)
    -- ngx.say("{\"响应来自\":\"nginx本地缓存\"}");
end

remove_content.lua代码如下:

ngx.header.content_type="application/json;charset=utf8"
local uri_args = ngx.req.get_uri_args();
local categoryid = uri_args["id"];
--获取本地缓存
local cache_ngx = ngx.shared.dis_cache;
--清除本地缓存数据
cache_ngx:set('content_cache_'..categoryid,nil);

local redis = require("resty.redis");
local red = redis:new();
red:connect("192.168.43.129",6379);
red:set("content_"..categoryid,"");

ngx.say("{\"msg\":\"缓存被清除\"}")

修改/usr/local/openresty/nginx/conf/nginx.conf文件: 添加头信息,和 location信息

重启 Nginx
测试地址: http://192.168.43.129/update_content?id=1
此时会将分类 ID=1 的所有广告查询出来,并存入到 Redis 缓存。
测试地址: http://192.168.43.129/read_content?id=1
此时会获取分类 ID=1 的所有广告信息。
上传项目相关文件到 nginx 目录: /usr/local/openresty/nginx/html
就完成啦~
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值