【问题标题】:NGINX not show default page on Amazon EC2 InstanceNGINX 不在 Amazon EC2 实例上显示默认页面
【发布时间】:2016-09-25 15:40:23
【问题描述】:

我在 Fedora 上安装了 nginx。但是我不知道为什么我无法通过浏览器请求服务器IP来获取默认的nginx页面。我的请求因超时而中断。

但是 nginx 正在运行。

$ sudo service nginx status
nginx (pid  20372) is running...

我的默认生成配置是

# For more information on configuration, see:
#   * Official English Documentation: http://nginx.org/en/docs/
#   * Official Russian Documentation: http://nginx.org/ru/docs/

user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /var/run/nginx.pid;

events {
    worker_connections 1024;
}

http {
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

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

    sendfile            on;
    tcp_nopush          on;
    tcp_nodelay         on;
    keepalive_timeout   65;
    types_hash_max_size 2048;

    include             /etc/nginx/mime.types;
    default_type        application/octet-stream;

    # Load modular configuration files from the /etc/nginx/conf.d directory.
    # See http://nginx.org/en/docs/ngx_core_module.html#include
    # for more information.
    include /etc/nginx/conf.d/*.conf;

    index   index.html index.htm;

    server {
        listen       80 default_server;
        listen       [::]:80 default_server;
        server_name  localhost;
        root         /usr/share/nginx/html;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        location / {
        }

        # redirect server error pages to the static page /40x.html
        #
        error_page 404 /404.html;
            location = /40x.html {
        }

        # redirect server error pages to the static page /50x.html
        #
        error_page 500 502 503 504 /50x.html;
            location = /50x.html {
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }

# Settings for a TLS enabled server.
#
#    server {
#        listen       443 ssl;
#        listen       [::]:443 ssl;
#        server_name  localhost;
#        root         /usr/share/nginx/html;
#
#        ssl_certificate "/etc/pki/nginx/server.crt";
#        ssl_certificate_key "/etc/pki/nginx/private/server.key";
#        # It is *strongly* recommended to generate unique DH parameters
#        # Generate them with: openssl dhparam -out /etc/pki/nginx/dhparams.pem 2048
#        #ssl_dhparam "/etc/pki/nginx/dhparams.pem";
#        ssl_session_cache shared:SSL:1m;
#        ssl_session_timeout  10m;
#        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
#        ssl_ciphers HIGH:SEED:!aNULL:!eNULL:!EXPORT:!DES:!RC4:!MD5:!PSK:!RSAPSK:!aDH:!aECDH:!EDH-DSS-DES-CBC3-SHA:!KRB5-DES-CBC3-SHA:!SRP;
#        ssl_prefer_server_ciphers on;
#
#        # Load configuration files for the default server block.
#        include /etc/nginx/default.d/*.conf;
#
#        location / {
#        }
#
#        error_page 404 /404.html;
#            location = /40x.html {
#        }
#
#        error_page 500 502 503 504 /50x.html;
#            location = /50x.html {
#        }
#    }

}

我不知道发生了什么。 /var/log/nginx/access.log 和 /var/log/nginx/access.log 也是空的。请帮忙...

【问题讨论】:

  • 根据您的服务器所在的位置,您可能需要调整防火墙才能访问它。服务器可能有自己的防火墙。如果它在云 (AWS) 中,您必须授予从本地 IP 访问它的权限。如果您在办公环境中,您的公司可能不允许访问某些 ip。
  • 你是说主持人?它是 EC2 亚马逊。我能做什么?
  • 您的服务器属于一个安全组。转到 EC2 Web 控制台并找到您的实例。单击其安全组。单击入站。单击编辑。添加 Rule -> HTTP,并将 Source 字段设置为 My Ip。
  • 你摇滚!非常感谢:)

标签: linux nginx amazon-ec2


【解决方案1】:

在 Amazon EC2 上,您需要打开防火墙以允许从您的浏览器到实例的传入 HTTP 连接。

  1. 登录亚马逊网络控制台
  2. 转到 EC2
  3. 找到您的实例
  4. 点击其安全组
  5. 点击入站标签
  6. 点击编辑
  7. 添加规则->HTTP,将源字段设置为My Ip

更改将立即生效。

请注意,如果您从非固定 IP(咖啡店 wifi)访问您的实例,则每次连接时都需要更改源 IP 地址并获得新的 IP 地址。因此,如果它有效,然后过了一段时间,它似乎挂起,这可能就是原因。

如果您还提供 HTTPS,您还需要添加特定规则。

【讨论】:

猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-07-24
  • 1970-01-01
  • 2016-06-01
  • 1970-01-01
  • 1970-01-01
  • 2020-04-05
相关资源
最近更新 更多