2020-11-20 利用python创建多进程UDP通信

今天学习一下python端的UDP通信,在网上找了资料学习

有一些值得注意的地方:如果没有这段代码:

server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)

将会出现错误

还有一些细节:如下

p = Process(target=f, args=('huang',))   #一般需要传入target目标函数,args函数的参数 args=('',)这个“,”不能省略

服务器端代码如下(大量参考互联网资料):

 

import socket
from multiprocessing import Process
import sys, os


def my_fun(self):
    try:
        # 变量声明
        PORT = 9999
        server_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
        #重复使用绑定信息
        server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
        address = ("192.168.130.130", PORT)
        server_socket.bind(address)
        while True:
            print('server waiting')
            receive_data, client_address = server_socket.recvfrom(1024)
            print("接收到了客户端 %s 传来的数据: %s" % (client_address, receive_data.decode()))
            server_socket.sendto(bytes("hello , if you want to exit the dialog,input quit please!".encode('utf-8')),
                             client_address, )
            #if (str(receive_data, 'utf8') == 'quit'):
            #    print('client exit')
            #     break
    finally:
        server_socket.close()


def works(func, arg, worknum):
    proc_record = []
    for i in range(worknum):
        p = Process(target=func, args=(arg,))
        p.start()
        proc_record.append(p)
    for p in proc_record:
        p.join()


if __name__ == '__main__':
    arg = 5
    procs=3
    #procs = 4   #进程个数
    # works(timetask, arg, procs)
    works(my_fun, arg, procs)



 

客户端代码:

import socket



client_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)

while True:

    msg = input("请输入要发送的内容:")

    server_address = ("192.168.130.130", 9999)

    client_socket.sendto(msg.encode(), server_address)

    receive_data,server_address=client_socket.recvfrom(1024)

    print("recv server %s data:%s" %(server_address,receive_data.decode()))

    if(msg=='exit'):

        break



client_socket.close()

基本实现了基于python 的UDP通信,收获满满的一天!

 
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Python中,可以使用socket在多个进程之间进行通信。Socket不仅可以在不同主机之间进行通信,还可以在同一主机的不同进程之间进行通信。 Socket通信可以通过TCP或UDP来实现,具体使用哪种协议取决于你的需求。在多进程编程中,每个进程可以创建一个socket对象,并通过socket对象的方法进行通信。可以使用socket的bind()方法将socket绑定到指定的IP地址和端口上,然后使用listen()方法开始监听连接请求。接下来,可以使用accept()方法接受客户端的连接请求,并通过recv()和send()方法进行数据的接收和发送。不同进程之间的通信可以通过socket的不同实例进行。需要注意的是,多进程通信中需要考虑进程间数据传递的同步问题,以避免数据的丢失或者冲突。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Python实现多进程通信的方法总结](https://blog.csdn.net/tyhj_sf/article/details/97401263)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [python多进程通信实例分析](https://blog.csdn.net/weixin_30587927/article/details/101082252)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值