前言
python multiprocessing中的queue实现进程间通信也是可以,但是在使用过程中遇到了一些问题.
处于性能考虑,思考使用Linux环境下的系统调用来进行进程间通信.本想自己实现一个Python的第三方拓展.
仔细考察一番后,发现已经有一个第三方库实现, posix-ipc
和 sysv-ipc
的实现.
由于实际的工作环境是Linux,且考虑到易用性,最终选择了 posix-ipc
来解决问题.
安装 posix-ipc
posix-ipc提供了共享内存、消息队列、信号量相关。
pip install posix-ipc
使用
该第三方库,源码中提供了比较完善的demo源码.此处仅仅举例使用消息队列.
消息队列消费实现
import posix_ipc import selectors # This program uses `posix_ipc` together with the `selectors`library from the # Python standard library. `selectors` provides "high-level I/O multiplexing" akin to having an event library. # The message queue is created as usual mq = posix_ipc.MessageQueue("/python_ipc_test", flags=posix_ipc.O_CREAT) mq.block = False # Function is defined to handle events on the queue def accept(message_queue, mask): (msg, prio) = message_queue.receive() print("Message: ", msg) print("Priority: ", prio) # The selector can now be created... sel = selectors.DefaultSelector() # ... and the message queue is registered. Other event sources could also be # registered simultaneously, but for now we stick to the queue sel.register(mq, selectors.EVENT_READ, accept) # `.select()` will block until an event is triggered # for i in range(10000*3+1): events = sel.select() for key, mask in events: # `.data` contains the third argument from `.register` above -- we use it for the callback. callback = key.data callback(key.fileobj, mask) # With the message successfully received, we can unlink and close. mq.unlink() mq.close()
队列生产实现
import posix_ipc # This program opens the message queue and sends a message mq = posix_ipc.MessageQueue("/python_ipc_test") mq.block = True import time st = time.time() print(f"start time {st}") # for i in range(270000): mq.send("From transmitter") ed = time.time() print(f"end time {ed}, use {ed - st} .")
版权声明:除特别注明外,本站所有文章均为王晨曦个人站点原创
转载请注明:出处来自王晨曦个人站点 » python 使用 linux 系统调用实现进程间通信
all white 11s nike low top air max lunette ray ban aviator noir what sell pandora bracelets black and red quince dresses the north face w diablo down jkt gtrelarm http://www.gtrelarm.com/
ganni feather trimmed dress red wing moc toe black sole nike air max excee famous footwear san francisco giants spring training hat for sale plus gingham dress atlanta braves green hat zionsville indiana batiservis http://www.batiservis.net/
Excavator And Bulldozer Spare Parts Polyoxymethylene/POM/Delrin/Acetal rods ルイヴィトン財布コピー
Reversing Lead Screw ルイヴィトン財布スーパーコピー Camping Table with Fabric Surface
Colorful And Round Plastic Comb Solar Panel Installation ルイヴィトンコピー財布
Shockwave Machine For Erectile Dysfunction ルイヴィトン財布スーパーコピー Thermoplast Solid PP toilet seat
Novelty Desk Fan SAE 15.82 - 5/8' Series Quick Connector ヴィトン財布コピー
Active Load Balancer ALB ルイヴィトン財布コピー激安代引き Rail Drilling Rig
Four In One Lead Sheet ルイヴィトン財布スーパーコピー 10KV High Voltage Solid Soft Start Device
18mm Plywood RGB Bathroom Mirror ルイヴィトンコピー財布
balenciagas red blanc 47 brand san francisco giants hat liners us western wedding apparel boy knit hats pattern 3ds double sole rick owens balenciaga track men hotelruf http://www.hotelruf.net/
ルイヴィトンコピー財布 Light Weight Plastic Case Alma Soprano Ice Platinum
0064201420 Mercedes Benz Front Brake Pad Set Striped Bucket Hat ルイヴィトンコピー財布
イヴィトン財布コピー激安代引き Green Energy Home A0034319507 Mercedes Benz Brake Valve
ヴィトン財布コピー 20A TRWR GFCI Round Paper Cardboard Gift Box
ルイヴィトン財布コピー Cnc Precision Turning Parts Power Supply PCB
Duo Silicone Rabbit With Suction Functions Purple ヴィトン財布コピー 915 Antenna
New Fashion Party Decorative Sequin Jazz Hat ルイヴィトン財布コピー Receptacle Replacement
ルイヴィトン財布コピー激安代引き Soluble Film Valve Body Processing
lightweight long sleeve button up shirts pandora chinese doll charm pandora signature collection nike air vapormax flyknit 2021 tight long sleeve shirt new york rangers panarin jersey smefaculty http://www.smefaculty.com/
Outdoor Camping Solar Light 300-500 Square Meters Ocean Theme Indoor Playground ヴィトン財布コピー
ルイヴィトン財布スーパーコピー 16W Waterproof LED Edge-lit Strips For Lightbox Earth Auger
infinity dress strapless adidas continental vulc yellow italy euro 2021 football shirt titleist tour flat bill long white shrug iphone xs max case near me lialusin http://www.lialusin.com/
SMC Basketball Board Mould イヴィトン財布コピー激安代引き Cam Buckle
adidas laufschuh zx 500 og core black toronto blue jays playoff hat designs reebok cheetah zac dysert 4 jersey for cheap thick strap black dress orange toronto blue jays hat 80s polofutar http://www.polofutar.com/