即使只使用端口80,也无法在任何端口上启动Ubuntu上的nginx

时间:2017-11-29 06:18:51

标签: python ubuntu nginx

我无法在Ubuntu16.04上启动nginx。

当我运行sudo /etc/init.d/nginx start时,我收到错误。

(env) agaidis@Computer:~$ sudo /etc/init.d/nginx start
[....] Starting nginx (via systemctl): nginx.serviceJob for nginx.service failed because the control process exited with error code. See "systemctl status nginx.service" and "journalctl -xe" for details.
failed!

当我通过调用

深入查看错误消息时
sudo systemctl status nginx.service

我得到以下反馈:

(env) agaidis@Computer:~/www$ sudo systemctl status nginx.service
● nginx.service - A high performance web server and a reverse proxy server
   Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)
   Active: failed (Result: exit-code) since Wed 2017-11-29 01:03:16 EST; 1min 57s ago
  Process: 6887 ExecStart=/usr/sbin/nginx -g daemon on; master_process on; (code=exited, status=1/FAILURE)
  Process: 6883 ExecStartPre=/usr/sbin/nginx -t -q -g daemon on; master_process on; (code=exited, status=0/SUCCESS)

Nov 29 01:03:13 Computer nginx[6887]: nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
Nov 29 01:03:14 Computer nginx[6887]: nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
Nov 29 01:03:14 Computer nginx[6887]: nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
Nov 29 01:03:15 DComputer nginx[6887]: nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
Nov 29 01:03:15 Computer nginx[6887]: nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
Nov 29 01:03:16 Computer nginx[6887]: nginx: [emerg] still could not bind()
Nov 29 01:03:16 Computer systemd[1]: nginx.service: Control process exited, code=exited status=1
Nov 29 01:03:16 Computer systemd[1]: Failed to start A high performance web server and a reverse proxy server.
Nov 29 01:03:16 Computer systemd[1]: nginx.service: Unit entered failed state.
Nov 29 01:03:16 Computer systemd[1]: nginx.service: Failed with result 'exit-code'.

我一直在关注this website上的步骤,让nginx和gunicorn一起跑步。我一直在网上寻找我的问题的修复程序,但没有任何工作。

我在端口80上运行的另一台服务器不是nginx,所以我已经切换了/etc/nginx/sited-available/default/etc/nginx/sited-available/<name of flask app>/etc/nginx/sited-enabled/<name of flask app>所有的端口来监听和响应端口8888.我也尝试过其他端口号。不幸的是,这似乎没有任何帮助。

我的/etc/nginx/sited-available/default文件如下:

##
# You should look at the following URL's in order to grasp a solid understanding
# of Nginx configuration files in order to fully unleash the power of Nginx.
# http://wiki.nginx.org/Pitfalls
# http://wiki.nginx.org/QuickStart
# http://wiki.nginx.org/Configuration
#
# Generally, you will want to move this file somewhere, and start with a clean
# file but keep this around for reference. Or just disable in sites-enabled.
#
# Please see /usr/share/doc/nginx-doc/examples/ for more detailed examples.
##

# Default server configuration
#
server {
    #listen 8080 default_server;
    listen [::]:8888 ipv6only=on default_server;

    # SSL configuration
    #
    # listen 443 ssl default_server;
    # listen [::]:443 ssl default_server;
    #
    # Note: You should disable gzip for SSL traffic.
    # See: https://bugs.debian.org/773332
    #
    # Read up on ssl_ciphers to ensure a secure configuration.
    # See: https://bugs.debian.org/765782
    #
    # Self signed certs generated by the ssl-cert package
    # Don't use them in a production server!
    #
    # include snippets/snakeoil.conf;

    root /var/www/html;

    # Add index.php to the list if you are using PHP
    index index.html index.htm index.nginx-debian.html;

    server_name _;

    location / {
        # First attempt to serve request as file, then
        # as directory, then fall back to displaying a 404.
        try_files $uri $uri/ =404;
    }

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    #   include snippets/fastcgi-php.conf;
    #
    #   # With php7.0-cgi alone:
    #   fastcgi_pass 127.0.0.1:9000;
    #   # With php7.0-fpm:
    #   fastcgi_pass unix:/run/php/php7.0-fpm.sock;
    #}

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


# Virtual Host configuration for example.com
#
# You can move that to a different file under sites-available/ and symlink that
# to sites-enabled/ to enable it.
#
#server {
#   listen 80;
#   listen [::]:80;
#
#   server_name example.com;
#
#   root /var/www/example.com;
#   index index.html;
#
#   location / {
#       try_files $uri $uri/ =404;
#   }
#}

我的/etc/nginx/sited-enabled/<name of flask app>/etc/nginx/sited-available/<name of flask app>文件如下所示:

server {
    location / {
        proxy_pass http://localhost:8888;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
    }
    location /static {
        alias /home/agaidis/www/<name of flask app>/static/;
    }
}

在尝试启动服务器之前,我尝试过的其他一些内容包括sudo apt-get updatesudo apt-get upgrade nginx

无论如何在不停止当前服务器在端口80上运行的情况下修复问题?非常感谢任何和所有帮助:)

1 个答案:

答案 0 :(得分:0)

我在listen 8080;文件的顶部添加了/etc/nginx/sited-available/<name of flask app>。因此,它变成了:

server {

    listen 8080;

    location / {
        proxy_pass http://localhost:8888;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
    }
    location /static {
        alias /home/agaidis/www/<name of flask app>/static/;
    }
}

这解决了我的问题。