3

我正在使用 confd 和 etcd。我正在关注nginx 的 confd 示例。我将这些密钥放在我的 etcd 服务中:

curl http://127.0.0.1:4001/v2/keys/myapp/upstream -XPUT -d dir=true
curl http://127.0.0.1:4001/v2/keys/myapp/subdomain -XPUT -d value="myapp"
curl http://127.0.0.1:4001/v2/keys/myapp/upstream/app2 -XPUT -d value="10.0.1.101:80"
curl http://127.0.0.1:4001/v2/keys/myapp/upstream/app1 -XPUT -d value="10.0.1.100:80"

这是我的 toml 配置:

[template]
prefix = "myapp"
keys = [
  "subdomain",
  "upstream",
]
owner = "nginx"
mode = "0644"
src = "nginx.tmpl"
dest = "/tmp/myapp.conf"
check_cmd  = "/usr/sbin/nginx -t -c {{ .src }}"
reload_cmd = "/usr/sbin/service nginx reload"

这是我的 tmpl 配置。

upstream {{.subdomain}} {
{{range $server := .upstream}}
    #I want to get the key string value
    server {{$sever.key}} {{$server.Value}};
{{end}}
}

server {
    server_name  {{.subdomain}}.example.com;

    location / {
        proxy_pass        http://{{.subdomain}};
        proxy_redirect    off;
        proxy_set_header  Host             $host;
        proxy_set_header  X-Real-IP        $remote_addr;
        proxy_set_header  X-Forwarded-For  $proxy_add_x_forwarded_for;
   }
}

在这里,我想捕捉app2app1之类的键字符串值。我只知道如何获得它的价值。我想做这样的事情{{$sever.key}}但它不起作用。{{$sever.key}}上面的配置是错误的,但我这样做是为了显示我想要什么。

这个想法可能吗?

是否有任何保留词或语法?

4

1 回答 1

2

我有同样的问题。对我来说,这段代码有效(采用您的配置):

{{range gets "/myapp/upstream/*"}}
server {{base .Key}} {{.Value}}
{{end}}

对我来说,主要问题是gets功能。我在网上找到的所有示例都使用了getvs,它只提供了值。这些base功能只是删除了密钥路径的第一部分。

有关更多信息,请查看这些 confd 文档

于 2015-03-02T09:58:30.047 回答