濮阳杆衣贸易有限公司

主頁 > 知識庫 > Lua 操作 MongoDB 數(shù)據(jù)庫實例

Lua 操作 MongoDB 數(shù)據(jù)庫實例

熱門標(biāo)簽:漳州智云呼電話機器人 新岸線智能電銷機器人 武漢外呼防封系統(tǒng)多少錢 個人怎么在地圖標(biāo)注需要的店鋪 百度地圖標(biāo)注早餐區(qū)域 冀州市地圖標(biāo)注 怎么去除地圖標(biāo)注 地圖標(biāo)注大廈 清朝地圖標(biāo)注哈爾濱

最近有個工作是使用Nginx + Lua實現(xiàn)一個操作MongoDB數(shù)據(jù)庫的API,主要實現(xiàn)其count和query功能。之前沒有寫過Lua,于是也就勉強著上手,在cloudwu的 lua-mongo 的基礎(chǔ)上實現(xiàn)了操作MongoDB的API。

cloudwu的lua-mongo驅(qū)動實現(xiàn)了連接Mongo,進行find和findOne等基本操作的功能,所以在lua-mongo的基礎(chǔ)上增加了count和query等方法。修改的具體內(nèi)容如下:

1、API基于luajit-2.0開發(fā),相當(dāng)于lua 5.1,需要使用lua-compat-5.2兼容lua 5.2

2、使用ngx.socket.tcp替換mongo.socket模塊

3、增加了count,query,auth等方法

修改之后的代碼見: lua-mongo

具體的操作MongoDB的lua代碼如下:

復(fù)制代碼 代碼如下:

-- lua mongo test script
-- utils
function string:split(sep)
  local sep, fields = sep or ":", {}
  local pattern = string.format("([^%s]+)", sep)
  self:gsub(pattern, function(c) fields[#fields + 1] = c end)
  return fields
end
-- 常量
HOST = "127.0.0.1"
PORT = 27017
KEEPALIVE_TIMEOUT = 60000
KEEPALIVE_SIZE = 100
CONN_TIMEOUT = 3000
DB_USER = "user"
DB_PASSWD = "password"
DB_NAME = "blog"
DB_COLLECTION = "article"
-- 引用
mongo = require("mongo")
cjson = require("cjson.safe")
cbson = require("bson")
-- 狀態(tài)
local status_msg = "error"
local status_code = 500
local message = "unknown error"
local mongo_query = {["category_id"] = {["$in"] = {1,2,3,4}}, ["status"] = {["$ne"] = 2}, ["create_time"] = {["$lte"] = 1427102260}}
local mongo_sort = {["create_time"] = 1}
local mongo_limit = 100
local mongo_skip = 0
local mongo_fields = { ["_id"] = false }
-- 涉及到時間的字段,需要使用bson轉(zhuǎn)化一下
if mongo_query["create_time"] then
  local create_time = mongo_query["create_time"]
  local t = type(create_time)
  if t == "table" then
    for key, value in pairs(create_time) do
      mongo_query["create_time"][key] = cbson.date(value)
    end
  else
    mongo_query["create_time"] = cbson.date(create_time)
  end
end
local conn = mongo.client({ host = HOST, port = PORT })
conn:set_timeout(CONN_TIMEOUT)
local db = conn:getDB(DB_NAME)
local reused_times = conn:get_reused_times()
if reused_times == 0 then
  db:auth(DB_USER, DB_PASSWD)
end
local col = db:getCollection(DB_COLLECTION)
local result = {}
-- count
local count, err = col:count(mongo_query)
local ok, err = conn:set_keepalive(KEEPALIVE_TIMEOUT, KEEPALIVE_SIZE)
if count ~= nil then
  result = count
  status_code = 200
  status_msg = "ok"
  message = "success"
end
-- query
local bson_obj
if mongo_sort then
  bson_obj = cbson.encode_order("$query", mongo_query, "$orderby", mongo_sort)
else
  bson_obj = cbson.encode({ ["$query"] = mongo_query })
end
local results = col:query(bson_obj, mongo_fields, mongo_skip, mongo_limit)
local ok, err = conn:set_keepalive(KEEPALIVE_TIMEOUT, KEEPALIVE_SIZE)
if results then
  for _, object in pairs(results) do
    for key, value in pairs(object) do
      if value == cbson.null then
        object[key] = cjson.null
      else
        local type_name, value = cbson.type(value)
        object[key] = value
      end
    end
  end
  result = results
  status_code = 200
  status_msg = "ok"
  message = "success"
end
-- findOne
local results = col:findOne({["id"] = 14 })
local ok, err = conn:set_keepalive(KEEPALIVE_TIMEOUT, KEEPALIVE_SIZE)
if results then
  for key, value in pairs(results) do
    if value == cbson.null then
      results[key] = cjson.null
    else
      local type_name, value = cbson.type(value)
      results[key] = value
    end
  end
  result = results
  status_code = 200
  status_msg = "ok"
  message = "success"
end
ngx.status = status_code
json_out = cjson.encode({ status = status_msg, message = message, data = result })
ngx.header["Content-Length"] = json_out:len()
ngx.print(json_out)

標(biāo)簽:濰坊 天門 臺灣 儋州 金昌 天門 德宏 宣城

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Lua 操作 MongoDB 數(shù)據(jù)庫實例》,本文關(guān)鍵詞  Lua,操作,MongoDB,數(shù)據(jù)庫,實例,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Lua 操作 MongoDB 數(shù)據(jù)庫實例》相關(guān)的同類信息!
  • 本頁收集關(guān)于Lua 操作 MongoDB 數(shù)據(jù)庫實例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    余姚市| 古浪县| 保康县| 灵山县| 南澳县| 黔南| 巴东县| 怀化市| 涟水县| 北宁市| 柳林县| 山丹县| 仁布县| 黑河市| 天气| 阿城市| 金门县| 潍坊市| 会同县| 桂平市| 登封市| 靖边县| 小金县| 安塞县| 祁门县| 沂源县| 大邑县| 横山县| 精河县| 噶尔县| 仪征市| 北川| 峨山| 民丰县| 老河口市| 沾化县| 油尖旺区| 安康市| 永济市| 江山市| 琼海市|