Конфигурация Gitea и Nginx

Я пытаюсь настроить свой Ubuntu 18.04 VPS для работы в качестве веб-сервера nginx и частного сервера gitea. У меня конфигурация в основном работает, за исключением того, что любые 404 из моего домена передаются в gitea и показывают gitea 404. Я бы предпочел, чтобы пользователи основного домена не были направлены в Gitea.

Задача:

  • Любой поддомен, кроме git.domain.com, не должен быть проксирован в Gitea и должен использовать https (работает).
  • Любые ошибки для поддоменов, кроме git.domain.com, не должны попадать в Gitea (не работает)
  • git.domain.com должен предоставить https доступ к gitea (работает)

Пытался:

  • Используя location / git / для Gitea, разделить их и разрешить location / вернуть 404 после попытки URL. Это вызывает все виды проблем с ошибками 404 в Gitea и / или git.domain.com не использовать nginx

конфигурация с поддержкой сайтов домена:

server {

    root /var/www/example.com/html;
    index index.html index.htm index.nginx-debian.html;

    server_name git.example.com;
    location / {
            proxy_pass https://0.0.0.0:3000;
    }
server_name *.example.com;
location ~ \.php$ {
    include snippets/fastcgi-php.conf;
    fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;
}
location ~ /\.ht {
    deny all;
}
    #location / {
    #        try_files $uri $uri/ =404;
    #}

listen [::]:443 ssl ipv6only=on; # managed by Certbot
listen 443 ssl; # managed by Certbot
ssl_certificate <path>/fullchain.pem; # managed by Certbot
ssl_certificate_key <path>/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

}

Любая помощь с благодарностью. Спасибо.

1 ответ

Ваш конфиг не выглядит действительно чистым. Посмотрите здесь https://linuxserversetup.com/tutorial/self-hosted-git-service#nginx-forwarding-with-https и прокрутите вниз до «Изменить файл конфигурации Nginx на HTTPS».

Чтобы запустить Gitea в подпапке git.example.com/git, конфиг Nginx должен быть таким:

      server {
  listen      443 ssl http2;
  listen      [::]:443 ssl http2;
  server_name git.example.com;

  root        /var/www/example.com/html;
  index       index.htm;

  location / {
    try_files $uri $uri/ /index.htm;
  }

  location /git/ {
    proxy_pass http://localhost:3000/;
  }

  # ...
}

И в конфиге Gitea соответственно

      [server]
PROTOCOL         = http
DOMAIN           = git.example.com/gitea
HTTP_PORT        = 3000
ROOT_URL         = https://git.example.com/gitea
Другие вопросы по тегам