我已经设置了一个 nginx 虚拟主机来为 angularjs SPA 提供服务,其入口文件位于index.html
我的 Ubuntu 16.04 LTS 电脑上,运行良好。
在格式化并安装 Ubuntu 22.04 LTS(当然还有 nginx)后,我从格式化 PC 之前保存的 /etc/nginx/sites-available 文件夹中复制了我的虚拟主机文件,并重新创建了指向 sites-enabled/ 文件夹所需的符号链接。但是它不起作用(我使用不同的浏览器时都收到“无法访问此站点”消息)。
语法和状态检查正常。端口 80 中的默认 nginx 页面就在那里。我已多次重启 nginx 以及我的电脑,以排除任何奇怪的缓存情况。
我这样做了sudo ufw app list
,结果(我猜测)还不错(CUPS、Nginx Full、Nginx HTTP、Nginx HTTPS)。
我的 /etc/nginx/nginx.conf 文件如下:
user www-data;
worker_processes auto;
pid /run/nginx.pid;
include /etc/nginx/modules-enabled/*.conf;
events {
worker_connections 768;
# multi_accept on;
}
http {
##
# Basic Settings
##
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;
# server_tokens off;
server_names_hash_bucket_size 64;
# server_name_in_redirect off;
include /etc/nginx/mime.types;
default_type application/octet-stream;
##
# SSL Settings
##
ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3; # Dropping SSLv3, ref: POODLE
ssl_prefer_server_ciphers on;
##
# Logging Settings
##
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
##
# Gzip Settings
##
gzip on;
# gzip_vary on;
# gzip_proxied any;
# gzip_comp_level 6;
# gzip_buffers 16 8k;
# gzip_http_version 1.1;
# gzip_types text/plain text/css application/json
application/javascript text/xml application/xml
application/xml+rss text/javascript;
##
# Virtual Host Configs
##
include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
}
#mail {
# # See sample authentication script at:
# # http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript
#
# # auth_http localhost/auth.php;
# # pop3_capabilities "TOP" "USER";
# # imap_capabilities "IMAP4rev1" "UIDPLUS";
#
# server {
# listen localhost:110;
# protocol pop3;
# proxy on;
# }
#
# server {
# listen localhost:143;
# protocol imap;
# proxy on;
# }
#}
我的 sites-available 文件夹内的虚拟主机文件是:
server {
listen 80;
root /home/my_user/parent/file/path;
index index.html index.htm;
server_name my_server.local www.my_server.local;
location / {
try_files $uri $uri/ /index.html =404;
}
}
可能出了什么问题?
更新:
我发现我没有添加以下行:
127.0.0.1 my_server.local
文件中/etc/hosts
,这就是为什么我在浏览器上收到“无法访问此网站”消息的原因。唉,现在我得到了403 禁止来自 Nginx 的消息。我尝试将上述服务器根路径的所有者更改为,www-data
但仍然收到相同的消息。
我该如何解决这个问题?
答案1
原来问题出在文件所有权上。起初,我www-data
仅在 中的最后一个/path
文件夹将所有权更改为用户/home/my_user/parent/file/path
,但 nginx 要求其用户拥有该路径的第一个祖先目录的所有权。也就是说,当我这样做时
sudo chown -R www-data:data /home/*
index.html
路径中最后一个文件夹中的文件已正常提供。
但是因为我不想my_user
失去对其文件的访问权限,所以我将目录的所有权切换回my_user
并更改了 nginx 用户,将/etc/nginx/nginx.conf
文件的第一行替换为:
user my_user;
此后,index.html
服务就不再有问题了。