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


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之旅吧!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM