我的开发环境包括一个容器中的本地consul服务器和另一个容器中的应用程序(运行consul-template),所有这些都与docker-compose相关联。我希望一切都能无缝地旋转,无需人工干预开发(安全性不是问题),所以我想通过挂载特定文件以编程方式在启动时以默认的方式添加默认键/值对。
我一直遇到这个问题,每当我尝试使用API在启动时向领事添加k / v对时,它都会失败,并显示错误2016/06/03 21:10:15 [ERR] http: Request PUT /v1/kv/app/secret_key, error: No cluster leader from=[::1]:58888
。如果我事先添加一个睡眠命令,给予领事足够的时间选举一个领导者,它就有效。但是,必须有一种更好的方法来同步这样做,对吧?特别是当群集中只有一个节点时。
这是我到目前为止所做的。
Dockerfile
FROM voxxit/consul
ARG REFRESHED_AT="2016-06-01"
ARG DOCKERIZE_VERSION="v0.2.0"
ENV CONSUL_ADDR="http://localhost:8500"
ADD "https://github.com/jwilder/dockerize/releases/download/${DOCKERIZE_VERSION}/dockerize-linux-amd64-${DOCKERIZE_VERSION}.tar.gz" /tmp
RUN set -x && \
apk add --update curl jq && \
cd /tmp && \
tar -C /usr/local/bin -xzvf dockerize-linux-amd64-${DOCKERIZE_VERSION}.tar.gz && \
rm -rf /var/cache/apk/* /tmp/*
RUN mkdir -p /etc/consul.d/data
COPY ./consul.json /etc/consul.d/
COPY ./entrypoint.sh /
RUN chmod +x /entrypoint.sh
WORKDIR /etc/consul.d/data
VOLUME ["/etc/consul.d/data"]
ENTRYPOINT ["/entrypoint.sh"]
CMD ["dockerize", "-stdout", "/var/log/consul.out", "-stderr", "/var/log/consul.err"]
entrypoint.sh
#!/bin/bash -e
# Start consul server and wait for it
nohup consul agent -config-file=/etc/consul.d \
>/var/log/consul.out 2>/var/log/consul.err &
dockerize -wait "${CONSUL_ADDR}" # <-- Not working as I'd hoped
DEFAULT_CONFIG="/etc/consul.d/data/default.json"
if [ -f $DEFAULT_CONFIG ]; then
# Bulk upload default k/v pairs
while IFS=" " read -r key value; do
prefix="${APP_NAME}"
result=$(curl -s -X PUT -d "$value" "${CONSUL_ADDR}/v1/kv/${prefix}/${key}")
if [ "$result" != "true" ]; then
echo "ERROR loading $value into $key for $prefix"
exit 1
fi
done < <(jq -r 'to_entries|map("\(.key) \(.value|tostring)")|.[]' $DEFAULT_CONFIG)
fi
echo "init complete - ready for start up"
exec "$@"
consul.json
{
"bootstrap": true,
"client_addr": "0.0.0.0",
"data_dir": "/data",
"enable_syslog": false,
"log_level": "INFO",
"server": true,
"ui_dir": "/ui",
"http_api_response_headers": {
"Access-Control-Allow-Origin": "*"
}
}
必须有一些方法可以暂停批量上传,直到我确定领事已经启动并运行。
答案 0 :(得分:0)
我遇到了类似的问题,我通过在单个节点上指定预期Consul节点的数量(使用命令行参数Bootstrap cannot be provided with an expected server count
而不是简单的-bootstrap-expect=5
来解决我的问题(-boostrap
)节点