Ubuntu 18上的nginx网站未在公共IP上加载

时间:2019-03-21 15:14:04

标签: linux amazon-web-services ubuntu nginx amazon-ec2

我正在尝试通过nginx在Amazon AWS EC2 Ubuntu 18.04上托管网站。我首先关注this tutorial。我跑了sudo apt updatesudo apt install nginx。然后,我运行了sudo ufw allow 'Nginx HTTP'。运行sudo ufw status返回了以下内容;

Status: active

To                         Action      From
--                         ------      ----
Nginx HTTP                 ALLOW       Anywhere
OpenSSH                    ALLOW       Anywhere
Nginx HTTP (v6)            ALLOW       Anywhere (v6)
OpenSSH (v6)               ALLOW       Anywhere (v6)

此后,我运行systemctl status nginx并返回:

● nginx.service - A high performance web server and a reverse proxy server
   Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: en
   Active: active (running) since Thu 2019-03-21 14:30:31 UTC; 1min 17s ago
     Docs: man:nginx(8)
  Process: 2657 ExecStart=/usr/sbin/nginx -g daemon on; master_process on; (code
  Process: 2644 ExecStartPre=/usr/sbin/nginx -t -q -g daemon on; master_process
 Main PID: 2661 (nginx)
    Tasks: 2 (limit: 1152)
   CGroup: /system.slice/nginx.service
           ├─2661 nginx: master process /usr/sbin/nginx -g daemon on; master_pro
           └─2663 nginx: worker process

Mar 21 14:30:31 ip-172-31-29-16 systemd[1]: Starting A high performance web serv
Mar 21 14:30:31 ip-172-31-29-16 systemd[1]: nginx.service: Failed to parse PID f
Mar 21 14:30:31 ip-172-31-29-16 systemd[1]: Started A high performance web serve
lines 1-15/15 (END)...skipping...
● nginx.service - A high performance web server and a reverse proxy server
   Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)
   Active: active (running) since Thu 2019-03-21 14:30:31 UTC; 1min 17s ago
     Docs: man:nginx(8)
  Process: 2657 ExecStart=/usr/sbin/nginx -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
  Process: 2644 ExecStartPre=/usr/sbin/nginx -t -q -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
 Main PID: 2661 (nginx)
    Tasks: 2 (limit: 1152)
   CGroup: /system.slice/nginx.service
           ├─2661 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
           └─2663 nginx: worker process

Mar 21 14:30:31 ip-172-31-29-16 systemd[1]: Starting A high performance web server and a reverse proxy server...
Mar 21 14:30:31 ip-172-31-29-16 systemd[1]: nginx.service: Failed to parse PID from file /run/nginx.pid: Invalid argument
Mar 21 14:30:31 ip-172-31-29-16 systemd[1]: Started A high performance web server and a reverse proxy server.

然后我尝试解决Failed to parse PID from file /run/nginx.pid: Invalid argument错误。我是这样做的,先做mkdir /etc/systemd/system/nginx.service.d,然后再做printf "[Service]\nExecStartPost=/bin/sleep 0.1\n"

  

[服务]
  ExecStartPost = / bin / sleep 0.1

此后,我运行sudo nano /etc/systemd/system/nginx.service.d/override.conf,并将上面的引号插入其中并保存。然后sudo systemctl daemon-reloadsudo systemctl restart nginx。之后,运行systemctl status nginx返回了此信息:

● nginx.service - A high performance web server and a reverse proxy server
   Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)
  Drop-In: /etc/systemd/system/nginx.service.d
           └─override.conf
   Active: active (running) since Thu 2019-03-21 14:54:44 UTC; 16s ago
     Docs: man:nginx(8)
  Process: 2941 ExecStop=/sbin/start-stop-daemon --quiet --stop --retry QUIT/5 --pidfile /run/nginx.pid (code=exited, status=0/SUCCESS)
  Process: 2957 ExecStartPost=/bin/sleep 0.1 (code=exited, status=0/SUCCESS)
  Process: 2955 ExecStart=/usr/sbin/nginx -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
  Process: 2944 ExecStartPre=/usr/sbin/nginx -t -q -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
 Main PID: 2956 (nginx)
    Tasks: 2 (limit: 1152)
   CGroup: /system.slice/nginx.service
           ├─2956 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
           └─2962 nginx: worker process

Mar 21 14:54:44 ip-172-31-29-16 systemd[1]: Stopped A high performance web server and a reverse proxy server.
Mar 21 14:54:44 ip-172-31-29-16 systemd[1]: Starting A high performance web server and a reverse proxy server...
Mar 21 14:54:44 ip-172-31-29-16 systemd[1]: Started A high performance web server and a reverse proxy server.

我认为现在一切正常,所以我运行了curl localhost并且返回了

<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
    body {
        width: 35em;
        margin: 0 auto;
        font-family: Tahoma, Verdana, Arial, sans-serif;
    }
</style>
</head>
<body>
<h1>Welcome to nginx!</h1>
<p>If you see this page, the nginx web server is successfully installed and
working. Further configuration is required.</p>

<p>For online documentation and support please refer to
<a href="http://nginx.org/">nginx.org</a>.<br/>
Commercial support is available at
<a href="http://nginx.com/">nginx.com</a>.</p>

<p><em>Thank you for using nginx.</em></p>
</body>
</html>

我相信我也应该能够从家用PC上访问它,所以我做了curl ifconfig.me来获取我的公共IP,然后我去了http://PUBLICIP,但是它说这个站点不能达到。

有人可以帮我解决这个问题吗?

谢谢。

1 个答案:

答案 0 :(得分:0)

问题是我的AWS安全组,我添加了一个入站规则来接受所有TCP,现在它可以工作了。