python multiprocessing 和tcp
#用类方法 服务端
from socket import *from multiprocessing import Processimport os
class Myprocess(Process): def __init__(self, conn): self.conn = conn super().__init__()
def run(self): conn = self.conn start = True while start: try: print('启动子线程:%s' % os.getpid(), end='') data = conn.recv(1024)
conn.send(data) print('线程编号:%s,data=%s' % (os.getpid(), data.decode('utf-8'))) except Exception as e: conn.close() start = False print('关闭了') conn.close()
if __name__ == '__main__': # p=Myprocess('这是测试文件') # p.start()
st = socket(AF_INET, SOCK_STREAM) host = '127.0.0.1' port = 8080 listen_number = 5 st.bind((host, port)) st.listen(listen_number) transcript = None while True: print('等待连接') conn, _ = st.accept() if conn != transcript: transcript = conn p = Myprocess(conn) p.start() print('连接成功') else: print('不知道:%s' % conn)
st.close()
#用函数方法 服务端
from multiprocessing import Processfrom socket import *import json, struct
import os
def process_communication(conn): while True: try: print('启动子线程:%s' % os.getpid(), end='') data = conn.recv(1024) conn.send(data) print('线程编号:%s,data=%s' % (os.getpid(), data.decode('utf-8'))) except Exception: conn.close() print('关闭了') break
if __name__ == '__main__':
st = socket(AF_INET, SOCK_STREAM) host = '127.0.0.1' port = 8080 listen_number = 5 st.bind((host, port)) st.listen(listen_number) transcript = None while True: print('等待连接') conn, _ = st.accept() if conn != transcript: transcript = conn p = Process(target=process_communication, args=(conn,)) p.start() #p.join() print('连接成功') else: print('不知道:%s' % conn)
st.close()
#客户端
from socket import *
st = socket(AF_INET, SOCK_STREAM)host = '127.0.0.1'port = 8080st.connect((host, port))while True:
msg = input('请输入:').strip() if not len(msg): continue
st.send(msg.encode(encoding = 'utf-8')) data=st.recv(1024) print(data.decode(encoding='utf-8'))
st.close()
(现代操作系统)书 egon老师推荐
开启线程方式一:import multiprocessingfrom multiprocesssing import Process
def task(name): print('%s is runings'%name) time.sleep(3) print('%s is done'%name)group#保留参数 无用target#任务名
#如果只有一个参数一定记住加 逗号(,)#Process(target=task,kwargs={'name':'子进程'})
if __name__=='__main__': p=Process(target=task,args=('子进程',)) p.start()#windows系统倒模块的方式,把父进程加载进去 #linux 其实不用放入main下面的, #但是为了兼容liunx和windows系统 所以全部加吧 #可以自定义函数名
#主进程会等待子进程结束后才会结束
p.start()#只是在操作系统发送一个开启子进程的信号 #p.start只是发送信号(这步速度非常快) #申请内存空间,开辟个名称空间,在将父进程的数据复制一份到这个内存空间中 #至于开启的时间,开启的方式都是操作系统说的算
class Myprocess(Process): def __init__(self,x): super().__init__() self.name=x def run(self): self.name#进程名称
if __name__=='__main__': p=Myprocess('测试') p.start()#等同于p.run()#自定义类必须实现run()方法
import timex='tiankong'def task(): global x x=0 print('done') print(x)
if __name__ == '__main__': p=Process(target=task) p.start() time.sleep(5)#让父进程等待5秒,让子进程运行完闭后,才执行下一行代码 print(x) #但是子进程不一定5秒就能运行完。、
#进程间内存隔离
from multiprocessing import Processimport time,osdef task(name,n): print('name is :%s'%name) time.sleep(3) print('子进程pid%s'%os.getpid()) print(n) print('end')
if __name__ == '__main__': p=Process(target=task,args=('子进程',('这里可以给子进程传参'))) p.start() p.pid#父进程查看 子进程的pid方式
p.join()#让父进程在原地等待,等到子进程运行完毕后,才执行下一行代码 #本质和time.sleep()一样但是等待时间不用手动输入了 print('主进程')
def walk(): print('walk:%s'%os.getpid()) time.sleep(12)
if __name__ == '__main__': p=Process(target=walk) p.start() p.is_alive()#只要信号发出,就认为这个子线程是活着 print('父进程:%s'%os.getpid()) p.join()#自动回收僵尸进程 #让父进程进入等待状态 p.terminate()#给操作系统发送信号,杀死这个子进程
#杀死进程taskkill /F /PID 进程号#liunx 中孤儿进程 父进程会变成 init
python multiprocessing 和tcp的更多相关文章
- python socket之tcp服务器与客户端demo
python socket之tcp服务器与客户端demo 作者:vpoet mails:vpoet_sir@163.com server: # -*- coding: cp936 -*- ''' 建立 ...
- python multiprocessing example
python multiprocessing example Server Code: #!/usr/bin/python #-*- coding: UTF-8 -*- # mpserver.py # ...
- python MultiProcessing模块进程间通信的解惑与回顾
这段时间沉迷MultiProcessing模块不能自拔,没办法,python的基础不太熟,因此就是在不断地遇到问题解决问题.之前学习asyncio模块学的一知半解,后来想起MultiProcessin ...
- python小练习---TCP服务器端
针对于上一篇分享python小练习---TCP客户端 http://www.cnblogs.com/zhaijiahui/p/6926197.html我继续按书中内容,向下进行这里需要强调一个事py3 ...
- 【Python】如何基于Python写一个TCP反向连接后门
首发安全客 如何基于Python写一个TCP反向连接后门 https://www.anquanke.com/post/id/92401 0x0 介绍 在Linux系统做未授权测试,我们须准备一个安全的 ...
- Python中的Tcp协议的应用之Tcp服务端程序开发
TCP通信协议是面向连接的可靠的网络通信协议. 网络间想要进行数据传输必须要用到socket,socket翻译过来叫做套接字,其主要作用是不同设备或同一台设备之间的进程通信工具. Python中的Tc ...
- python中的tcp示例详解
python中的tcp示例详解 目录 TCP简介 TCP介绍 TCP特点 TCP与UDP的不同点 udp通信模型 tcp客户端 tcp服务器 tcp注意点 TCP简介 TCP介绍 TCP协议 ...
- python multiprocessing模块
python multiprocessing模块 原文地址 multiprocessing multiprocessing支持子进程.通信和共享数据.执行不同形式的同步,提供了Process.Queu ...
- python socket 模拟tcp通讯
对于tcp server 端的创建而言, 分为如下步骤: 1,创建socket对象(socket):其中俩个参数分别为 Address Family(如AF_INET为ipv4),AF_I ...
随机推荐
- linux下给PHP安装拓展
要先完成了上一篇文章的phpize的操作,并激活它才能下一步. 下载拓展,在http://pecl.php.net/这个网站下载,其他的有可能不成功,我之前还很纳闷phpize已经调试通过了,但是切换 ...
- 16.Set、List、Queue集合;Map.md
目录 1.Set 1.2HashSet TreeSet 2.List 2.1ArrayList 2.1.1ArrayList和Vector的区别 2.2LinkedList 3.Queue 4.各种线 ...
- Unity AssetBundle
Unity AssetBundle爬坑手记 - 夜阑卧听风吹雨 时间 2014-09-15 16:55:00 博客园精华区原文 http://www.cnblogs.com/ybgame/p/39 ...
- C# 递归获取 文件夹的 所有文件
public void Director(string dir, List<string> list) { DirectoryInfo d = new DirectoryInfo(dir) ...
- 吴裕雄 06-MySQL选择数据库
实例以下实例选取了数据库 RUNOOB:use RUNOOB;注意:所有的数据库名,表名,表字段都是区分大小写的.所以你在使用SQL命令时需要输入正确的名称. 使用PHP脚本选择MySQL数据库PHP ...
- NYOJ201-作业题-(dp)
201-作业题 内存限制:64MB 时间限制:3000ms 特判: No通过数:9 提交数:28 难度:3 题目描述: 小白同学这学期有一门课程叫做<数值计算方法>,这是一门有效使用数字计 ...
- Python中struct.pack()和struct.unpack()
https://blog.csdn.net/tjuyanming/article/details/79700601 https://www.cnblogs.com/yezl/p/5861787.htm ...
- OpenCV SVM
#include <opencv2/core/core.hpp> #include <opencv2/highgui/highgui.hpp> #include <ope ...
- python遇到的错误
今天学习文件遇到这个错误. 这是在 text_files\vvvv.txt 之间加一个\ 就可以了,变成 text_files\\vvvv.txt,运行成功
- web.xml中<security-constraint>和四种认证类型
https://blog.csdn.net/lisheng19870305/article/details/40819481 sztc开发中http请求一直发送后无响应,通过soapui定位异常信息为 ...