Я переустановил nginx на моем сервере (который был под Ubuntu, а теперь под Arch Linux), попытался воссоздать все как раньше, но в моем браузере, когда я пытаюсь подключиться к своему сайту mysite1.me
Я всегда получаю ошибку 403. Вот мой /etc/nginx/nginx.conf
:
#user html;
worker_processes 1;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
#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 logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
server {
server_name mysite2.me;
root /home/user/mysite2/;
location / {
index index.php index.html index.htm;
}
listen [::]:443 ssl; # managed by Certbot
listen 443 ssl; # managed by Certbot
ssl_certificate /etc/letsencrypt/live/mysite1.me/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/mysite1.me/privkey.pem; # managed by Certbot
include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
}
server {
server_name mysite1.me;
root /home/user/mysite1/;
location / {
index index.php index.html index.htm;
}
listen [::]:443 ssl ipv6only=on; # managed by Certbot
listen 443 ssl; # managed by Certbot
ssl_certificate /etc/letsencrypt/live/mysite1.me/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/mysite1.me/privkey.pem; # managed by Certbot
include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
}
server {
if ($host = mysite1.me) {
return 301 https://$host$request_uri;
} # managed by Certbot
listen 80;
listen [::]:80;
server_name mysite1.me;
return 404; # managed by Certbot
}
server {
if ($host = mysite2.me) {
return 301 https://$host$request_uri;
} # managed by Certbot
listen 80;
listen [::]:80;
server_name mysite2.me;
return 404; # managed by Certbot
}}
И мой /etc/nginx/sites-available/mysite1
:
server {
root /home/user/mysite1;
index index.html index.htm;
server_name mysite1.me www.mysite1.me;
# Les urls commençant par / (toutes les urls)
location / {
index index.php index.html index.htm;
try_files $uri $uri/ $uri.html =404;
}
}
Я запустил:
sudo chown -R http:http /home/user/mysite1
sudo chmod 644 /home/user/mysite1/index.html
, потому что первый столбец ps -ef | grep nginx
указывает http
для строки, содержащей worker process
(user
находится в группе http
). И наконец я запустил
sudo nginx -t && sudo systemctl restart nginx && sudo systemctl reload nginx
, и это не дало никакой ошибки; но у меня все еще есть ошибка 403, когда я пытаюсь получить доступ к mysite1.me
в моем браузере. Что я делаю не так?