• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 9,  comments - 19,  trackbacks - 0

            背景

            前段時間項目需要一個點擊服務,大致是要根據用戶請求的url及數據庫中的規則,匹配出一個結果并記錄日志。最開始是一個很小的需求,結果業務越來越復雜,業務邏輯中經常要處理header頭和一些其他的信息,導致代碼越來越混亂。在一期結束之后,抽時間把這段時間的工作抽象出了一個輕量級框架,只做了適量的封裝,加入了代碼生成的模塊,可以幫助開發者迅速做出一個可用的web服務。

            介紹

            dodolu框架地址(Github)。

            該框架只做了最小化的封裝,幾乎沒有性能損失,并提供了根據配置文件(meta.lua),自動生成route模塊,nginx.conf配置,logger模塊的功能,減輕了開發工作量,避免重復手寫大量易錯的配置或字符串變量,有助于多人開發統一風格。

            詳情Github的README

            功能

            包括三個部分,一個是web框架,一個是代碼自動生成模塊,一個是魔改出的lua遠程調試器

            web框架部分

            只有1k行以下的代碼,集成了resty.template、resty.cookie、UUID生成等第三方模塊。提供request、response、context、util等庫方便開發人員使用。

            代碼自動生成部分

            可自動生成:

            1. 路由配置
            2. 日志記錄模塊
            3. nginx.conf

            主要目的在于解決nginx配置與lua代碼的分離問題(在日志記錄中尤為嚴重)。

            開發人員新建應用步驟:在App文件夾下,新建lua文件,然后填入do_get()方法即可處理相應的get請求,所有配置在meta/meta.lua里面。

            一個記錄日志并返回1x1gif的例子:

            -- 這個文件下面存放你的業務邏輯
            -- 這個文件下面存放你的業務邏輯
            local app = {} function app.do_get(ctx)      local response = ctx.response     local request = ctx.request     local cookie = ctx.cookie
                response:set_content_type("text/html")     local url = request.uri     -- do some process
                ------------- write log ---------------     -- my_log 日志模塊是根據meta.lua自動生成的     local logger = ctx.get_logger('my_log')       local log_data = { a = "xxx"}     logger.write(log_data, other_params)
                ------------- return empty gif -------     response:empty_gif()     response:close() end
            function app.do_post(ctx) end function app.do_put(ctx) end function app.do_delete(ctx) end
            return app

            lua遠程調試器

            文檔詳細見這里,這里只演示下用法:
            sh debug.sh,然后運行用戶程序,成功后

            Lua Remote Debugger
            Run the program you wish to debug
            Paused at file a.lua
            Type 'help' for commands

            下一步  n

            n
            Paused at file a.lua line 8
            8: print("Start")


            查看源碼  l

            > l  
            source file: a.lua
            2:   
            3:   local tab = {
            4:       foo = 1,
            5:       bar = 2
            6:   }
            7:   
            8:>> print("Start")
            9:   
            10:  local bb = require "b"
            11:  bb.foo()
            12:   
            13:  for i = 1, 10 do
            14:      print("Loop")


            設置斷點   b <file>:<line>   查看    listb

            > b a.lua:11
            > listb 
            a.lua: 11

            查看局部變量  local

            > local {         ["tab"] = {                 {                         ["bar"] = 2,                         ["foo"] = 1,                 },                 "table: 0x2589ee0",         }, }

            查看變量   p tab

            > p tab
            {
                    ["bar"] = 2,
                    ["foo"] = 1,
            }
            繼續執行,直到斷點  r
            > r Paused at file a.lua line 11


            posted on 2014-12-22 18:22 右席 閱讀(3366) 評論(1)  編輯 收藏 引用 所屬分類: Luajit
            91麻精品国产91久久久久| 国产午夜精品理论片久久影视| 亚洲国产成人久久综合碰碰动漫3d | 欧美精品福利视频一区二区三区久久久精品 | 久久亚洲国产精品成人AV秋霞| 久久久久久久波多野结衣高潮| 久久精品黄AA片一区二区三区| 国产伊人久久| 久久久久久久久久久久中文字幕 | 久久精品这里热有精品| 欧美性大战久久久久久 | 久久精品国产精品亚洲精品| 色综合久久中文色婷婷| 成人综合久久精品色婷婷| 91精品无码久久久久久五月天| 亚洲欧洲久久久精品| 亚洲一区二区三区日本久久九| 精品久久久久成人码免费动漫| 久久久久夜夜夜精品国产| 久久亚洲精品无码aⅴ大香| 久久激情亚洲精品无码?V| 久久久久久夜精品精品免费啦| 久久99精品久久久久久野外| 91精品国产综合久久久久久| 亚州日韩精品专区久久久| 久久99精品综合国产首页| 亚洲午夜久久久久妓女影院| 久久人妻少妇嫩草AV蜜桃| 国产成人综合久久久久久| 国产精品久久久久久影院| 国内精品九九久久久精品| 久久婷婷五月综合97色一本一本| 久久久久亚洲爆乳少妇无| 国产精品欧美亚洲韩国日本久久| 国产精品毛片久久久久久久| 久久亚洲精品无码AV红樱桃| 狠狠色婷婷久久综合频道日韩| 性高湖久久久久久久久AAAAA| 精品久久人人妻人人做精品 | 亚洲人成无码www久久久| 精品欧美一区二区三区久久久|