问题描述

【k8s】或【普通容器】或【Linux】部署的RabbitMQ启动时出现了 epmd error for host xx.xx: nxdomain (non-existing domain) 错误,MQ无法启动成功。

其中 xx.xx 为无法解析的域名。

RabbitMQ官方还提到报错 Error during startup: {error,no_epmd_port} 也是同样的情况。

解决办法

这里简单记录下解决办法,分别以 Linux环境、docker容器环境、k8s环境、说明下。

Linux环境

/etc/hosts 文件添加域名解析 xx.xx127.0.0.1,以下示例:

127.0.0.1 mydomain.io

docker容器环境

docker run命令添加 --add-host 参数

–add-host=“” : Add a line to /etc/hosts (host:IP)

示例:

docker run -d --add-host="mydomain.io:127.0.0.1" -p 5672:5672 rabbitmq:latest

k8s环境

在 podTemplate的spec下添加 hostname 写上域名,当rabbitmq访问该域名时自动映射到POD上。

示例:

apiVersion: apps/v1kind: StatefulSetmetadata:name: rabbitmqlabels:app: rabbitmqspec:replicas: 1selector:matchLabels:app: rabbitmqserviceName: rabbitmqtemplate:metadata:labels:app: rabbitmqspec:hostname: "mydomain.io"containers:- name: rabbitmqimage: 'rabbitmq:latest'ports:- name: tcp-5672containerPort: 5672protocol: TCPenv:- name: TZvalue: 'Asia/Shanghai'

k8s官方文档上还有添加 hostAlias 的办法,这里简单截个图放一下文档地址:https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#PodSpec

参考:

  • https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#PodSpec
  • https://docs.docker.com/engine/reference/run/#network-settings
  • https://www.rabbitmq.com/kubernetes/operator/troubleshooting-operator.html#pods-restart-on-startup