1 端口说明

RabbitMQ Web管理端口是15672,默认情况下为localhost:15672网页登陆提供用户名guest,密码guest的登陆账号。

注意:guest账号默认情况下只支持本地机器使用,访问URL:http://localhost:15672/或者http://127.0.0.1:15672/


RabbitMQ 服务默认连接端口是5672,可以通过advanced.config配置文件修改
注意:如果连接返回connection closed unexpectedly,说明端口不正确

注意:在RabbitMQ服务安装的本地机器,可以通过127.0.0.1和guest账号登陆访问MQ,其他的机器无法通过guest账号登陆访问MQ

die_on_amqp_error(amqp_login(conn, "/", 0, 131072, 0, AMQP_SASL_METHOD_PLAIN,"guest", "guest")
使用用户名guest ,密码guest。登陆出现如下的错误:User can only log in via localhost
默认情况下guest是无法发送数据的,必须进行修改

 

2
amqp_consumer和amqp_producer例子中并没有指定交换机的类型,说明当前交换机的创建权力交给其他的创建者在这里,并没有并没有指定队列名称,而是通过指定routing_key,来关联相应的队列名。匹配的方式根据交换机的类型来确定

amqp_consume_message函数执行的返回值保存在amqp_rpc_reply_t ret;

/**
 * Response type
 *
 * \since v0.1
 */

typedef enum amqp_response_type_enum_
{
  AMQP_RESPONSE_NONE = 0, /**< the library got an EOF from the socket */
 
AMQP_RESPONSE_NORMAL, /**< response normal, the RPC completed successfully */
 
AMQP_RESPONSE_LIBRARY_EXCEPTION, /**< library error, an error occurred in the
  library, examine the library_error */
 
AMQP_RESPONSE_SERVER_EXCEPTION   /**< server exception, the broker returned an
  error, check replay */
} amqp_response_type_enum;
默认情况下ret.reply_type等于AMQP_RESPONSE_NORMAL说明回复正常,RPC正确执行。AMQP_RESPONSE_LIBRARY_EXCEPTION说明在函数
调用过程中返回结果异常(并不是说编译的库出现问题,而是在跟服务器通信的时候,遇到其他的异常,例如接收超时,例如连接断开等等)

例如,当接收超时的时候ret.library_error的返回值是-13,操作超时
  AMQP_STATUS_TIMEOUT = -0x000D,                    /**< Operation timed out */

 AMQP_STATUS_SOCKET_ERROR = -0x0009,               /**< A socket error
 occurred */
当跟服务器断开连接的时候,会返回-9错误码,在例子中并没有处理这种异常情况,实际上需要进行重连