Назад | Перейти на главную страницу

Сине-зеленые тестовые рельсы с nginx + Unicorn

Я использую Unicorn в качестве сервера приложений перед своим веб-приложением. По сути, я хочу провести сине-зеленое тестирование, запустив одновременно две версии сайта. Проблема в том, что корневой путь отличается от одной версии сайта к другой. Есть ли способ сделать это?

Это мой конфиг. Прямо сейчас это не работает, потому что, когда второй сервер запускается в циклическом режиме, файлы ломаются, потому что они не находятся в корневом пути.

upstream unicorn { 
   server unix:/tmp/unicorn.main.sock fail_timeout=0; 
   server unix:/tmp/unicorn.main_staging.sock fail_timeout=0; 
} 

server { 
    listen 80; 
    server_name mysite.com; 
    root /var/www/sites/main/current/public; 

    try_files $uri/index.html $uri @unicorn; 

    location @unicorn { 
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
        proxy_set_header Host $http_host; 
        proxy_redirect off; 
        proxy_pass https://unicorn; 
     }  

     location ~ ^/assets/ { 
        expires 1y; 
        add_header Cache-Control public; 

        add_header ETag ""; 
        break; 
     } 

     error_page 500 502 504 /500.html; 
     client_max_body_size 4G; 
     keepalive_timeout 10; 
}

РЕДАКТИРОВАТЬ: Я добавил ответ, который считаю правильным.

Я почти уверен, что понял это. В основном мне нужно было переместить корневой путь в местоположение активов, а затем добавить дополнительный резерв, если активы были найдены.

upstream unicorn { 
   server unix:/tmp/unicorn.main.sock fail_timeout=0; 
   server unix:/tmp/unicorn.main_staging.sock fail_timeout=0; 
} 

server { 
    listen 80; 
    server_name mysite.com; 
    ### REMOVED root /var/www/sites/main/current/public; 

    try_files $uri/index.html $uri @unicorn; 

    location @unicorn { 
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
        proxy_set_header Host $http_host; 
        proxy_redirect off; 
        proxy_pass https://unicorn; 
     }  

     location ~ ^/assets/ {
        root /var/www/sites/main/current/public;  ## ADDED ##
        try_files $uri @altassets; ## ADDED ##
        expires 1y; 
        add_header Cache-Control public; 

        add_header ETag ""; 
        break; 
     } 

     location @altass {
         root /var/www/sites/main_staging/current/public;
         try_files $uri $uri/;
     }


     error_page 500 502 504 /500.html; 
     client_max_body_size 4G; 
     keepalive_timeout 10; 
}