Nginx 做为优秀的开源软件,凭借其高性能高并发等特色,经常做为web和反向代理服务部署在生产环境中。可是当 Nginx 的规模较大时, Nginx 的运维成本也是不断上升。本文介绍如何经过confd+ACM来管理 Nginx 配置,经过集中式的配置管理方式解决 Nginx 的大规模运维问题,运维和开发人员不用登录到 Nginx 机器上,只须要配置好confd,而后在ACM上操做就能够动态修改 Nginx 的配置参数。html
在操做本文的示例以前须要配置好开通ACM和对confd的使用有基本概念。node
Nginx 在平常开发中使用得比较多的功能是负载均衡、限流、缓存等, Nginx 的使用和安装能够在网上查阅相关资料。本文结合负载均衡和限流功能讲解如何使用confd+ACM实现 Nginx 的大规模运维操做。web
建立confd所需的toml格式配置文件json
vim /etc/confd/conf.d/myapp.toml
check_cmd用于检验 Nginx 配置的正确性,当src配置错误则不会覆盖 Nginx 配置
reload_cmd用于reload Nginx 配置vim
[template] src = " Nginx .conf.tmpl" dest = "/usr/local/ Nginx /conf/ Nginx .conf" keys = [ "/myapp/ Nginx /conf", ] check_cmd = "/usr/local/ Nginx /sbin/ Nginx -t -c {{.src}}" reload_cmd = "/usr/local/ Nginx /sbin/ Nginx -s reload"
vim /etc/confd/templates/ Nginx .conf.tmpl
getv从ACM中获取对应dataId的配置,/myapp/ Nginx /conf对应的dataId为myapp. Nginx .conf,配置格式为json格式,模版文件包含了 Nginx 的upstream、限流、黑白名单配置内容,经过json指令解析配置文件。upstream后端ip经过从ACM的配置的backends数组中获取,一样地,白名单和黑名单ip分别存储在whiteList和blackList的数组中,限流的速率和并发数经过rateLimit和connectionLimit设置后端
... {{$data := json (getv "/myapp/ Nginx /conf")}} geo $whiteiplist { default 1; {{range $data.whiteList}} {{.}} 0; {{end}} } map $whiteiplist $limit { 1 $binary_remote_addr; 0 ""; } limit_req_zone $limit zone=rateLimit:10m rate={{$data.rateLimit}}r/s; limit_conn_zone $limit zone=connectionLimit:10m; {{range $data.blackList}} deny {{.}}; {{end}} upstream myapp { server 11.160.65.95:8080; } server { listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location / { root html; index index.html index.htm; proxy_pass http://myapp; limit_conn connectionLimit {{$data.connectionLimit}}; limit_req zone=rateLimit burst={{$data.burst}} nodelay; } ... } ...
建立dataId为myapp. Nginx .conf的配置文件,group使用默认的DEFAULT_GROUP便可,配置内容设置好上游节点、黑白名单以及限流阈值数组
{ "backends":["10.0.1.100:80","10.0.1.101:80"], "whiteList":["10.0.1.102","10.0.1.103"], "blackList":["10.0.1.104","10.0.1.104"], "rateLimit":"10", "connectionLimit":"10", "burst":"10" }
启动confd,设置好backend、endpoint、命名空间namespace和阿里云帐号accessKey/secretKey缓存
confd -backend nacos -endpoint {endpoint}:8080 -namespace {namespace} -accessKey {accessKey} -secretKey {secretKey}
confd将ACM中的参数经过模板文件渲染生成新的 Nginx 配置文件,查看生成的/usr/local/ Nginx / Nginx .conf配置文件是否符合预期,并检查 Nginx 是否成功reload配置。并发
... geo $whiteiplist { default 1; 10.0.1.102 0; 10.0.1.103 0; } map $whiteiplist $limit { 1 $binary_remote_addr; 0 ""; } limit_req_zone $limit zone=rateLimit:10m rate=10r/s; limit_conn_zone $limit zone=connectionLimit:10m; deny 30.5.125.74; deny 10.0.1.105; upstream myapp { server 11.160.65.95:8080; } server { listen 80; server_name localhost; location / { root html; index index.html index.htm; proxy_pass http://myapp; limit_conn connectionLimit 10; limit_req zone=rateLimit burst=10 nodelay; } ... } ...
运行时当须要调节 Nginx 的名单或者限流阈值的时候,能够在ACM上修改配置的内容。固然在生产环境可使用ACM的灰度发布功能(Beta发布)验证没问题再全量发布下去。app
本文演示了如何使用confd+ACM管理 Nginx 配置,下降 Nginx 的运维成本。
原文连接 本文为云栖社区原创内容,未经容许不得转载。