[rabbitmq] Spring AMQP + RabbitMQ 3.3.5 ACCESS_REFUSED-인증 메커니즘 PLAIN을 사용하여 로그인이 거부되었습니다.

나는 예외를 받고있다

org.springframework.amqp.AmqpAuthenticationException : com.rabbitmq.client.AuthenticationFailureException : ACCESS_REFUSED-인증 메커니즘 PLAIN을 사용하여 로그인이 거부되었습니다. 자세한 내용은 브로커 로그 파일을 참조하십시오.

구성 : Windows의 RabbitMQ 3.3.5

의 구성 파일에서 https://www.rabbitmq.com/access-control.html에%APPDATA%\RabbitMQ\rabbit.config
따라 아래 변경을 수행했습니다.

[{rabbit, [{loopback_users, []}]}].

또한 사용자 / 비밀번호를 만들려고 시도했습니다. 테스트 / 테스트가 작동하지 않는 것 같습니다.

게시물 의 단계를 시도했습니다 .

기타 구성 세부 정보는 다음과 같습니다.

Tomcat 호스팅 Spring 애플리케이션 컨텍스트 :

<!-- Rabbit MQ configuration Start -->
    <!-- Connection Factory -->
    <rabbit:connection-factory id="rabbitConnFactory" virtual-host="/" username="guest" password="guest" port="5672"/>

    <!-- Spring AMQP Template -->
    <rabbit:template id="rabbitTemplate" connection-factory="rabbitConnFactory" routing-key="ecl.down.queue" queue="ecl.down.queue" />

    <!-- Spring AMQP Admin -->
    <rabbit:admin id="admin" connection-factory="rabbitConnFactory"/>

    <rabbit:queue id="ecl.down.queue" name="ecl.down.queue" />

    <rabbit:direct-exchange name="ecl.down.exchange">
        <rabbit:bindings>
            <rabbit:binding key="ecl.down.key" queue="ecl.down.queue"/>
        </rabbit:bindings>
    </rabbit:direct-exchange>

내 컨트롤러 클래스에서

@Autowired
RmqMessageSender rmqMessageSender;

//Inside a method
rmqMessageSender.submitToECLDown(orderInSession.getOrderNo());

내 메시지 발신자에서 :

import org.springframework.amqp.core.AmqpTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

@Component("messageSender")
public class RmqMessageSender  {

    @Autowired
    AmqpTemplate                rabbitTemplate;

    public void submitToRMQ(String orderId){
        try{
            rabbitTemplate.convertAndSend("Hello World");
        } catch (Exception e){
            LOGGER.error(e.getMessage());
        }
    }
}

위 예외 블록은 아래 예외를 제공합니다.


org.springframework.amqp.AmqpAuthenticationException : com.rabbitmq.client.AuthenticationFailureException : ACCESS_REFUSED-인증 메커니즘 PLAIN을 사용하여 로그인이 거부되었습니다. 자세한 내용은 브로커 로그 파일을 참조하십시오.


오류 기록

  =ERROR REPORT==== 7-Nov-2014::18:04:37 ===
closing AMQP connection <0.489.0> (10.1.XX.2XX:52298 -> 10.1.XX.2XX:5672):
    {handshake_error,starting,0,
                     {amqp_error,access_refused,
                                 "PLAIN login refused: user 'guest' can only connect via localhost",
                                 'connection.start_ok'}}

Pls는 pom.xml 항목 아래에서 찾습니다.

        <dependency>
            <groupId>org.springframework.amqp</groupId>
            <artifactId>spring-rabbit</artifactId>
            <version>1.3.6.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.integration</groupId>
            <artifactId>spring-integration-amqp</artifactId>
            <version>4.0.4.RELEASE</version>
        </dependency>

의견이나 제안이 있으면 알려주십시오.



답변

Artem Bilan이 여기에서 설명한 것이이 오류의 원인 중 하나 일 수 있습니다.

Caused by: com.rabbitmq.client.AuthenticationFailureException:
ACCESS_REFUSED - Login was refused using authentication mechanism PLAIN.
For details see the

하지만 나를위한 해결책 은 게스트 / 게스트 인 기본 사용자 이름과 암호 로 rabbitMQ 관리 페이지 ( http : // localhost : 15672 / # / users )에 로그인 한 다음 새 사용자를 추가하고 해당 새 사용자를 위해 I 가상 호스트에서 액세스 할 수있는 권한을 활성화 한 다음 기본 게스트 대신 새 사용자 이름과 암호를 사용하여 오류를 해결했습니다.

여기에 이미지 설명 입력


답변

@ cpu-100 답변 을 완료하려면 ,

웹 인터페이스를 활성화 / 사용하지 않으려는 경우 아래와 같은 명령 줄을 사용하여 새 자격 증명을 생성하고이를 코드에서 사용하여 RabbitMQ에 연결할 수 있습니다.

$ rabbitmqctl add_user YOUR_USERNAME YOUR_PASSWORD
$ rabbitmqctl set_user_tags YOUR_USERNAME administrator
$ rabbitmqctl set_permissions -p / YOUR_USERNAME ".*" ".*" ".*"


답변

사용자 ‘guest’는 localhost를 통해서만 연결할 수 있습니다.

RabbitMQ 3.3.x 이후로 사실입니다. 따라서 클라이언트 라이브러리와 동일한 버전으로 업그레이드하거나 Spring AMQP를 최신 버전으로 업그레이드해야합니다 (종속성 관리 시스템을 사용하는 경우).

127.0.0.1host옵션에 대한 기본값으로 사용 된 이전 버전의 클라이언트 ConnectionFactory.


답변

오류

ACCESS_REFUSED - Login was refused using authentication mechanism PLAIN. For details see the broker logfile.

애플리케이션이 RabbitMQ에 연결하는 데 사용하려는 자격 증명이 올바르지 않거나 누락 된 경우 발생할 수 있습니다.

ASP.NET 응용 프로그램의 web.config파일에 저장된 RabbitMQ 자격 증명에 ""실제 암호 문자열 값 대신 암호 값 이있을 때 이런 일이 발생했습니다 .


답변

게스트 액세스를 원격으로 허용하려면 다음을 작성하십시오.

[{rabbit, [{loopback_users, []}]}].

여기로

c:\Users\[your user name]\AppData\Roaming\RabbitMQ\rabbitmq.config

그런 다음 rabbitmq Windows 서비스를 다시 시작하십시오 (출처 https://www.rabbitmq.com/access-control.html )


답변

저에게 해결책은 간단했습니다. 사용자 이름은 대소 문자를 구분합니다. 올바른 대문자를 사용하지 않으면 오류가 발생합니다.


답변

새로운 솔루션 :

노드 모듈 :이 암호를 제대로 처리 할 수 ​​없습니다 . 정상적으로 작동하는 것처럼 URL로 인코딩 된 경우에도 작동하지 않습니다.

암호에 URL의 일반적인 특수 문자를 사용하지 마십시오!

다음 중 하나와 같습니다. : . ? + %


원본, 오답 :

오류 메시지 PLAIN는를 사용하는 것에 대해 분명히 불평 합니다. 이는 자격 증명이 잘못되었음을 의미하는 것이 아니라 일반 텍스트 대신 암호화 된 데이터 전송 (TLS)을 사용해야 함을 의미합니다.

amqp://연결 문자열을 amqps://(참고 s) 로 변경하면 이 문제가 해결됩니다.