首页
/ CZMQ 技术文档

CZMQ 技术文档

2024-12-23 15:48:54作者:余洋婵Anita

本文档将详细介绍如何安装、使用及API调用CZMQ项目。CZMQ是ZeroMQ(ØMQ)的高级别C语言绑定库,旨在简化ØMQ的使用并提供更加易于理解的高级API。

1. 安装指南

1.1 使用包管理器安装

Linux

在Debian和Ubuntu系统中,可以通过包管理器直接安装CZMQ:

sudo apt-get install czmq

对于其他发行版,可以参考packages.org获取安装包。

也可以在openSUSE的构建服务上获取最新git master分支的预编译二进制文件:

  • 仅包含稳定API的Git master分支: http://software.opensuse.org/download.html?project=network%3Amessaging%3Azeromq%3Agit-stable&package=czmq
  • 包含草稿API的Git master分支: http://software.opensuse.org/download.html?project=network%3Amessaging%3Azeromq%3Agit-draft&package=czmq

MacOS

在macOS上,可以使用Homebrew安装CZMQ:

brew install czmq

Windows

如果使用vcpkg,可以通过以下命令下载和安装CZMQ:

vcpkg install czmq

此命令将构建32位共享库。以下是构建64位静态库的命令:

vcpkg install czmq:x64-windows-static

还可以选择安装包含可选库的CZMQ:

vcpkg install czmq[curl,httpd,lz4]:x64-windows

若要使用草稿API,请在安装时添加draft特性:

vcpkg install czmq[draft]

若要始终使用最新版本的CZMQ,请添加--head选项:

vcpkg install czmq --head

这些命令还将打印出如何在MSBuild或CMake项目中使用库的说明。

1.2 在Linux和macOS上构建

首先,需要以下软件包:

  • git -- 用于与其他人共享代码。
  • build-essential, libtool, pkg-config -- C编译器和相关工具。
  • autotools-dev, autoconf, automake -- GNU autoconf makefile生成器。
  • cmake -- CMake makefile生成器(autoconf的替代品)。

以及其他一些软件包:

  • uuid-dev, libpcre3-dev -- 实用库。
  • valgrind -- 用于检查代码的工具。
  • pkg-config -- 使依赖项构建更简单的可选工具。

在Debian风格的系统中,可以这样安装:

sudo apt-get update
sudo apt-get install -y \
    git build-essential libtool \
    pkg-config autotools-dev autoconf automake cmake \
    uuid-dev libpcre3-dev valgrind

# 如果需要更新手册页(会增加构建时间),请执行以下命令:
sudo apt-get install -y asciidoc

以下是如何从GitHub构建CZMQ的步骤(从包构建非常相似,不同之处在于解压缩tarball而不是克隆仓库),包括libzmq(ZeroMQ核心库):

git clone https://github.com/zeromq/libzmq.git
cd libzmq
./autogen.sh
./configure --with-libsodium
make check
sudo make install
sudo ldconfig
cd ..

git clone https://github.com/zeromq/czmq.git
cd czmq
./autogen.sh && ./configure && make check
sudo make install
sudo ldconfig
cd ..

通常,CZMQ与最新的libzmq master分支配合使用效果最佳。如果系统中已安装较旧的libzmq版本,例如在/usr/目录下,则可以:

# 在系统上安装较旧版本的libzmq
sudo apt-get install libzmq3-dev

2. 项目的使用说明

CZMQ提供了一系列高级API,用于简化ZeroMQ的消息传递操作。使用CZMQ,开发者可以轻松创建消息框架、安全认证、网络发现等功能。

以下是一个简单的示例,展示如何使用CZMQ创建一个Réactor模式的消息处理程序:

#include <czmq.h>

int main(void) {
    zactor_t *server = zactor_new(zserver, NULL);
    zsock_send(server, "ss", "BIND", "tcp://*:5555");

    zactor_t *client = zactor_new(zclient, NULL);
    zsock_send(client, "ss", "CONNECT", "tcp://localhost:5555");

    // 等待消息
    zmsg_t *request = zactor_recv(client);
    if (request) {
        zmsg_print(request);
        zmsg_destroy(&request);
    }

    zactor_destroy(&server);
    zactor_destroy(&client);
    return 0;
}

3. 项目API使用文档

CZMQ提供了丰富的API,以下是一些核心类的简要描述:

  • zactor: 简单的Actor框架。
  • zauth: ØMQ安全机制的认证。
  • zbeacon: 局域网发现和存在。
  • zcert: 适用于CURVE安全证书的操作。
  • zchunk: 内存块操作。
  • zclock: 毫秒级时钟和延迟。
  • zconfig: 处理以rfc.zeromq.org/spec:4/ZPL格式编写的配置文件。
  • zdigest: 提供散列函数(目前为SHA-1)。
  • zdir: 文件系统目录操作。
  • zfile: 提供以可移植方式处理文件的方法。
  • zframe: 单个消息帧操作。
  • zgossip: 去中心化配置管理。
  • zhash: 简单的通用哈希容器。
  • zlist: 简单的通用列表容器。
  • zloop: 事件驱动的Réactor。
  • zmonitor: 套接字事件监控。
  • zmsg: 多部分消息操作。
  • zpoller: 简单的套接字轮询器类。
  • zproxy: 在后台运行可 steer 的代理。
  • zsock: 隐藏libzmq上下文和套接字的顶层套接字API。
  • zstr: 发送和接收字符串。
  • zsys: 系统级方法。
  • ztimerset: 定时器集。
  • ztrie: 简单的可标记字符串trie。
  • zuuid: UUID支持类。

具体API的使用方法和示例代码,请参考CZMQ的官方文档和示例。

4. 项目安装方式

CZMQ可以通过多种方式安装,以下是一些常见的安装方法:

  • 使用包管理器(如上所述)。
  • 从源代码构建(如上所述)。
  • 使用容器(如Docker)。

请根据具体的操作系统和环境选择合适的安装方式。

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

热门内容推荐

最新内容推荐

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
144
1.94 K
kernelkernel
deepin linux kernel
C
22
6
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
274
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
145
189
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
930
554
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
887
394
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
75
66
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.11 K
0
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
64
512