当前位置:首页 > 科技  > 软件

一篇文章带你了解Python的分布式进程接口

来源: 责编: 时间:2024-04-11 17:29:38 119观看
导读一、前言在Thread和Process中,应当优选Process,因为Process更稳定,而且,Process可以分布到多台机器上,而Thread最多只能分布到同一台机器的多个CPU上。Python的multiprocessing模块不但支持多进程,其中managers子模块还支持

一、前言

JH528资讯网——每日最新资讯28at.com

在Thread和Process中,应当优选Process,因为Process更稳定,而且,Process可以分布到多台机器上,而Thread最多只能分布到同一台机器的多个CPU上。JH528资讯网——每日最新资讯28at.com

Python的multiprocessing模块不但支持多进程,其中managers子模块还支持把多进程分布到多台机器上。可以写一个服务进程作为调度者,将任务分布到其他多个进程中,依靠网络通信进行管理。JH528资讯网——每日最新资讯28at.com

二、案例分析

在做爬虫程序时,抓取某个网站的所有图片,如果使用多进程的话,一般是一个进程负责抓取图片的链接地址,将链接地址放到queue中,另外的进程负责 从queue中取链接地址进行下载和存储到本地。JH528资讯网——每日最新资讯28at.com

怎么用分布式进程实现?JH528资讯网——每日最新资讯28at.com

一台机器上的进程负责抓取链接地址,其他机器上的进程负责系在存储。那么遇到的主要问题是将queue 暴露到网络中,让其他机器进程都可以访问,分布式进程就是将这个过程进行了封装,可以将这个过程称为本地队列的网络化。JH528资讯网——每日最新资讯28at.com

例:JH528资讯网——每日最新资讯28at.com

1.pyJH528资讯网——每日最新资讯28at.com

from multiprocessing.managers import BaseManagerfrom multiprocessing import freeze_support, Queue# 任务个数task_number = 10# 收发队列task_quue = Queue(task_number)result_queue = Queue(task_number)def get_task():    return task_quuedef get_result():    return result_queue# 创建类似的queueManagerclass QueueManager(BaseManager):    passdef win_run():    # 注册在网络上,callable 关联了Queue 对象    # 将Queue对象在网络中暴露    # window下绑定调用接口不能直接使用lambda,所以只能先定义函数再绑定    QueueManager.register('get_task_queue', callable=get_task)    QueueManager.register('get_result_queue', callable=get_result)    # 绑定端口和设置验证口令    manager = QueueManager(address=('127.0.0.1', 8001), authkey='qiye'.encode())    # 启动管理,监听信息通道    manager.start()    try:        # 通过网络获取任务队列和结果队列        task = manager.get_task_queue()        result = manager.get_result_queue()        # 添加任务        for url in ["ImageUrl_" + str(i) for i in range(10)]:            print('url is %s' % url)            task.put(url)                    print('try get result')        for i in range(10):            print('result is %s' % result.get(timeout=10))    except:        print('Manager error')    finally:        manager.shutdown()if __name__ == '__main__':    freeze_support()    win_run()

连接服务器,端口和验证口令注意保持与服务器进程中完全一致从网络获取Queue,进行本地化,从task队列获取任务,并且把结果写入result队列JH528资讯网——每日最新资讯28at.com

2.pyJH528资讯网——每日最新资讯28at.com

#coding:utf-8import timefrom multiprocessing.managers import BaseManager# 创建类似的Manager:class Manager(BaseManager):    pass#使用QueueManager注册获取Queue的方法名称Manager.register('get_task_queue')Manager.register('get_result_queue')#连接到服务器:server_addr = '127.0.0.1'print('Connect to server %s...' % server_addr)# 端口和验证口令注意保持与服务进程设置的完全一致:m = Manager(address=(server_addr, 8001), authkey='qiye')# 从网络连接:m.connect()#获取Queue的对象:task = m.get_task_queue()result = m.get_result_queue()#从task队列取任务,并把结果写入result队列:while(not task.empty()):        image_url = task.get(True,timeout=5)        print('run task download %s...' % image_url)        time.sleep(1)        result.put('%s--->success'%image_url)#结束:print('worker exit.')

任务进程要通过网络连接到服务进程,所以要指定服务进程的IP。JH528资讯网——每日最新资讯28at.com

运行结果如下:JH528资讯网——每日最新资讯28at.com

获取图片地址,将地址传到2.py。JH528资讯网——每日最新资讯28at.com

JH528资讯网——每日最新资讯28at.com

接收1.py传递的地址,进行图片的下载,控制台显示爬取结果。JH528资讯网——每日最新资讯28at.com

JH528资讯网——每日最新资讯28at.com

三、总结

本文基于Python基础,Python的分布式进程接口简单,封装良好,适合需要把繁重任务分布到多台机器的环境下。通过讲解Queue的作用是用来传递任务和接收结果。JH528资讯网——每日最新资讯28at.com

欢迎大家积极尝试,有时候看到别人实现起来很简单,但是到自己动手实现的时候,总会有各种各样的问题,切勿眼高手低,勤动手,才可以理解的更加深刻。JH528资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-82946-0.html一篇文章带你了解Python的分布式进程接口

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: markdown-it大揭秘:轻松玩转文本格式化新神器!

下一篇: C++中的外部模板及其在当前编译文件中的实例化

标签:
  • 热门焦点
  • 石头自清洁扫拖机器人G10S评测:多年黑科技集大成之作 懒人终极福音

    石头自清洁扫拖机器人G10S评测:多年黑科技集大成之作 懒人终极福音

    科技圈经常能看到一个词叫“缝合怪”,用来形容那些把好多功能或者外观结合在一起的产品,通常这样的词是贬义词,但如果真的是产品缝合的好、缝合的实用的话,那它就成了中性词,今
  • 6月iOS设备好评榜:第一蝉联榜首近一年

    6月iOS设备好评榜:第一蝉联榜首近一年

    作为安兔兔各种榜单里变化最小的那个,2023年6月的iOS好评榜和上个月相比没有任何排名上的变化,仅仅是部分设备好评率的下降,长年累月的用户评价和逐渐退出市场的老款机器让这
  • JavaScript 混淆及反混淆代码工具

    JavaScript 混淆及反混淆代码工具

    介绍在我们开始学习反混淆之前,我们首先要了解一下代码混淆。如果不了解代码是如何混淆的,我们可能无法成功对代码进行反混淆,尤其是使用自定义混淆器对其进行混淆时。什么是混
  • K8S | Service服务发现

    K8S | Service服务发现

    一、背景在微服务架构中,这里以开发环境「Dev」为基础来描述,在K8S集群中通常会开放:路由网关、注册中心、配置中心等相关服务,可以被集群外部访问;图片对于测试「Tes」环境或者
  • 微信语音大揭秘:为什么禁止转发?

    微信语音大揭秘:为什么禁止转发?

    大家好,我是你们的小米。今天,我要和大家聊一个有趣的话题:为什么微信语音不可以转发?这是一个我们经常在日常使用中遇到的问题,也是一个让很多人好奇的问题。让我们一起来揭开这
  • 小红书1周涨粉49W+,我总结了小白可以用的N条涨粉笔记

    小红书1周涨粉49W+,我总结了小白可以用的N条涨粉笔记

    作者:黄河懂运营一条性教育视频,被54万人“珍藏”是什么体验?最近,情感博主@公主是用鲜花做的,火了!仅仅凭借一条视频,光小红书就有超过128万人,为她疯狂点赞!更疯狂的是,这
  • 猿辅导与新东方的两种“归途”

    猿辅导与新东方的两种“归途”

    作者|卓心月 出品|零态LT(ID:LingTai_LT)如何成为一家伟大企业?答案一定是对“势”的把握,这其中最关键的当属对企业战略的制定,且能够站在未来看现在,即使这其中的
  • 8月见!小米MIX Fold 3获得3C认证:支持67W快充

    8月见!小米MIX Fold 3获得3C认证:支持67W快充

    这段时间以来,包括三星、一加、荣耀等等有不少品牌旗下的最新折叠屏旗舰都得到了不少爆料,而小米新一代折叠屏旗舰——小米MIX Fold 3此前也屡屡被传
  • 网传小米汽车开始筛选交付中心 建筑面积不低于3000平方米

    网传小米汽车开始筛选交付中心 建筑面积不低于3000平方米

    7月7日消息,近日有微博网友@长三角行健者爆料称,据经销商集团反馈,小米汽车目前已经开始了交付中心的筛选工作,要求候选场地至少有120个车位,建筑不能低
Top