web-dev-qa-db-ja.com

nginxエラー:(99:要求されたアドレスを割り当てることができません)

Ubuntu Hardy 8.04とnginx 0.7.65を実行していますが、nginxサーバーを起動しようとすると:

$ Sudo /etc/init.d/nginx start

次のエラーが発生します。

Starting nginx: [emerg]: bind() to IP failed (99: Cannot assign requested address)

ここで、「IP」は私のIPアドレスのプレースホルダーです。そのエラーが発生している理由を誰かが知っていますか?これはEC2で実行されています。

私のnginx.confファイルは次のようになります:

user www-data www-data;
worker_processes  4;

events {
    worker_connections  1024;
}

http {
    include       mime.types;
    default_type  application/octet-stream;

    access_log /usr/local/nginx/logs/access.log;

    sendfile        on;
    tcp_nopush      on;
    tcp_nodelay         on;

    keepalive_timeout  3;

    gzip  on;
    gzip_comp_level 2;
    gzip_proxied any;
    gzip_types  text/plain text/css application/x-javascript text/xml application/xml
    application/xml+rss text/javascript;

    include /usr/local/nginx/sites-enabled/*;

}

そして私の/usr/local/nginx/sites-enabled/example.comは次のようになります:

server {

        listen   IP:80;
        server_name  example.com;
        rewrite ^/(.*) https://example.com/$1 permanent;

       }

server {

        listen   IP:443 default ssl;

        ssl         on;
        ssl_certificate     /etc/ssl/certs/myssl.crt;
        ssl_certificate_key /etc/ssl/private/myssl.key;

        ssl_protocols       SSLv3 TLSv1;
        ssl_ciphers ALL:!ADH:RC4+RSA:+HIGH:+MEDIUM:-LOW:-SSLv2:-EXP;

        server_name example.com;

        access_log /home/example/example.com/log/access.log;
        error_log /home/example/example.com/log/error.log;

        }
25
k-g-f

Amazon EC2とエラスティックIPでは、サーバーは他のほとんどのサーバーのように実際にはIPを認識しません。

したがって、プロセスに非ローカルアドレスへのバインドを許可するようにLinuxに指示する必要があります。次の行を/etc/sysctl.confファイルに追加するだけです。

# allow processes to bind to the non-local address
# (necessary for Apache/nginx in Amazon EC2)
net.ipv4.ip_nonlocal_bind = 1

次に、sysctl.confを次のようにリロードします。

$ sysctl -p /etc/sysctl.conf

これは再起動で問題ありません。

56
kirpit

構成でIPアドレスをハードコーディングしないようにするには、次のようにします。

listen *:80;
listen [::]:80;
7
Till

上記のkirpitのように、LinuxプロセスがローカルIPアドレスにバインドできるようにする必要があります。

nano /etc/sysctl.conf

# allow processes to bind to the non-local address
net.ipv4.ip_nonlocal_bind = 1

sysctl -p /etc/sysctl.conf

次に、エラスティックIPに関連付けられているprivate ip addressを追加し、それをサイト構成に追加します。

nano /etc/nginx/sites-available/example.com

Nginxをリロードします。

service nginx reload

全部終わった!

2
user2035677

Network Managerを使用している場合は、サービスを開始する前に、ネットワークインターフェイスを上げるまで待つ必要があります。

systemctl enable NetworkManager-wait-online.service

0
Ultra Breaker

Amazon EC2とエラスティックIPでは、サーバーは他のほとんどのサーバーのように実際にはIPを認識しません。したがって、Apache仮想ホストファイルでは、少なくともエラスティックIP:80ではなく*:80を配置します。

その後、正しく動作します。したがって、理論的には、nginxに対して*:80を実行しても同じように機能しますが、[emerg]を取得すると、0.0.0.0:80へのbind()が失敗します(98:アドレスはすでに使用されています)。まだ解決策を見つけていません。 。

0
cchiera

将来これに対処する可能性のある人のために、私はAWSインスタンスでプライベートIPを検索し、それにバインドしました。 nginxが公に聞いて、その後私の書き換えを実行できることを確認しました。プロキシする内部サーバーがあったため、*:PORTを実行できませんでした。

0
MLindsay

ポート80で使用/リスニングしているプロセス/プログラムが残っている可能性があります。

これはnetstat -lpを使用して確認できます。そのプロセスを終了し、nginxを起動します。

0
Rodney Quillo