码迷,mamicode.com
首页 > 系统相关 > 详细

多进程并发简单socket

时间:2018-06-17 20:49:58      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:==   lis   客户   cep   add   send   erro   int   close   

server---------------------
这种简单实现:坏处客户端启动一个一个进程,进程多了机器要蹦
#!/usr/bin/env python
# encoding: utf-8  
# Date: 2018/6/17


from socket import *
from multiprocessing import Process


# 负责通信
def talk(conn):
    while True:
        try:
            data = conn.recv(1024)
            if not data: break
            conn.send(data.upper())
        except ConnectionResetError:
            break
    conn.close()


# 建立链接
def server(ip, port):
    server = socket(AF_INET, SOCK_STREAM)
    server.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
    server.bind((ip, port))
    server.listen(5)

    while True:
        conn, addr = server.accept()
        p = Process(target=talk, args=(conn,))
        p.start()
    server.close()


if __name__ == ‘__main__‘:
    server(‘127.0.0.1‘, 8080)

    
    
client-------------------
#!/usr/bin/env python
# encoding: utf-8  
# Date: 2018/6/17

# 客户端可以启动多个进程,启动一个就是一个进程
from socket import *

client = socket(AF_INET, SOCK_STREAM)
client.connect((‘127.0.0.1‘, 8080))

while True:
    msg = input(‘>>>:‘).strip()
    if not msg: continue
    client.send(msg.encode(‘utf-8‘))
    data = client.recv(1024)
    print(data.decode(‘utf-8‘))


    
    
    
   

多进程并发简单socket

标签:==   lis   客户   cep   add   send   erro   int   close   

原文地址:https://www.cnblogs.com/fmgao-technology/p/9193628.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!