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;
}
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
これは再起動で問題ありません。
構成でIPアドレスをハードコーディングしないようにするには、次のようにします。
listen *:80;
listen [::]:80;
上記の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
全部終わった!
Network Managerを使用している場合は、サービスを開始する前に、ネットワークインターフェイスを上げるまで待つ必要があります。
systemctl enable NetworkManager-wait-online.service
Amazon EC2とエラスティックIPでは、サーバーは他のほとんどのサーバーのように実際にはIPを認識しません。したがって、Apache仮想ホストファイルでは、少なくともエラスティックIP:80ではなく*:80を配置します。
その後、正しく動作します。したがって、理論的には、nginxに対して*:80を実行しても同じように機能しますが、[emerg]を取得すると、0.0.0.0:80へのbind()が失敗します(98:アドレスはすでに使用されています)。まだ解決策を見つけていません。 。
将来これに対処する可能性のある人のために、私はAWSインスタンスでプライベートIPを検索し、それにバインドしました。 nginxが公に聞いて、その後私の書き換えを実行できることを確認しました。プロキシする内部サーバーがあったため、*:PORTを実行できませんでした。
ポート80で使用/リスニングしているプロセス/プログラムが残っている可能性があります。
これはnetstat -lpを使用して確認できます。そのプロセスを終了し、nginxを起動します。