首页
/ Haigha - 同步与异步的AMQP客户端库技术文档

Haigha - 同步与异步的AMQP客户端库技术文档

2024-12-26 09:15:39作者:裴锟轩Denise

1. 安装指南

Haigha是一个用于与AMQP代理交互的客户端库,支持同步和异步操作。以下是安装Haigha的步骤:

使用pip安装

Haigha可以通过pip从PyPI安装:

pip install haigha

从源码安装

如果你希望从源码安装Haigha,可以按照以下步骤操作:

  1. 克隆Haigha的GitHub仓库:

    git clone https://github.com/agoragames/haigha.git
    
  2. 进入项目目录:

    cd haigha
    
  3. 安装依赖:

    • 如果需要安装开发依赖(如测试框架):

      pip install -r development.txt
      
    • 如果不需要开发依赖:

      pip install -r requirements.txt
      

安装异步支持

Haigha支持多种异步传输类型,包括libeventgevent。默认情况下,Haigha不会自动安装这些依赖。如果你需要使用libevent,可以手动安装:

pip install event-agora==0.4.1

2. 项目的使用说明

Haigha提供了一个简单易用的接口来与AMQP代理进行交互。以下是一个简单的使用示例,展示了如何连接、声明交换机和队列、发布消息以及获取消息:

from haigha.connection import Connection
from haigha.message import Message

# 创建连接
connection = Connection(
    user='guest', password='guest',
    vhost='/', host='localhost',
    heartbeat=None, debug=True
)

# 创建通道
ch = connection.channel()

# 声明交换机
ch.exchange.declare('test_exchange', 'direct')

# 声明队列
ch.queue.declare('test_queue', auto_delete=True)

# 绑定队列到交换机
ch.queue.bind('test_queue', 'test_exchange', 'test_key')

# 发布消息
ch.basic.publish(Message('body', application_headers={'hello': 'world'}),
                 'test_exchange', 'test_key')

# 获取消息
print(ch.basic.get('test_queue'))

# 关闭连接
connection.close()

使用RabbitMQ协议扩展

如果你需要使用RabbitMQ的协议扩展,可以使用RabbitConnection类来初始化连接:

from haigha.connections.rabbit_connection import RabbitConnection

connection = RabbitConnection(
    user='guest', password='guest',
    vhost='/', host='localhost',
    heartbeat=None, debug=True
)

3. 项目API使用文档

Haigha的API设计简洁,易于使用。以下是一些常用的API方法:

连接管理

  • Connection(user, password, vhost, host, heartbeat, debug):创建一个新的AMQP连接。
  • connection.channel():创建一个新的通道。
  • connection.close():关闭连接。

通道管理

  • channel.exchange.declare(exchange, type):声明一个交换机。
  • channel.queue.declare(queue, auto_delete):声明一个队列。
  • channel.queue.bind(queue, exchange, routing_key):将队列绑定到交换机。
  • channel.basic.publish(message, exchange, routing_key):发布消息到指定的交换机和路由键。
  • channel.basic.get(queue):从队列中获取一条消息。

消息管理

  • Message(body, application_headers):创建一个新的消息对象。

4. 项目安装方式

Haigha可以通过多种方式安装,具体取决于你的需求:

使用pip安装

pip install haigha

从源码安装

  1. 克隆仓库:

    git clone https://github.com/agoragames/haigha.git
    
  2. 进入项目目录:

    cd haigha
    
  3. 安装依赖:

    • 安装开发依赖:

      pip install -r development.txt
      
    • 安装生产依赖:

      pip install -r requirements.txt
      

安装异步支持

如果你需要使用libeventgevent,可以手动安装相关依赖:

pip install event-agora==0.4.1

总结

Haigha是一个功能强大且易于使用的AMQP客户端库,支持同步和异步操作。通过本文档,你可以快速了解如何安装、使用Haigha,并掌握其核心API的使用方法。希望本文档能帮助你更好地理解和使用Haigha。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
155
245
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
773
477
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
117
171
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
137
256
csv4cjcsv4cj
一个支持csv文件的读写、解析的库
Cangjie
11
3
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
377
363
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
79
2
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.04 K
0
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
320
1.05 K
open-eBackupopen-eBackup
open-eBackup是一款开源备份软件,采用集群高扩展架构,通过应用备份通用框架、并行备份等技术,为主流数据库、虚拟化、文件系统、大数据等应用提供E2E的数据备份、恢复等能力,帮助用户实现关键数据高效保护。
HTML
114
77