6

現在、私の AWS ヘルスチェックは私のサーバーに非常に執拗に影響を与えています。

...
54.228.16.40 - - [14/Jan/2014:10:17:22 +0000] "GET / HTTP/1.1" 301 178 "-" "Amazon Route 53 Health Check Service"
54.248.220.40 - - [14/Jan/2014:10:17:24 +0000] "GET / HTTP/1.1" 301 178 "-" "Amazon Route 53 Health Check Service"
54.232.40.110 - - [14/Jan/2014:10:17:25 +0000] "GET / HTTP/1.1" 301 178 "-" "Amazon Route 53 Health Check Service"
54.241.32.78 - - [14/Jan/2014:10:17:26 +0000] "GET / HTTP/1.1" 301 178 "-" "Amazon Route 53 Health Check Service"
54.245.168.46 - - [14/Jan/2014:10:17:28 +0000] "GET / HTTP/1.1" 301 178 "-" "Amazon Route 53 Health Check Service"
54.251.31.174 - - [14/Jan/2014:10:17:28 +0000] "GET / HTTP/1.1" 301 178 "-" "Amazon Route 53 Health Check Service"
...

そして、NginX が のユーザー エージェントでリクエストをログに記録しないように構成したいと思います"Amazon Route 53 Health Check Service"

私の現在の試みは次のようになります。

# default server for forwarding all requests over to main www domain
server {
    listen 80 default_server;

    server_name _;

    return 301 $scheme://www.example.com$request_uri;
}

# server configured to catch aws health check requests
server {
    listen 80;
    server_name 12.345.67.89;

    location / {
        if ( $http_user_agent ~* 'Amazon Route 53 Health Check Service' ) {
            access_log off;
            return 200 'Service OK';      
        }
    }
}

# actual application server
server {
    listen 80;
    server_name www.example.com;

    location / { 
        ...
    }
}

これは私には良さそうに見えます。実際、ヘルスチェックがヒットするように設定されているのと同じアドレスを CURL すると、次のようになります。

curl --user-agent "Amazon Route 53 Health Check Service" http://12.345.67.89:80/

私が期待するものを手に入れます:

Service OK

そして、私のリクエストはログに記録されません。

ただし、これらのリクエストが実際の AWS ヘルスチェックから来る場合、私のログは引き続きこれらのリクエストに圧倒されます。

私が間違っている場所についてのアイデアはありますか?

ありがとう

4

2 に答える 2

0

example.comつまり、私のヘルス チェックは、IP アドレスではなくヒットするように設定されていたことがわかりました。

記録のために、変数をログ形式に追加することでこれを発見しました$host(行末を参照):

log_format debug_format '$remote_addr - $remote_user [$time_local] "$request" $status $body_bytes_sent "$http_referer" "$http_user_agent" "$http_x_forwarded_for" host:"$host"';

access_log /var/log/nginx/access.log debug_format;

とにかく乾杯

于 2014-01-14T11:16:22.763 に答える