私は次のようにして、2 つの Domino サーバーのロード バランサーとして NGINX を設定しました。
http {
upstream www.mydomain.com {
server 1.1.1.1;
server 2.2.2.2 backup;
}
server {
listen 80;
server_name www.mydomain.com;
location / {
proxy_pass http://www.mydomain.com;
}
}
}
Domino サーバーに直接アクセスした場合、応答ヘッダーは次のようになります。
HTTP/1.1 200 OK
Server: Lotus-Domino
Date: Mon, 23 Dec 2013 12:19:36 GMT
Last-Modified: Fri, 20 Dec 2013 08:16:27 GMT
Content-Type: text/html; charset=US-ASCII
Content-Length: 12713
Cache-control: private
ETag: W/"MTAtODEwRC1DMjI1N0MzRDAwN0M3NTBCLUMyMjU3QzQ3MDAyRDczMzktMC1DTj1QYW51IEhhYXJhbW8vTz1BQUQ="
NGINX 経由で同じページにアクセスすると、応答ヘッダーは次のようになります。
HTTP/1.1 200 OK
Server: nginx/1.0.15
Date: Mon, 23 Dec 2013 12:02:29 GMT
Content-Type: text/html; charset=US-ASCII
Connection: keep-alive
Last-Modified: Mon, 23 Dec 2013 12:20:47 GMT
Expires: Tue, 01 Jan 1980 06:00:00 GMT
Content-Length: 12713
NGINX を設定して、Domino から直接取得した応答ヘッダーを正確に渡すことはできますか? 次のように、いくつかを 1 つずつ設定できることはわかっています。
proxy_pass_header Server;
しかし、例えばETag
この方法でも通過することはありません。
答え1
おそらく、nginxは、例えばgzipが有効になっているためにアップストリームからの応答を変更します。詳細については、ここ。