lua nginx mysql_nginx+lua学习笔记

该博客详细介绍了如何在本地Linux环境下搭建CentOS,关闭防火墙,添加用户并配置SSH。接着,通过步骤演示了如何安装OpenResty,配置Nginx,并实现Nginx操作MySQL的功能。文章提供了具体的Lua脚本示例,展示了连接和关闭数据库的函数,以及查询数据的方法。
摘要由CSDN通过智能技术生成

一. 本地linux环境搭建

1. 安装vmware

3. centos关闭防火墙(当然只是方便学习用才关闭)/etc/init.d/iptables stop

4. 添加用户 useradd test

passwd test

5. 配置ssh

vim /etc/ssh/sshd_config

service sshd restart

二. 安装nginx(openresty)

wget "http://openresty.org/download/ngx_openresty-1.5.8.1.tar.gz"

tar xzvf ngx_openresty-1.5.8.1.tar.gz

yum install gcc

yum install readline-devel pcre-devel openssl-devel

./configure

gmake

gmake install

三. 配置nginx

PATH=/usr/local/openresty/nginx/sbin:$PATH

export PATH

vim /usr/local/openresty/nginx/conf/nginx.conf

比如:

worker_processes  1;

error_log logs/error.log;

events {

worker_connections 1024;

}

http {

server {

listen 8080;

location / {

default_type text/html;

content_by_lua '

ngx.say("

hello, world

")

';

}

}

}

四. nginx操作mysql

1. 修改nginx.conf

worker_processes  1;

error_log  /log/nginx/logs/error.log;

events {

worker_connections  1024;

}

http {

include       mime.types;

default_type  application/octet-stream;

log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '

'$status $body_bytes_sent "$http_referer" '

'"$http_user_agent" "$http_x_forwarded_for"';

access_log  /log/nginx/logs/access.log  main;

sendfile        on;

keepalive_timeout  65;

lua_package_path "/usr/local/openresty/nginx/conf/lua/?.lua;;";

server {

listen       8000;

server_name  localhost;

location / {

root   html;

index  index.html index.htm;

}

error_page   500 502 503 504  /50x.html;

location = /50x.html {

root   html;

}

location = /interface{

default_type 'text/plain';

content_by_lua_file conf/lua/interface.lua;

}

}

}

2. 编写lua脚本

-------dbUtil.lua

dbUtil = {}

function dbUtil.getCon()

if not ngx.ctx.dbCon then

local mysql = require "resty.mysql"

local db, err = mysql:new()

if not db then

ngx.log(ngx.ERR, "failed to instantiate mysql: ", err)

return false, nil

end

db:set_timeout(6000)

local ok, err, errinfo, sqlstate = db:connect{

host = "xxx",

port = xxx,

database = "xxx",

user = "xxx",

password = "xxx",

max_packet_size = 1024 * 1024

}

if not ok then

ngx.log(ngx.ERR, "failed to connect: ", err, ": ", errno, " ", sqlstate)

return false, nil

end

ngx.ctx.dbCon = db

end

return true, ngx.ctx.dbCon

end

function dbUtil.closeCon(dbCon)

if not dbCon then return end

local ok, err = dbCon:set_keepalive(10000, 3000)

if not ok then

ngx.say("failed to set keepalive: ", err)

dbCon:close()

return

end

end

return dbUtil

---------interface.lua

local dbutil  = require("dbutil")

local args = ngx.req.get_uri_args()

if args == nil then

ngx.say("{}")

end

local md5 = args["md5"]

if not md5 then

ngx.exit(400)

elseif string.len(tostring(md5)) ~= 32 then

ngx.exit(400)

end

if not cjson then cjson = require "cjson" end

local status, db = dbutil.getCon()

if not status then

ngx.exit(500)

end

local sql = "SELECT xxx FROM xxx WHERE MD5='" .. md5 .. "'"

local res, err, errno, sqlstate = db:query(sql)

if res then

ngx.say(cjson.encode(res))

else

ngx.say(err, errno,sqlstate)

end

dbutil.closeCon(db)

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2014-02-21 15:55

浏览 1141

分类:互联网

评论

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值