在开发的过程中,经常会涉及到不同的环境切换或者并行开发的问题,为了解决这个问题,大部分情况下会采取切换host或者通过不同环境指定不同域名的方式来实现。但是这中间有两个问题:
- 切换host偶尔会受到dns缓存或浏览器缓存的问题
- 不同环境不同host有可能导致版本发布时,错误的host导致线上出现问题。
为了解决这两个问题,换个方式,我们可以使用一致域名、nginx转发的方式来实现不同环境的切换,示例如下:
假设:
- app.host.com 应用,默认dns解析到10.129.5.20
- 测试(testing)10.129.5.21:5000
- 开发环境(dev) 10.129.5.22:5000
step 1:nginx配置
10.129.5.20服务器的nginx配置如下
server{
listen 80;
server_name app.host.com;
set $backend "http://10.129.5.21:5000";
if ($http_cookie ~ "env=testing") {
set $backend "http://10.129.5.21:5000"
}
if ($http_cookie ~ "env=dev") {
set $backend "http://10.129.5.21:5000";
}
location /switch{
proxy_pass http://127.0.0.1:5000/switch;
}
location / {
proxy_pass $backend;
}
}
在这个配置里,通过对cookie的判断来决定backend最终proxy pass 到哪里,我们可以看到。其中,/switch是切换环境的链接。
step 2: 简单的python切换环境的应用
from flask import Flask, make_response
app = Flask(__name__)
@app.route('/switch/<env>')
def switch(env):
resp = make_response('environment switch to %s' % env)
resp.set_cookie('env', env)
return resp
if __name__ == '__main__':
app.run()
在10.129.5.20上部署python应用(uwsgi或者至今指定端口运行),以上nginx中已经配置为url,这时候就可以切换了。
例子
- 指定host解析app.host.com 到10.129.5.20
- 切换环境,直接使用浏览器访问
http://app.host.com/switch/testing|dev
则可以将当前浏览器的环境切换过来。