##概览

`app.conf`为应用程序的配置文件,它使用`goconfig`的语法,与windows的ini文件类似。

示例:

app.name=chat
app.secret=pJLzyoiDe17L36mytqC912j81PfTiolHm1veQK6Grn1En3YFdB5lvEHVTwFEaWvj
http.addr=
http.port=9000

[dev]
results.pretty=true
watch=true

log.trace.output = off
log.info.output = stderr
log.warn.output = stderr
log.error.output = stderr

[prod]
results.pretty=false
watch=false

log.trace.output = off
log.info.output = off
log.warn.output = %(app.name)s.log
log.error.output = %(app.name)s.log

每一个段落都是一个运行模式,在最顶层不属于任何一个段落的字段,应用于所有运行模式。`[prod]`段落下的字段应用于生产模式。这样允许为所有的运行模式提供默认值,然后根据需要覆盖。

通过给`revel run`参数可以给指定应用程序相应的运行模式。

##自定义属性

开发者可以通过`revel.Config`变量访问自定义属性,它暴露了简单的api。

##内建属性

**应用程序设置**

- app.name

人类可读的应用程序名称。通常用于一些控制台输出和开发的网页。示例:

app.name = Booking example application

默认值:空

- app.secret

密钥用于加密操作(revel.Sign)。revel通常用它进行会话cookie的签名。通过设置空字符串来禁用签名功能。

初始化一个新的项目时,它被设置为一个随机的字符串(如使用`revel new`创建项目时)。示例:

app.secret = pJLzyoiDe17L36mytqC912j81PfTiolHm1veQK6Grn1En3YFdB5lvEHVTwFEaWvj

默认值:空

**HTTP设置**

- http.port

监听的端口。示例:

http.port = 9000

- http.addr

用于监听的IP地址。在linux上,空的字符串表示通配符- 在windows上,空的字符串会被转为"localhost"

默认值:””

- harness.port

当被harness前置运行时,用于指定应用程序的监听端口。例如, 当harness运行时, 它会在http.port端口监听, 然后在harness.port端口运行程序, 然后对请求进行反向代理。 如果没有harness, 应用程序则直接监听http.port.

默认情况下,会选择一个随机的端口。这仅仅用于当运行在环境限制使用套接字访问程序时。

默认:0

- http.ssl

如果为true, revel会配置自己允许接受SSL请求, 这需要X509证书和密钥文件。

默认值:false

- http.sslcert

指定X509证书文件的路径

默认值: ””

- http.sslkey

指定X509证书密钥

默认值: ””

**Results**

- results.chunked

判断是否使用chunked编码来渲染模板。chunked编码可以在模板被完全渲染之前向客户端发送首个字节用以缩短时间。

默认值:false

- results.pretty

配置`RenderXml`与`RenderJson`产生缩进的`XML/JSON`。示例:

results.pretty = true

默认值:false

**国际化 (i18n)**

- i18n.default_language

当请求的local不被接受时,使用的默认语言。如果未指定,则向请求返回虚拟的消息。示例:

i18n.default_language = en

默认值:””

- i18n.cookie

存储用于指定用户local设置的cookie名。

默认值:“%(cookie.prefix)_LANG” (see cookie.prefix)

**观察器**

revel观察整个项目,并且支持多种类型来源的热重载。开启观察器:

watch = true

如果是false, 什么都不会被观察,并忽略其他`watch.*`配置属性. (这可以适当的用于生产部署)

默认值:true

- watch.templates

如果是true, revel会观察试图的变化并在必要的时候重载它们

默认值:true

- watch.routes
如果为true, revel会观察路由文件的变化并在必要的时候重载它

默认值:true

- watch.code

如果为true, revel会观察Go源码的变化并在必要时重新编译应用程序。(这需要运行harness作为应用程序的前置)

应用程序的`app/`目录的源码都会被观察。(或者任何子目录下的源码)

默认值:true

**Cookies**

revel组建默认使用下列cookies:

REVEL_SESSION
REVEL_LANG
REVEL_FLASH
REVEL_ERRORS

- cookie.prefix

revel在cookie名字中使用的前缀. 这是为了让多个revel程序存在一个域上。示例:

cookie.prefix = MY

这样将会导致以下cookie名:

MY_SESSION
MY_LANG
MY_FLASH
MY_ERRORS

默认值:“REVEL”

**格式化**

- format.date

指定默认情况下日期的格式化字符串. revel将在两个地方使用它:

绑定日期参数至`time.Time`类型

使用模板函数`date`输出日期

默认值:“2006-01-02”

- format.datetime

指定默认情况下时间的格式化字符串. revel将在两个地方使用它:

绑定日期参数至`time.Time`类型

使用模板函数`date`输出日期

默认值:“2006-01-02 15:04”

**数据库**

- db.import

指定需要导入的`database/sql`驱动模块的路径

默认值:””

- db.driver

指定`database/sql`接口类型驱动的名称(用于`sql.Open`)

默认值:””

- db.spec

指定`database/sql`接口类型驱动的数据库名(用于`sql.Open`)

默认值:””

**构建**

- build.tags

构建程序是所指定的构建标签

默认值:””

**Logging**

TODO (移步: http://www.cnblogs.com/hangxin1940/p/3270581.html)

**Cache**

缓存模块接口。

- cache.expires

设置缓存数据的过期时间。用于调用者传递`cache.DEFAULT`常量。

这个字符串必须能被`time.ParseDuration`所接受。

(目前它不能指定为FOREVER)

默认值:“1h” (1小时)

- cache.memcached

如果是true, 将使用memcached作为内存型缓存。

默认值:false

- cache.hosts

一个用逗号分隔的memcached地址列表。缓存内容会动态的存储。可以多次重复地址以提高它的分配比重。

默认值:””

**计划任务**

jobs模块可以用来执行计划任务或者临时任务。

- 具名计划任务

命名的cron计划任务可以如下方式设置名称:

cron.schedulename = @hourly

该计划任务可以在被引用后提交给任务执行器。示例:

jobs.Schedule("cron.schedulename", job)

- jobs.pool

允许任务同时运行的数量. 示例:

jobs.pool = 4

如果是0, 则没有限制.

默认值:10

- jobs.selfconcurrent

如果是true, 允许同一个任务在之前没有执行完的情况下,再次运行。

默认值:false

**模块**

modul允许通过它们的导入路径来给应用程序添加一个模块。示例:

module.testrunner = github.com/robfig/revel/modules/testrunner

Go Revel - app.conf的更多相关文章

  1. Go语言实战 - revel框架教程之MongDB的最佳搭档revmgo

    由于revel框架本身对于model层的编写没有提供任何指导,所以在设计这部分的时候就有些犹豫,反复斟酌到底怎样才算是最佳实践. 我在做山坡网的时候刚开始也纠结了一下,拿不准mongodb的sessi ...

  2. Go语言实战 - revel框架教程之用户注册

    用户注册.登录和注销是任何一个网站都必然会有的功能,可以说,这是重新造轮子做多的领域,每个做网站的人应该都做过很多遍.见微知著,从这么一个小功能其实就可以看到所使用的web框架中的大部分东西. 今天就 ...

  3. revel + swagger 文档也能互动啦

    beego 从 1.3 后开始支持自动化API文档,不过,目测比较复杂,一直期望 revel 能有官方支持. revel 确实已经有了官方支持的计划,有可能将在 0.14 版本支持,现在才 0.11. ...

  4. Go Revel - Logging(日志)

    revel提供了4种日志记录器: 1.`TRACE` - 调试信息 2.`INFO` - 信息 3.`WARN` - 一些无害的异常信息 4.`ERROR` - 必须要关注的错误 日志记录器可以在`a ...

  5. Go Revel - Jobs(任务调度模块)

    revel提供了一个框架用于脱离请求流程的执行异步任务,一般用来执行经常运行的任务.更新缓存数据或发送邮件等. ##启用 该框架作为一个可选的revel模块,默认并不启用.需要更改应用配置来启用它: ...

  6. Go Revel - Testing(测试模块)

    revel提供了一个测试框架来方便的为自己的程序编写功能测试用例. 默认创建的应用骨架附带一个简单的测试用例,这里将它作为起点 ##概览 测试保存在`tests`目录: corp/myapp app/ ...

  7. Go Revel - Modules(模块)

    revel中的模块是一个可以插入到应用中的包, 它允许从第三方引入至应用,并在它和应用之间共享控制器.视图与资源等数据. 一个模块应当具有和revel应用相同的结构."主"程序会以 ...

  8. Go Revel - Cache(缓存)

    revel在服务器端提供了`cache`库用以低延迟的存储临时数据.它缓存那些需要经常访问数据库但是变化不频繁的数据,也可以实现用户会话的存储. ##有效期 一下三种方法为缓存元素设置过期时间: 1. ...

  9. Go Revel - i18n(国际化)

    ##Messages `Messages`信息是对内容提供翻译的外部文本片段.revel提供了组织每一种语言文本片段的message文件.自动区域查找.基于cookie覆盖的消息嵌套和参数. 术语表: ...

随机推荐

  1. Nuxt.js 如何在 asyncData中 请求数据 ,并将拿到的数据传给子组件

    说明:同接口请求一样,也可以进行数据的处理:return  中 左侧的变量  可以直接拿到在页面上使用,也可以传递给子组件 下面再给出一段代码,方便觉得有用的.却又不想手敲的朋友们: async as ...

  2. git 变基(无卵用)

    在当前分支执行rebase即可,会将提交的记录变成一条直线 git rebase

  3. Java svnkit check update commit

    import java.io.File; import org.apache.log4j.Logger;import org.tmatesoft.svn.core.SVNCommitInfo;impo ...

  4. C# 8.0的新的using语法——Using declarations

    我们在代码中经常使用using保障非托管资源的释放 static void Main(string[] args) { using (var options = Parse(args)) { if ( ...

  5. android:ListView 的简单用法

    首 先新 建 一个 ListViewTest 项 目, 并 让 ADT 自 动帮 我 们创 建 好 活动 . 然后 修 改 activity_main.xml 中的代码,如下所示: <Linea ...

  6. EBS 由数据库端找到对应的前台URL地址

    SELECT home_url FROM icx_parameters; SELECT profile_option_value     FROM fnd_profile_option_values  ...

  7. Toast信息提示:下拉收起(基于jQuery)(app信息提示更新)

    直接上效果:

  8. 【Spark】Spark-架构

    Spark-架构 Spark Master at spark://node-01:7077 spark clustermanager_百度搜索 看了之后不再迷糊-Spark多种运行模式 - 简书 Sp ...

  9. RPC简述

    在某种意义上,WebService.REST均是RPC的实现,那么RPC的发展过程如何呢?本文参考了wikipedia,对RPC做一下简要摘记. RPC(RemoteProcedureCall),是进 ...

  10. mock以及特殊场景下对mock数据的处理

    一.为什么要mock 工作中遇到以下问题,我们可以使用mock解决: 无法控制第三方系统某接口的返回,返回的数据不满足要求 某依赖系统还未开发完成,就需要对被测系统进行测试 有些系统不支持重复请求,或 ...