NGINX Настройка для приложения Reactive Spring Boot WebFlux - PullRequest
0 голосов
/ 19 марта 2020

В своем стремлении лучше понять реактивное программирование, я создал небольшое приложение с двумя конечными точками - POST и GET. Метод POST сохраняет некоторые данные в MongoDB Atlas, а метод GET возвращает данные из БД.

Рабочий процесс: запрос GET через браузер -> POST некоторые новые данные через curl -> новые данные отображаются в браузере.

Рабочий процесс работает локально, но как только я добавьте NGINX в смесь, рабочий процесс перестает работать. Данные не отображаются, и через некоторое время соединение прерывается.

Мой контроллер:

    @GetMapping(value = "mda", produces = MediaType.APPLICATION_STREAM_JSON_VALUE)
    public Flux<ResponseData> getAll(){
        return repo.findBy();
    }

Мой метод репо:

   @Tailable
   Flux<ResponseData> findBy();

Как мне изменить мой NGINX conf, чтобы приложение работало?

My NGINX Config. Я изменил исходный домен:

server {
    server_name example.com www.example.com;

    location / {
          try_files $uri $uri/ =404;
        }

    location /reactive/data {
        proxy_pass http://localhost:8081/data;
        proxy_redirect off;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto https;
    }

    location /reactive/mda {
        proxy_pass http://localhost:8081/mda;
        proxy_redirect off;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto https;

        }   

    listen [::]:443 ssl; # managed by Certbot
    listen 443 ssl; # managed by Certbot
    ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/example.com/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 = www.example.com) {
        return 301 https://$host$request_uri;
    } # managed by Certbot


    if ($host = example.com) {
        return 301 https://$host$request_uri;
    } # managed by Certbot


    listen 80;
    listen [::]:80;
    server_name example.com www.example.com;
    return 404; # managed by Certbot
}

Для завершения: Конечная точка / data содержит POST и GET (NO @Tailable), и они работают как с NGINX, так и без него.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...