Как получить с помощью confd значение строки ключа, генерируемое с помощью etcd
Я использую confd и т. Д. Я следую примеру Confd для Nginx. Я положил эти ключи в мой сервис 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;
}
}
Здесь я хочу поймать значение ключевой строки, как app2 или app1. Я только знаю, как получить его значения. Я хочу сделать что-то вроде этого {{$sever.key}}, но это не работает. Приведенная выше конфигурация {{$sever.key}} неверна, но я сделал это, чтобы показать, чего я хочу.
Возможна ли эта идея?
Есть ли зарезервированное слово для этого или синтаксис?
1 ответ
У меня такая же проблема. Для меня этот код работал (принят в ваш конфиг):
{{range gets "/myapp/upstream/*"}}
server {{base .Key}} {{.Value}}
{{end}}
Для меня главной проблемой было gets
функция. Все примеры, которые я нашел в сети, использовались getvs
, который предоставляет только значения. base
функции, просто удаляет первые части пути вашего ключа.
Для получения дополнительной информации ознакомьтесь с этими документами confd.