Flask + html + Shell 实现nginx配置管理web平台
一.起因:
1.最近公司频繁添加nginx 虚拟主机,操作太过频繁,人工太坑,真对此需求新开发通过界面添加nginx 虚拟主机;
二.前端页面代码;
<form action="/nginx_configuer" method="get"> <div class="row"> <div class="col-md-6" style="margin-top: 10px"> <div class="form-group"> <label for="exampleFormControlSelect1">nginx应用名称</label> <select class="form-control" id="exampleFormControlSelect1"> <option>ops_nginx01</option> <option>ops_nginx02</option> </select> <br> <div class="col-xs-12"> <label for="exampleFormControlSelect1">访问域名</label> <input type="text" id="text" name="domain_name" required="required" placeholder="" class="form-control col-md-7 col-xs-12"> <br> <label for="exampleFormControlSelect1">后端ip地址</label> <input type="text" id="text02" name="backend_ip" required="required" placeholder="" class="form-control col-md-7 col-xs-12"> <br> <label for="exampleFormControlSelect1">后端服务端口</label> <input type="text" id="text03" name="backend_port" required="required" placeholder="" class="form-control col-md-7 col-xs-12"> </div> </div> </div> <div class="col-md-6" style="margin-top: 10px"> <label for="exampleFormControlSelect1">Nginx IP列表</label> <select multiple class="form-control" id="nuber01"> </select> <label for="exampleFormControlSelect1">Upstream 名称</label> <input type="text" id="text04" name="upstream_name" required="required" placeholder="" class="form-control col-md-7 col-xs-12"> </div> </div> </div> <div role="tabpanel" class="tab-pane fade" id="Test"> TEST </div> <div role="tabpanel" class="tab-pane fade" id="Ontest"> ONTEST </div> <div role="tabpanel" class="tab-pane fade" id="Cloudtest"> CLOUD </div> <div role="tabpanel" class="tab-pane fade" id="Prod"> PROD </div> </div> </div> <div class="modal-footer"> <button type="button" class="btn btn-secondary" data-dismiss="modal">取消</button> <button type="submit" class="btn btn-primary">确定</button> </div> </form>
页面效果如下;
三.flask 路由代码如下;
""" 通过页面新增nginx 虚拟主机,固定参数,域名,后端ip地址和端口以及upstream 名称; """ @app.route('/nginx_configuer', methods=['GET']) def nginx_configuer(): domain_name = request.args.get('domain_name') backend_ip = request.args.get('backend_ip') backend_port = request.args.get('backend_port') upstream_name = request.args.get('upstream_name') nginx_config_instance = Nginx_configure() result = nginx_config_instance.nginx_config_edit(domain_name,backend_ip,backend_port,upstream_name) return Response(json.dumps(result), mimetype='application/json')
四.后台处理逻辑代码如下;
# -*- coding: utf-8 -*- import os class Nginx_configure(object): def nginx_config_edit(self,domain_name,backend_ip, backend_port,upstream_name): self.name = domain_name self.ip = backend_ip self.port = backend_port self.upstream_name = upstream_name p = os.popen("/bin/bash ./shell/nginx_set_config.sh {0} {1} {2} {3}".format(self.name,self.ip,self.port,self.upstream_name)) reult = p.read() return reult
4.实现shell 脚本如下;
#!/bin/bash function Edit_nginx_config(){ if [ $# == 0 ] then echo "no parameters nuber" else if [ $# == 4 ] then cat >/etc/nginx/conf.d/$1.conf<<EOF upstream $4 { server $2:$3; } server { listen 80; server_name $1; access_log /chj/data/log/$1.log; location / { proxy_set_header Host \$host; proxy_set_header X-Real-IP \$remote_addr; proxy_set_header X-Forwarded-For \$proxy_add_x_forwarded_for; add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Headers X-Requested-With; add_header Access-Control-Allow-Methods GET,POST,OPTIONS,HEAD; proxy_pass http://$4; } } EOF echo "domain_nming add sucess" else echo "Insufficient parameters $#" fi fi } Edit_nginx_config $1 $2 $3 $4