RabbitMQ第六课 例子说明

RabbitMQ Web管理端口是15672


RabbitMQ example例子中默认连接端口是5672。
第一次启动example,测试连接服务器,端口填写错误,连接失败,返回 connection closed unexpectedly

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是无法发送数据的,必须进行修改


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错误码,在例子中并没有处理这种异常情况,实际上需要进行重连

相关文章
相关标签/搜索