xavante运行cgilua流程
安装软件
需要安装三个lua 库: xavante wsapi cgilua
luarocks install xavante
http://keplerproject.github.io/xavante/manual.html#install
Xavante is a Lua HTTP 1.1 Web server that uses a modular architecture based on URI mapped handlers. Xavante currently offers a file handler, a redirect handler and a WSAPI handler. Those are used for general files, URI remapping and WSAPI applications respectively.
luarocks install wsapi-xavante
http://keplerproject.github.io/wsapi/index.html
WSAPI is an API that abstracts the web server from Lua web applications. By coding against WSAPI your application can run on any of the supported servers and interfaces (currently CGI, FastCGI and Xavante, on Windows and UNIX-based systems).
https://github.com/keplerproject/wsapi
cgilua
luarocks install cgilua
https://github.com/keplerproject/cgilua
CGILua is a tool for creating dynamic Web pages and manipulating input data from Web forms. CGILua allows the separation of logic and data handling from the generation of pages, making it easy to develop web applications with Lua.
运行脚本
切换到cgilua样例目录
root@fqs:/home/share/cgilua-master/cgilua-master/examples# lua xavante_cgilua.lua
[2016-06-22 22:16:50] Xavante started on port(s) 8080
脚本内容 laucher:
xavante = require "xavante"
xavante.filehandler = require "xavante.filehandler"
xavante.cgiluahandler = require "xavante.cgiluahandler"
xavante.redirecthandler = require "xavante.redirecthandler"-- Define here where Xavante HTTP documents scripts are located
local webDir = "."local simplerules = {
{ -- URI remapping example
match = "^[^%./]*/$",
with = xavante.redirecthandler,
params = {"index.lp"}
},{ -- cgiluahandler example
match = {"%.lp$", "%.lp/.*$", "%.lua$", "%.lua/.*$" },
with = xavante.cgiluahandler.makeHandler (webDir)
},
{ -- filehandler example
match = ".",
with = xavante.filehandler,
params = {baseDir = webDir}
},
}xavante.HTTP{
server = {host = "*", port = 8080},
defaultHost = {
rules = simplerules
},
}-- Displays a message in the console with the used ports
xavante.start_message(function (ports)
local date = os.date("[%Y-%m-%d %H:%M:%S]")
print(string.format("%s Xavante started on port(s) %s",
date, table.concat(ports, ", ")))
end)xavante.start()
WSAPI Xavante 安装后自带launcher
http://keplerproject.github.io/wsapi/manual.html
Xavante
If you installed the
wsapi-xavantepackage you already have a Xavante launcher with WSAPI support. Just run thewsapiscript in the path you want as your document root, and point your browser either to thehello.luaorhello.wsscript (both extensions are treated as WSAPI applications). Seewsapi --helpfor the launcher's configuration options.
launcher:
root@fqs:/usr/local/bin# cat wsapi
#!/bin/shexec '/usr/bin/lua5.1' -e 'package.path="/root/.luarocks/share/lua/5.1/?.lua;/root/.luarocks/share/lua/5.1/?/init.lua;/usr/local/share/lua/5.1/?.lua;/usr/local/share/lua/5.1/?/init.lua;"..package.path; package.cpath="/root/.luarocks/lib/lua/5.1/?.so;/usr/local/lib/lua/5.1/?.so;"..package.cpath' -e 'local k,l,_=pcall(require,"luarocks.loader") _=k and l.add_context("wsapi-xavante","1.6.1-1")' '/usr/local/lib/luarocks/rocks/wsapi-xavante/1.6.1-1/bin/wsapi' "$@"
主要实现在 '/usr/local/lib/luarocks/rocks/wsapi/1.6.1-1/bin/wsapi'
此内容,与运行脚本章节的 launcher 功能角色上相同, 但是其比较完善。
root@fqs:/usr/local/bin# cat /usr/local/lib/luarocks/rocks/wsapi-xavante/1.6.1-1/bin/wsapi
#!/usr/bin/env lualocal lfs = require "lfs"
local util = require "wsapi.util"
local wsx = require "wsapi.xavante"
local xavante = require "xavante"
local filehandler = require "xavante.filehandler"
local redirecthandler = require "xavante.redirecthandler"local usage = [[
Usage: wsapi [options] [document root]Starts a Xavante instance to serve static files and WSAPI applications.
Treats .lua and .ws files as WSAPI applications, and everything else as
static (but see the --cgilua and --op options, below).The default document root is the current path.
Options:
-c<file>, --config=<file> Runs the specified file for additional
configuration before starting the server
-l<file>, --log=<file> Logs all output to the file (default stdout
and stderr)
-p<port>, --port=<port> Binds to the specified port (default 8080)
--cgilua Adds .lp and .cgi rules for CGILua pages and
scripts
--op Adds an .op rule that for Orbit pages
-r, --reload Reloads applications on every request
-h, --help Shows this help screen]]
local config = {}
local opts, args = util.getopt({ ... }, "clp")
if opts.h or opts.help then
print(usage)
os.exit()
endlocal config = {
docroot = args[1] or lfs.currentdir(),
logfile = opts.l or opts.log,
port = tonumber(opts.p or opts.port) or 8080,
start_message = function (ports)
local date = os.date("[%Y-%m-%d %H:%M:%S]")
print(string.format("%s Xavante started on port(s) %s",
date, table.concat(ports, ", ")))
end,
rules = {},
is_finished = function() return false end,
reload = opts.r or opts.reload,
isolated = true
}local config_file = opts.c or opts.config
if config_file then
local f, err = util.loadfile(config_file, setmetatable(config, { __index = _G }))
if not f then
io.stderr:write("Cannot load config file " .. config_file .. ":\n\n" .. err .. "\n")
os.exit()
end
local res, err = pcall(f)
if not res then
io.stderr:write("Error in config file:\n\n" .. err .. "\n")
os.exit()
end
setmetatable(config, nil)
endif config.logfile then
local tostring = tostring
local log = io.open(config.logfile, "a+")
if not log then
error("Could not open log file. Please check the write permissions for: " .. config.logfile)
end
io.stdout = log
io.stderr = log
print = function (...)
local nargs = select('#', ...)
for i = 1, nargs-1 do
log:write(tostring((select(i, ...))))
log:write("\t")
end
log:write(tostring(select(nargs, ...)))
log:write("\n")
end
endlocal ONE_HOUR = 60 * 60
local ONE_DAY = 24 * ONE_HOURlocal launcher_params = {
isolated = config.isolated,
reload = config.reload,
period = config.period or ONE_HOUR,
ttl = config.ttl or ONE_DAY
}config.rules = config.rules or {}
local function addrule(rule)
config.rules[#config.rules+1] = rule
endaddrule{ -- URI remapping example
match = "^/$",
with = redirecthandler,
params = {"index.html"}
}addrule{ -- wsapihandler example
match = {"%.lua$", "%.lua/" },
with = wsx.makeGenericHandler (config.docroot, launcher_params)
}addrule{ -- wsapihandler example
match = {"%.ws$", "%.ws/" },
with = wsx.makeGenericHandler (config.docroot, launcher_params)
}if opts.cgilua then
local hcgi = require "xavante.cgiluahandler"
addrule{
match = {"%.lp$", "%.lp/.*$", "%.cgi$", "%.cgi/.*$" },
with = hcgi.makeHandler (config.docroot, launcher_params)
}
end
if opts.op then
local hop = require "orbit.ophandler"
addrule{
match = {"%.op$", "%.op/.*$" },
with = hop.makeHandler (config.docroot, launcher_params)
}
endaddrule{ -- filehandler example
match = ".",
with = filehandler,
params = { baseDir = config.docroot }
}-- Displays a message in the console with the used ports
xavante.start_message(config.start_message)io.stdout:write("[Xavante launcher] Starting Xavante...\n")
xavante.HTTP{
server = {host = "*", port = config.port},defaultHost = {
rules = config.rules
},
}res, err = pcall(xavante.start, function (...)
io.stdout:flush()
io.stderr:flush()
return config.is_finished(...)
end, config.timeout)
if not res then
io.stderr:write(err .. "\n")
else
io.stderr:write("[Xavante launcher] Xavante stopped\n")
end
root@fqs:/usr/local/bin#
运行流程分析
1、 xavante 负责服务器的启动, 并制定 cgilua 请求处理的handler注册
{ -- cgiluahandler example
match = {"%.lp$", "%.lp/.*$", "%.lua$", "%.lua/.*$" },
with = xavante.cgiluahandler.makeHandler (webDir)
},
2、xavante.cgiluahandler.makeHandler (webDir) , handler的构造
-------------------------------------------------------------------------------
-- Returns the CGILua handler
-------------------------------------------------------------------------------
function _M.makeHandler (diskpath, params)
params = setmetatable(params or {}, { __index = { modname = "wsapi.sapi",
bootstrap = bootstrap } })
local sapi_loader = common.make_isolated_launcher(params)
return xavante.makeHandler(sapi_loader, nil, diskpath)
end
其中,handler构造依赖了 xavante的wsapi, with的值可以是 function(req, res)
local xavante = require "wsapi.xavante" --- 专门针对 xavante写的wsapi的适配
-- Makes a WSAPI handler for a single WSAPI application
function _M.makeHandler (app_func, app_prefix, docroot, app_path, extra_vars)
return function (req, res)
return wsapihandler(req, res, app_func, app_prefix, docroot, app_path, extra_vars)
end
end
wsapi.xavante中存在 构造 cgivars 表。
make_handler 入参 wsapi_loader需要 wsapi.sapi文件支持
params = setmetatable(params or {}, { __index = { modname = "wsapi.sapi",
bootstrap = bootstrap } })
local sapi_loader = common.make_isolated_launcher(params)
此loader即加载 wsapi.sapi文件, 文件被rings包裹运行, 即 wsapi.sapi –> cgilua 都是在独立环境下运行
前面 “wsapi.xavante中存在 构造 cgivars 表” 也会传入 独立的运行环境。
wsapi.sapi 直接 调用 cgilua
local cgilua = require "cgilua"
cgilua.main()
return res:finish()
end
WSAPI Xavante 安装后自带 wsapi.cgi 程序
root@fqs:/usr/local/bin# ls
cgilua.cgi cgilua.fcgi summary.lua wsapi wsapi.cgi
root@fqs:/usr/local/bin#
root@fqs:/usr/local/bin#
root@fqs:/usr/local/bin# cat wsapi.cgi
#!/bin/shexec '/usr/bin/lua5.1' -e 'package.path="/root/.luarocks/share/lua/5.1/?.lua;/root/.luarocks/share/lua/5.1/?/init.lua;/usr/local/share/lua/5.1/?.lua;/usr/local/share/lua/5.1/?/init.lua;"..package.path; package.cpath="/root/.luarocks/lib/lua/5.1/?.so;/usr/local/lib/lua/5.1/?.so;"..package.cpath' -e 'local k,l,_=pcall(require,"luarocks.loader") _=k and l.add_context("wsapi","1.6.1-1")' '/usr/local/lib/luarocks/rocks/wsapi/1.6.1-1/bin/wsapi.cgi' "$@"
root@fqs:/usr/local/bin#
实现文件:
root@fqs:/usr/local/bin# cat /usr/local/lib/luarocks/rocks/wsapi/1.6.1-1/bin/wsapi.cgi
#!/usr/bin/lua-- Generic WSAPI CGI launcher, extracts application to launch
-- either from the command line (use #!wsapi in the script)
-- or from SCRIPT_FILENAME/PATH_TRANSLATEDlocal wsapi = require "wsapi"
local common = require "wsapi.common"
local cgi = require "wsapi.cgi"local arg_filename = (...)
local function wsapi_loader(wsapi_env)
local path, file, modname, ext =
common.find_module(wsapi_env, arg_filename, "wsapi.cgi", { "SCRIPT_FILENAME", "PATH_TRANSLATED" })
if not path then
error({ 404, "Resource " .. wsapi_env.SCRIPT_NAME .. " not found" })
end
wsapi.app_path = path
local app = common.load_wsapi(path, file, modname, ext)
wsapi_env.APP_PATH = path
return app(wsapi_env)
endcgi.run(wsapi_loader)
root@fqs:/usr/local/bin#
此cgi程序用于运行 满足 wsapi接口的应用脚本, 例如:
http://keplerproject.github.io/wsapi/manual.html
#!/usr/bin/env wsapi.cgi module(..., package.seeall) function run(wsapi_env)
local headers = { ["Content-type"] = "text/html" } local function hello_text()
coroutine.yield("<html><body>")
coroutine.yield("<p>Hello Wsapi!</p>")
coroutine.yield("<p>PATH_INFO: " .. wsapi_env.PATH_INFO .. "</p>")
coroutine.yield("<p>SCRIPT_NAME: " .. wsapi_env.SCRIPT_NAME .. "</p>")
coroutine.yield("</body></html>")
end return 200, headers, coroutine.wrap(hello_text)
end
xavante运行cgilua流程的更多相关文章
- Servlet简介与Servlet和HttpServlet运行的流程
1.Servlet [1] Servlet简介 > Server + let > 意为:运行在服务器端的小程序. > Ser ...
- 老李推荐:第5章2节《MonkeyRunner源码剖析》Monkey原理分析-启动运行: 启动流程概览
老李推荐:第5章2节<MonkeyRunner源码剖析>Monkey原理分析-启动运行: 启动流程概览 每个应用都会有一个入口方法来供操作系统调用执行,Monkey这个应用的入口方法就 ...
- SpringMVC生命周期,SpringMVC运行流流程
SpringMVC详细运行流程图 SpringMVC运行原理 1. 客户端请求提交到DispatcherServlet2. 由DispatcherServlet控制器查询一个或多个HandlerMap ...
- coTurn 运行在Windows平台的方法及服务与客户端运行交互流程和原理
coTurn是一个开源的STUN和TURN及ICE服务项目,只是不支持Windows.为了在window平台上使用coTurn源码,需要在windows平台下安装Cygwin环境,并编译coTurn源 ...
- 魔兽私服TrinityCore 运行调试流程
配置参见上一篇:TrinityCore 魔兽世界私服11159 完整配置 (1)启动Web服务器 打开TC2_Web_Mysql目录,运行“启动Web服务器.exe” 自动弹出帐号注册界面,并启动Ap ...
- Spark源码分析之一:Job提交运行总流程概述
Spark是一个基于内存的分布式计算框架,运行在其上的应用程序,按照Action被划分为一个个Job,而Job提交运行的总流程,大致分为两个阶段: 1.Stage划分与提交 (1)Job按照RDD之间 ...
- 【hadoop2.6.0】通过代码运行程序流程
之前跑了一下hadoop里面自带的例子,现在顺一下如何通过源代码来运行程序. 我懒得装eclipse,就全部用命令行了. 整体参考官网上的:http://hadoop.apache.org/docs/ ...
- Mybaits 运行原理流程时序图
1 .初始化sqlsessionFactory 2openSession 3.getMapper返回接口的代理对象 包含了SqlSession对象 4.查询流程
- php运行代码流程和性能优化方法
---恢复内容开始--- php文件->扫描->zd引擎去理解->opcodes->执行->输出 例子,用white随机循环20000数据进行性能测试,分别对比isset ...
随机推荐
- 定期来一次“绩效谈话”(摘自易中)
值得借鉴学习 管理者和下属直接的互动关系当中,需要有一个定期的反馈机制.员工在工作当中需要管理者给他持续地反馈.以下是一个绩效谈话的标准程序: 一:说明会谈的目的和时间:我们用10分钟对你上一阶段的工 ...
- ihhh题解
10分做法: 由于空间卡得紧,所以给了10分暴力分0.0所以大家很容易就知道暴力就是线段树套ac自动机辣时间:$O((\sum |qSi| + \sum |nSi|)*log Q)$空间:$O((\s ...
- BZOJ3653: 谈笑风生
Description 设T 为一棵有根树,我们做如下的定义:• 设a和b为T 中的两个不同节点.如果a是b的祖先,那么称“a比b不知道高明到哪里去了”.• 设a 和 b 为 T 中的两个不同节点.如 ...
- BZOJ2322: [BeiJing2011]梦想封印
Description 渐渐地,Magic Land上的人们对那座岛屿上的各种现象有了深入的了解. 为了分析一种奇特的称为梦想封印(Fantasy Seal)的特技,需要引入如下的概念: 每一位魔法的 ...
- C语言(2)
C语言(2)---变量 基本格式: 变量类型 变量名1[,变量名2,变量名3,...变量名n]: 注意: 1.在C语言中如果申请一个变量,里面存放小数,则用float表示,且在输出时需要注意prin ...
- 再说memcache的multiget hole(无底洞)
关键词:multiget hole,memcache 适用于:java,php 基础知识背景: 1)multiget 是什么: multiget 指的是从 memcache(或其他分布式缓存) ...
- CentOS评估磁盘I/O性能读写极限测试
用一个fio工具 安装 yum -y install fio 二,FIO用法: 随机读:fio -direct=1 -iodepth 1 -thread -rw=randread -ioengine ...
- Picture effect of JavaScript
每隔一定时间跟换图片Img = new Array("image/2.jpg","image/1.jpg","image/3.jpg",&q ...
- jsp统测
. 解析:B/S架构并不是C/S架构的替代品,有些程序例如大型的网络游戏一般使用的是C/S架构 . 解析:web-inf目录中的文件不能被客户端直接访问.所以正确答案为c 解析:jsp的是jsp内置 ...
- [LintCode] Add Binary 二进制数相加
Given two binary strings, return their sum (also a binary string). Have you met this question in a r ...