1. 程式人生 > >使用Revel(go)開發網站(全面版)

使用Revel(go)開發網站(全面版)

goroutine file format 參數解析 註意 ive mvc nbsp 訪問

Revel很好的利用了Go語言的goroutine,把每一個request都分配到了goroutine裏。不用再寫一大堆的回調。如果你寫過nodejs的話就會深刻的體會到callback hell是什麽樣子的。正是由於Revel有了goroutine,Revel的性能也有了很大的提升。官網號稱請求的吞吐量是Rails的3到10倍。Revel的性能好,在開發方面也提供了非常全面的工具。常用的路由、模板、session、參數解析、等幾乎都有,甚至還提供了一個測試框架。而這些東西的開發都是模塊化的,也就是你可以用自己的實現來代替上述提到的工具。比如,用你覺得合適的活著自己開發的router來代替默認的路由。

這裏默認的你已經配置好了go env。在GOPATH所指定的目錄中的一個裏,運行命令go get github.com/revel/revel之後再運行go get github.com/revel/cmd/revel。好的這個時候你會報錯說無法import到websocket這個包。感謝偉大的全國防火墻,這部分的代碼被屏蔽了。雖然直接下載不行,但是代碼在github上還是有的。所以,還是可以手動下載,之後配置上的。

這裏就需要知道go的另一個很好的工具:http://gopm.io/。這是一個類似於nodejs的npm一樣的工具。他會根據版本號來下載對應的go包,而不是git、hg什麽的。你可以下載這個工具,也可以點download項進入下載頁面(這裏:http://gopm.io/download

)。然後在import path裏輸入 golang.org/x/net,點擊下載。這個包就下載下來了。技術分享

下載成功後,解壓下載包:

技術分享

很大的一包。最後就是我們需要的websocket包。我們準備把全部的這些包都放在需要的目錄下。這個時候回頭看看報錯內容:golang.org/x/net/websocket。但是在我們的GOPATH/src目錄下是沒有這個目錄的。所以我們需要創建websocket之前的全部目錄。之後把我們上面解壓出來的全部的內容拷貝過去。這個問題就可以解決了。最後,手動build一下revel。執行命令:go build github.com/revel/cmd/revel。之後就會在bin目錄下生成revel的二進制可執行文件。到這裏revel的安裝就算完成了。

完成安裝後,運行revel命令會出現如下的提示:

localhost:golang user$ revel
~
~ revel! http://revel.github.io
~
usage: revel command [arguments]

The commands are:

    new         create a skeleton Revel application
    run         run a Revel application
    build       build a Revel application (e.g. for deployment)
    package     package a Revel application (e.g. for deployment)
    clean       clean a Revel application‘s temp files
    test        run all tests from the command-line

Use "revel help [command]" for more information.

運行revel new命令,revel會為你生成一個默認的站點。命令如下:revel new github.com/first_test/app。應為這個站點只是測試用的,我還要生成更多的其他的站點,所以這裏的目錄略復雜一點。你可以根據自己的需要決定目錄。大體的目錄結構式這樣的:

技術分享

運行命令revel run,例如:revel run github.com/first_test/app。這個時候一個站點已經運行起來了。在瀏覽器中輸入localhost:9000,回車。你會看到:

技術分享

現在安裝和配置已經完成。

開發之前先認識一下revel為我們生成的目錄結構:

app                   項目根目錄
├── app               MVC框架目錄
│   ├── controllers   控制器目錄
│   ├── init.go
│   ├── models        模型目錄
│   ├── routes
│   ├── tmp
│   └── views         視圖目錄
├── conf
│   ├── app.conf      配置文件
│   └── routes        路由文件
├── messages          國際化目錄
├── public            靜態文件目錄
└── tests

看起來好復雜的樣子。其實對於開發者來說最常用的並沒有那麽多。最簡單的public,這個目錄下面的是css、img和js文件存放的地方。我們最常用到的就是app/conf/routesapp/app/controllers

現在我們在app/conf/routes這個文件中增加一個路由GET /blogs Blogs.Blogs

技術分享

保存。在views目錄下創建blogs目錄並在其下創建blogs.html文件。這裏只是作為示例使用,所以blogs.html文件是從index.html復制過來改了個名字的。

在controllers下創建我們自己的controller:blogs.go文件,代碼如下:

package controllers

import "github.com/revel/revel"

type Blogs struct {
    *revel.Controller
}

func (c Blogs) Blogs() revel.Result {
    return c.Render()
}

現在重啟服務,在瀏覽器中輸入localhost:9000/blogs就會出現開始的時候出現的index頁的內容。這裏出現index的內容,如前所述,是因為我們直接把index頁的內容拷貝過來的。

由此可見,在revel上的開發一般是如下三步:

  1. 創建我們所需要的路由。
  2. 創建相關的view試圖。
  3. 創建controller。

完成以上三步就已經添加了我們自己需要的東西了。其他的內容的使用可以參考官網的文檔。

還有一點需要註意。先看下圖:

技術分享

我們在添加路由的文件中需要註意最後的一行。* /:controller/:action :controller.:action

*表示的是網絡請求的方法:GET、POST、DELETE等,後面的/:controller/:action是網絡請求的路徑,最後的:controller.:action是用戶定義的controller和在其中的action。所以按照這個路徑訪問的內容,如果controller和action都存在的話,是可以訪問到的。也就是說,如果我們沒有添加任何的路由,只用這個默認的生成的路由也是可以訪問到blogs的。可以試一下,在瀏覽器訪問localhost:9000/blogs/blogs。同樣可以顯示我們添加的blogs.html。這個路徑的第一個blogs就是controller的名字(當讓controller的首字母是會大寫的)。後面的一個blogs對應的就是controller的action也就是Blogs結構的Blogs方法。

controller的數據如何能傳給模板呢。修改blogs.html中的

<h1>It works!</h1>

<h1>{{.greeting}}</h1>

修改Blogs的代碼:

func (c Blogs) Blogs() revel.Result {
    var greeting = "你好REVEL!"
    return c.Render(greeting)
}

這次不用重啟服務了。對於路由、controller和view的修改是不用重啟服務的。Revel支持hot-reload。修改後的內容都會自動重新編譯。刷新瀏覽器。

技術分享

開啟你的Revel之旅吧!

使用Revel(go)開發網站(全面版)