如題,Nginx Upstream的配置能否跨機房設置為外網(wǎng)IP。
親測是可以的,但是不知道實際環(huán)境中會有什么問題。
Nginx upsteam做前端代理的時候是長連接,可能會因為網(wǎng)絡不好什么的出問題。
請問有這方面使用或者經(jīng)驗的同學可以回答下么?
認證0級講師
我的網(wǎng)站就是跨機房的,一臺nginx做反向代理,真正的web服務器在另外一個機房
做反向代理的nginx配置大概是這樣:
upstream real.sites {
server 123.123.123.123;
// 用keepalive保存長連接,降低頻繁創(chuàng)建連接的開銷
keepalive 16;
}
proxy_cache_path /path/to/cache levels=1:2 keys_zone=static_cache:100m;
server {
server_name www.example.com;
// 把真正的IP地址放到header的X-Forwarded-For里面
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_http_version 1.1;
proxy_set_header Connection "";
proxy_next_upstream http_503;
// 把靜態(tài)資源緩存起來,減少服務器間數(shù)據(jù)傳輸
location ~ \.(css|js|jpg|png|gif|ico)$ {
proxy_cache static_cache;
proxy_pass http://real.sites;
}
location / {
proxy_pass http://real.sites;
}
}
這種部署方式受機房間網(wǎng)絡質量的影響比較大,如果機房間網(wǎng)絡給力就妥妥的,nginx本身倒沒有制造過什么麻煩。
其實varnish應該比nginx更適合干這個,奈何我不熟悉varnish,干脆就用nginx搞了。