JSRUN 用代码说话

操作

编辑教程

操作

日志类型

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

然后,将压缩包复制到目标平台。

JSRUN闪电教程系统是国内最先开创的教程维护系统, 所有工程师都可以参与共同维护的闪电教程,让知识的积累变得统一完整、自成体系。 大家可以一起参与进共编,让零散的知识点帮助更多的人。
X
支付宝
9.99
无法付款,请点击这里
金额: 0
备注:
转账时请填写正确的金额和备注信息,到账由人工处理,可能需要较长时间
如有疑问请联系QQ:565830900
正在生成二维码, 此过程可能需要15秒钟