操作
编辑教程操作
日志类型
Revel 支持四类日志信息:
- TRACE - 调试信息
- INFO - 一般信息
- WARN - 警告信息
- ERROR - 错误信息
下面是在Revel中使用日志的例子:
now := time.Now()
revel.TRACE.Printf("%s", now.String())
日志记录器默认使用 go 日志.
日志记录器在 app.conf中配置。例如:
app.name = sampleapp
[dev]
log.trace.output = stdout
log.info.output = stdout
log.warn.output = stderr
log.error.output = stderr
log.trace.prefix = "TRACE "
log.info.prefix = "INFO "
log.trace.flags = 10
log.info.flags = 10
[prod]
log.trace.output = off
log.info.output = off
log.warn.output = log/%(app.name)s.log
log.error.output = log/%(app.name)s.log
在开发环境中:
- 显示详细日志
- info 或 trace信息以app.conf中定义的前缀显示信息
在生产环境中:
- info 和 trace 日志将被忽略
- 警告 和 错误信息被写入 log/sampleapp.log 文件
根据 标记常量修改日志格式,。例如, 01:23:23 /a/b/c/d.go:23 Message 格式,使用标记 Ltime | Llongfile = 2 | 8 = 10
开发状态:
如果日志目录log不存在,Revel 会自动创建日志目录。
版本控制
nathany上已经给出了Go包版本控制的许多信息。然而, 那时还没有一个包版本管理的社区标准。因此, 只能由开发者确保软件安全与可重复构建。
如果你使用Revel构建应用程序, 开发者应避免由于不兼容造成的问题。你的构建过程不应当使用go get获取Revel的主分支。
处理这种情况最简单的方法是签出Revel和所有依赖包到你的代码库中。如果你使用git, 可以把这些库作为你项目的子代码库。
部署
几种常见的部署方法如下:
- 本地编译代码,然后复制到服务器上运行
- 在服务器上拉取代码,然后编译、运行
- 使用 Heroku 进行部署
使用命令行演示互动部署 - 一般将web服务器作为守护程序运行。常用工具有:
- Ubuntu Upstart
- systemd
本地编译
目标机器上不需要安装Go语言环境。Revel命令行工具 提供了package包命令,用来编译和压缩应用程序, 如下所示:
# 本地测试运行
$ revel run import/path/to/app
.. 测试程序 ..
# 打包程序
$ revel package import/path/to/app
打包的文件准备好了: app.tar.gz
# 复制到目标机器
$ scp app.tar.gz target:/srv/
# 在目标机器上运行
$ ssh target
$ cd /srv/
$ tar xzvf app.tar.gz
$ bash run.sh
如果您的本地机器与目标机器的架构相同,那么不会有什么问题。否则,你需要参考交叉编译来构建指定平台架构的程序。
增量部署
由于静态链接的二进制程序带有完整的资源文件,可能会变得相当大,所以支持增量部署。
# 构建应用程序到一个临时目录
$ revel build import/path/to/app /tmp/app
# 将临时目录 Rsync 到服务器上的主目录
$ rsync -vaz --rsh="ssh" /tmp/app server
# 连接到服务器,并重新启动应用程序
...
Rsync 支持ssh完整的复制操作。例如, 下面是一个更复杂的操作:
# 一个使用自定义证书、登录名和目标目录的例子
$ rsync -vaz --rsh="ssh -i .ssh/go.pem" /tmp/myapp2 ubuntu@ec2-50-16-80-4.compute-1.amazonaws.com:~/rsync
在服务器上构建
这种方法依赖你的版本控制系统来分发、更新代码。你需要在服务器上安装Go语言环境。好处是,你避免了潜在的交叉编译。
$ ssh server
... 安装Go语言环境 ...
... 配置存储库 ...
# 进入你的应用程序所在的目录 (GOPATH环境变量), 拉取代码, 并运行。
$ cd gocode/src/import/path/to/app
$ git pull
$ revel run import/path/to/app prod
Heroku
Revel 维护了一个 Heroku Buildpack, 允许一条命令即可部署代码,请参考 自述文件 使用说明
交叉编译
为了创建一个交叉编译环境,我们需要从源代码构建。参考 从源代码安装Go 获取更多信息。你必须正确设置 $PATH 和 $GOPATH 环境变量, 否则,如果已经有一个二进制的Go语言包存在,你会陷入严重的错误。
当Go编译器安装成功后,通过指定 GOOS 和 GOARCH 目标环境来建立交叉编译环境。参考 可用的环境变量 获取更多信息。
$ cd /path/to/goroot/src
$ GOOS=linux GOARCH=amd64 ./make.bash --no-clean
$ GOOS=windows GOARCH=386 ./make.bash --no-clean
在新的环境中安装Revel,然后设定目标架构,打包应用程序。
$ GOOS=linux GOARCH=amd64 revel package import/path/to/app
然后,将压缩包复制到目标平台。
选择支付方式:
备注:
转账时请填写正确的金额和备注信息,到账由人工处理,可能需要较长时间