<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                [TOC] # 項目路由設置 前面我們已經創建了 beego 項目,而且我們也看到他已經運行起來了,那么是如何運行起來的呢?讓我們從入口文件先分析起來吧: package main import ( _ "quickstart/routers" "github.com/astaxie/beego" ) func main() { beego.Run() } 我們看到main函數是入口函數,但是我們知道Go的執行過程是如下圖所示的方式: ![](https://box.kancloud.cn/2016-03-12_56e3ccbb8160f.png) 這里我們就看到了我們引入了一個包`_ "quickstart/routers"`,這個包只引入執行了里面的init函數,那么讓我們看看這個里面做了什么事情: ``` package routers import ( "quickstart/controllers" "github.com/astaxie/beego" ) func init() { beego.Router("/", &controllers.MainController{}) } ``` 路由包里面我們看到執行了路由注冊`beego.Router`, 這個函數的功能是映射URL到controller,第一個參數是URL(用戶請求的地址),這里我們注冊的是 `/`,也就是我們訪問的不帶任何參數的URL,第二個參數是對應的 Controller,也就是我們即將把請求分發到那個控制器來執行相應的邏輯,我們可以執行類似的方式注冊如下路由: beego.Router("/user", &controllers.UserController{}) 這樣用戶就可以通過訪問 `/user` 去執行 `UserController` 的邏輯。這就是我們所謂的路由,更多更復雜的路由規則請查詢 [beego 的路由設置](../mvc/controller/router.md) 再回來看看main函數里面的 `beego.Run`, `beego.Run` 執行之后,我們看到的效果好像只是監聽服務端口這個過程,但是它內部做了很多事情: - 解析配置文件 beego 會自動在 conf 目錄下面去解析相應的配置文件 `app.conf`,這樣就可以通過配置文件配置一些例如開啟的端口,是否開啟 session,應用名稱等各種信息。 - 執行用戶的hookfunc beego會執行用戶注冊的hookfunc,默認的已經存在了注冊mime,用戶可以通過函數`AddAPPStartHook`注冊自己的啟動函數。 - 是否開啟 session 會根據上面配置文件的分析之后判斷是否開啟 session,如果開啟的話就初始化全局的 session。 - 是否編譯模板 beego 會在啟動的時候根據配置把 views 目錄下的所有模板進行預編譯,然后存在 map 里面,這樣可以有效的提高模板運行的效率,無需進行多次編譯。 - 是否開啟文檔功能 根據EnableDocs配置判斷是否開啟內置的文檔路由功能 - 是否啟動管理模塊 beego 目前做了一個很帥的模塊,應用內監控模塊,會在 8088 端口做一個內部監聽,我們可以通過這個端口查詢到 QPS、CPU、內存、GC、goroutine、thread 等各種信息。 - 監聽服務端口 這是最后一步也就是我們看到的訪問 8080 看到的網頁端口,內部其實調用了 `ListenAndServe`,充分利用了 goroutine 的優勢 一旦 run 起來之后,我們的服務就監聽在兩個端口了,一個服務端口 8080 作為對外服務,另一個 8088 端口實行對內監控。 通過這個代碼的分析我們了解了 beego 運行起來的過程,以及內部的一些機制。接下來讓我們去剝離 Controller 如何來處理邏輯的。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看