#用类方法  服务端

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的更多相关文章

  1. python socket之tcp服务器与客户端demo

    python socket之tcp服务器与客户端demo 作者:vpoet mails:vpoet_sir@163.com server: # -*- coding: cp936 -*- ''' 建立 ...

  2. python multiprocessing example

    python multiprocessing example Server Code: #!/usr/bin/python #-*- coding: UTF-8 -*- # mpserver.py # ...

  3. python MultiProcessing模块进程间通信的解惑与回顾

    这段时间沉迷MultiProcessing模块不能自拔,没办法,python的基础不太熟,因此就是在不断地遇到问题解决问题.之前学习asyncio模块学的一知半解,后来想起MultiProcessin ...

  4. python小练习---TCP服务器端

    针对于上一篇分享python小练习---TCP客户端 http://www.cnblogs.com/zhaijiahui/p/6926197.html我继续按书中内容,向下进行这里需要强调一个事py3 ...

  5. 【Python】如何基于Python写一个TCP反向连接后门

    首发安全客 如何基于Python写一个TCP反向连接后门 https://www.anquanke.com/post/id/92401 0x0 介绍 在Linux系统做未授权测试,我们须准备一个安全的 ...

  6. Python中的Tcp协议的应用之Tcp服务端程序开发

    TCP通信协议是面向连接的可靠的网络通信协议. 网络间想要进行数据传输必须要用到socket,socket翻译过来叫做套接字,其主要作用是不同设备或同一台设备之间的进程通信工具. Python中的Tc ...

  7. python中的tcp示例详解

    python中的tcp示例详解  目录 TCP简介 TCP介绍 TCP特点 TCP与UDP的不同点 udp通信模型 tcp客户端 tcp服务器 tcp注意点   TCP简介   TCP介绍 TCP协议 ...

  8. python multiprocessing模块

    python multiprocessing模块 原文地址 multiprocessing multiprocessing支持子进程.通信和共享数据.执行不同形式的同步,提供了Process.Queu ...

  9. python socket 模拟tcp通讯

    对于tcp server 端的创建而言, 分为如下步骤:   1,创建socket对象(socket):其中俩个参数分别为     Address Family(如AF_INET为ipv4),AF_I ...

随机推荐

  1. hexo发表博文

    3.4创建博客文章与发布 在hexo 目录下终端命令: $ hexo new '文件名' //会在source/_posts创建一个文件名.md文件 这就可以使用markdown编辑器开始写自己的博客 ...

  2. 梯度迭代树(GBDT)算法原理及Spark MLlib调用实例(Scala/Java/python)

    梯度迭代树(GBDT)算法原理及Spark MLlib调用实例(Scala/Java/python) http://blog.csdn.net/liulingyuan6/article/details ...

  3. spark pyspark 常用算法实现

    利用Spark-mllab进行聚类,分类,回归分析的代码实现(python) http://www.cnblogs.com/adienhsuan/p/5654481.html 稀疏向量: 关于Spar ...

  4. js高级-数组的map foreach 方法

    函数式编程  sort map forEach  ....  jQuery() 数组的sort 方法 传入一个匿名函数 就是函数式编程 ie9 以上的浏览器支持 map 方法 map方法 返回一个新数 ...

  5. linux服务不支持chkconfig的解决

    服务不支持chkconfig的解决 写了脚本,想用命令chkconfig加载自启动.提示xxxxxxx服务不支持chkconfig",原来是自己写的脚本时,忘记写两行了.开头一般要这样写 # ...

  6. Java中递归的优缺点,Java写一个递归遍历目录下面的所有文件包括子文件夹里边的文件。

    题目: 遍历出aaa文件夹下的文件 首先分析思路: 1.首先判断这个文件夹是否为文件,通过isFile()函数可以判断是否为文件. 2.然后通过isDirectory判断是否为目录. 3.如果是目录就 ...

  7. ORACLE grant权限

    oracle的系统和对象权限 本文转自: http://hi.baidu.com/zhaojing_boy/blog/item/0ffe95091266d939e824885f.html alter ...

  8. java 反编译工具

    (1)点击进入>>   https://jingyan.baidu.com/article/3f16e003c857082590c1036f.html (备注:如果以上链接的资源不能下载, ...

  9. C/s程序过时了吗?

    目前的程序从原来的形态演变成了 C/s,B/s,和手机端. 其实应该各有自己的客户群,及定位. 比如C/s为单机版的可以完成个性化突出的复杂客户端应用,企业级别的应用. B/s的特点安装简单,功能制作 ...

  10. Python之逻辑回归模型来预测

    建立一个逻辑回归模型来预测一个学生是否被录取. import numpy as np import pandas as pd import matplotlib.pyplot as plt impor ...