用Python操作nanomsg(一)——准备

日前因工作需要,整在一点一点熟悉开源跨平台消息中间件:nanomsg,恰逢最近安装了Typora用于练习Markdown语法,那就一并把学习总结整理记录下来并同步更新到简书方便他人和自己日后回看。

关于nanomsg

nanomsg.org

nanomsg是一个消息通信组件,由zeroMQ的作者之一用C语言重写的通信框架,可以简单理解为跟Socket一样的东西,不过相比Socket它有很多优秀的特性,目前在各开发语言中都有相应的wrapper,其C、C++和Python的wrapper如下:

语言 库地址 说明
C nanomsg Reference implementation, sustaining mode
NNG Modern re-implementation.
C++ nanomsgxx
cppnanomsg
nngpp (NNG binding)
Python nanomsg-python
nnpy
pynng NNG binding. Docs here.

nnpy是其中一个对nanomsg的python wrapper,相比于nanomsg-python日渐缺少维护,更推荐使用nnpy。另外,现在也有了nng(nanomsg next negeration),当nanomsg使用熟练后可考虑转nng。

安装

本文基于Pyhton3.7,当前nnpy的最新版本为1.4.2,依次安装cmake、nanomsg、cffi和nnpy:

#安装cmake
sudo apt-get install cmake
#安装nanomsg
git clone https://github.com/nanomsg/nanomsg.git
cd nanomsg
mkdir build
cd build
cmake ..
cmake --build .
ctest -C Debug .
sudo cmake --build --target install
sudo ldconfig
#先安装cffi,版本要求为>=1.0
pip3 install cffi
#安装nnpy
pip3 install nnpy

配置开发环境

这里使用的开发环境为Jetbrains Pycharm 2019 + WSL,WSL使用的是Kali-Linux,其他版本如Ubuntu、Debian等也都可以。

设置WSL为Python Interpreter

我本机装的是Python 3.6,点击右下角当前正在使用的本地解析器名称Python 3.6,选择Add Interpreter

选择Add Interpreter

从左侧选择WSL后,右侧面板自动出来当前的WSL发行版本,注意的是这里默认的解析器路径为/usr/bin/python,Kali-Linux默认安装的时候只有python3没有python,需要手动改为/usr/bin/python3

修改为可用的python路径(这里为/usr/bin/python3)

而后点击OK完成WSL Interpreter的添加,在右下角选择3.7@Kali Linux即可启用WSL作为远程开发环境——不需要SSH、虚拟机或VPS就能在Windows下进行Linux开发,简直不要太舒服!!

选择刚才创建的WSL环境进行开发

nanomsg通信模式

nanomsg提供了如下几种通信模式,太具体的不介绍,说完会用就明白是怎么回事儿了:

PipeLine

  • aggregates messages from multiple sources and load balances them among many destinations

  • 单向管道模式,只能从一个node发往另一个node,不能临时对调角色

PushPub

  • distributes messages to large sets of interested subscribers

  • 发布/订阅模式,发布者可以广播消息,订阅者可以接收消息并且可选订阅消息的前缀,发布者发布信息与订阅者状态无关,订阅者如果不在线则会错过发布者在其不在线时刻发布的消息,上线时则不会错过任何消息

Pair

  • simple one-to-one communication

  • 一对一模式,一个node只能连接一个node,双向通信(send阻塞、recv不阻塞)

ReqRep

  • allows to build clusters of stateless services to process user requests

  • 请求/回复模式,每个request请求都要有与之对应的report相应

Survey

  • allows to query state of multiple applications in a single go

  • 调查模式,看官网介绍类似于PushPub的双向通信版本,允许一次查询多个应用的状态(暂时还没理解)

Bus:

  • simple many-to-many communication

  • 总线模式,一个总线上可以有多个套接字(即是server也是client),在总线上只要有消息产生都能收到,自己产生的消息除外(可理解为多对多通信)。

关于各通信模式的验证请前往本系列后续文章:

主题 文章地址 说明
PipeLine 用Python操作nanomsg(二)——PipeLine 2020.2.7更新
PushPub 用Python操作nanomsg(三)——PubSub 2020.2.8更新
Pair 用Python操作nanomsg(四)——Pair 未开始
ReqRep 用Python操作nanomsg(五)——ReqRep 未开始
Survey 用Python操作nanomsg(六)——Survey 未开始
Bus 用Python操作nanomsg(七)——Bus 未开始
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,612评论 5 471
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,345评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,625评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,022评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,974评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,227评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,688评论 3 392
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,358评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,490评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,402评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,446评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,126评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,721评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,802评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,013评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,504评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,080评论 2 341