RabbitMQ nginx 配置

问题描述 投票:0回答:1

我在服务器中输入 RabbitMQ 管理页面时遇到问题,它要求每个请求基本身份验证登录。我无法解决它,因此我没有输入每个请求。 这是我的 nginx 配置:

location ~* /rabbitmq/api/(.*?)/(.*) {
    #rewrite         ^/rabbitmq/api/(.*) /$1 break;
    proxy_pass http://127.0.0.1:15672/api/$1/%2F/$2?$query_string;
    allow all;
}

location ~* /rabbitmq/(.*) {
    rewrite         ^/rabbitmq/(.*) /$1 break;
    proxy_pass     http://127.0.0.1:15672;
    allow all;
}

版本:

nginx version: nginx/1.11.2

有人可以帮忙吗?

nginx rabbitmq centos7
1个回答
3
投票

在寻求帮助时,如果您提供完整的配置文件而不是像您所做的那样只是一个片段,这会对人们有所帮助。

这是一个完整的配置,它将

localhost:8888/rabbitmq
重定向到在端口
15672
上运行的管理服务器。我已经用
nginx
1.14.0
和 RabbitMQ
3.7.6
进行了测试。我只被提示登录一次。我以普通用户身份使用以下命令运行它:

nginx -p /home/lbakken/issues/SO/rabbitmq-nginx-config-48881248 -c nginx.conf
user                 lbakken lbakken;
worker_processes     1;
# Note: for debugging, very useful
# error_log            /dev/stderr debug;
error_log            /dev/stderr;
pid                  nginx.pid;
worker_rlimit_nofile 1024;
daemon               off;

events {
    worker_connections 1024;
}

http {
    client_body_temp_path /tmp/nginx;
    fastcgi_temp_path     /tmp/nginx;
    scgi_temp_path        /tmp/nginx;
    uwsgi_temp_path       /tmp/nginx;
    proxy_temp_path       /tmp/nginx;
    access_log            /dev/stdout;

    upstream rabbitmq {
        least_conn;
        server localhost:15672 weight=10 max_fails=3 fail_timeout=30s;
    }

    server {
        listen                          8888;
        server_name                     127.0.0.1;

        # Note: a big thanks to this answer:
        # https://stackoverflow.com/a/37584637
        location /rabbitmq/api/ {
            rewrite ^ $request_uri;
            rewrite ^/rabbitmq/api/(.*) /api/$1 break;
            return 400;
            proxy_pass http://rabbitmq$uri;
        }

        location /rabbitmq {
            rewrite ^/rabbitmq$ /rabbitmq/ permanent;
            rewrite ^/rabbitmq/(.*)$ /$1 break;
            proxy_pass http://rabbitmq;
            proxy_buffering                    off;
            proxy_set_header Host              $http_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 $scheme;
        }
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.