[TOC]
# 項目路由設置
前面我們已經創建了 beego 項目,而且我們也看到他已經運行起來了,那么是如何運行起來的呢?讓我們從入口文件先分析起來吧:
package main
import (
_ "quickstart/routers"
"github.com/astaxie/beego"
)
func main() {
beego.Run()
}
我們看到main函數是入口函數,但是我們知道Go的執行過程是如下圖所示的方式:

這里我們就看到了我們引入了一個包`_ "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 如何來處理邏輯的。
- 寫在前面的話
- 第0章 beego 簡介
- 0.1 為beego貢獻
- 0.2 發布版本
- 0.3 升級指南
- 第1章 安裝升級
- 1.1 bee工具的使用
- 第2章 快速入門
- 2.1 新建項目
- 2.2 路由設置
- 2.3 Controller運行機制
- 2.4 Model邏輯
- 2.5 View編寫
- 2.6 靜態文件處理
- 第3章 beego的MVC架構
- 3.1 Model設計
- 3.1.1 概述
- 3.1.2 ORM使用
- 3.1.3 CRUD操作
- 3.1.4 高級查詢
- 3.1.5 原生SQL查詢
- 3.1.6 構造查詢
- 3.1.7 事物處理
- 3.1.8 模型定義
- 3.1.9 命令模式
- 3.1.10 測試用例
- 3.1.11 自定義字段
- 3.1.12 FAQ
- 3.2 View設計
- 3.2.1 模板語法指南
- 3.2.2 模板處理
- 3.2.3 模板函數
- 3.2.4 靜態文件處理
- 3.2.5 模板分頁處理
- 3.3 Controller設計
- 3.3.1 參數配置
- 3.3.2 路由設置
- 3.3.3 控制器函數
- 3.3.4 XSRF過濾
- 3.3.5 請求數據處理
- 3.3.6 session 控制
- 3.3.7 過濾器
- 3.3.8 flash 數據
- 3.3.9 URL構建
- 3.3.10 多種格式數據輸出
- 3.3.11 表單數據驗證
- 3.3.12 錯誤處理
- 3.3.13 日志處理
- 第4章 beego的模塊設計
- 4.1 session 模塊
- 4.2 grace 模塊
- 4.3 cache 模塊
- 4.4 logs 模塊
- 4.5 httplib 模塊
- 4.6 context 模塊
- 4.7 toolbox 模塊
- 4.8 config 模塊
- 4.9 i18n 模塊
- 第5章 beego高級編程
- 5.1 進程內監控
- 5.2 API自動化文檔
- 第6章 應用部署
- 6.1 獨立部署
- 6.2 Supervisor部署
- 6.3 Nginx 部署
- 6.4 Apache 部署
- 第7章 第三方庫
- 第8章 應用例子
- 8.1 在線聊天室
- 8.2 短域名服務
- 8.3 Todo列表
- 第9章 FAQ