1.今日内容大纲

  1. 进程的介绍(理论部分)

  2. 进程的创建以及分析

  3. 获取进程的pid

  4. 进程之间的隔离

1.进程的介绍(理论部分)

1.1什么是进程

一个正在被cpu执行的程序就是一个进程,一个程序可以开启多个进程。

1.2 串行、并发、并行

1.2.1 串行

程序一个一个的被执行,同一时刻cpu只能执行一个程序。

1.2.2 并行

并行是同时运行多个程序,一个cpu运行一个程序,如果4个cpu同时运行4个程序。

1.2.3 并发

伪并行,看起来像是同时运行,其实是cpu在不同的任务间来回切换。多道技术。

  • 谁的效率最高?

    并行的效率最高。

  • 除去并行,直说串行和并发,谁的效率高?

    如果多个任务都是计算密集型,串行的效率高。

    如果IO密集型的任务居多,并发的效率高。

1.3 阻塞、非阻塞

  • 阻塞

    程序运行中由于某种原因(input,accept等)使得程序夯住,等待一段时间之后(获取到了结果之后),再继续运行。如果阻塞了,操作系统会将cpu从此任务中切换到执行其他的任务。

  • 非阻塞

    程序运行开始至结束中途无需等待结果(停住)。

1.4 进程的创建

无论哪一种,新进程的创建都是由一个已经存在的进程执行了一个用于创建进程的系统调用而创建的:(言外之意,一个进程的创建一定是基于一个父进程)

  • 在UNIX中该系统调用是:fork,fork会创建一个与父进程一模一样的副本,二者有相同的存储映像、同样的环境字符串和同样的打开文件(在shell解释器进程中,执行一个命令就会创建一个子进程)

  • 在windows中该系统调用是:CreateProcess,CreateProcess既处理进程的创建,也负责把正确的程序装入新进程。

关于创建的子进程,UNIX和windows

相同的是:进程创建后,父进程和子进程有各自不同的地址空间(多道技术要求物理层面实现进程之间内存的隔离),任何一个进程的在其地址空间中的修改都不会影响到另外一个进程。

不同的是:在UNIX中,子进程的初始地址空间是父进程的一个副本,提示:子进程和父进程是可以有只读的共享内存区的。但是对于windows系统来说,从一开始父进程与子进程的地址空间就是不同的。

1.5 进程的三个状态

进程的三个状态:运行,阻塞,就绪。

2.python的并发编程之多进程

2.1创建进程的两种方式

  • 引子

    我们之前写的那些项目,模拟博客园,ATM,教务管理系统等等都是一个程序,只有socket才是开启了多个进程进行操作。

  • 函数式开启进程的方式

     from multiprocessing import Process
     ​
     ​
     def task(a):
      print('in task')
      return a + 1
     ​
     ​
     if __name__ == '__main__': # windows系统下,开启多进程一定要配置这行代码。
     ​
      p1 = Process(target=task, args=(100,)) # 创建一个子进程对象
      p1.start() # 通知操作系统在内存中开辟一个子进程空间,将主进程所有的资源深copy一份放置到子进程空间中
      print('=====主')
     ​
     ​
     ​
     # import time
     # a = 1
     # b = 2
     # print(a + b)
     # time.sleep(2)
     # print(666)
    • 为什么主进程先执行,而子进程后执行?

      当p.start执行时,内存中马上开辟一个空间,创建一个子进程,此时cpu对应的就是在主子进程之间选择切换,由于子进程还需要加载数据等,遇到了阻塞,所以先执行主进程,这也说明了开启进程的开销相对较大。

  • 面向对象开启进程方式

     # from multiprocessing import Process
     # import time
     #
     # def task(a):
     # print('in task')
     # return a + 1
     #
     #
     # if __name__ == '__main__': # windows系统下,开启多进程一定要配置这行代码。
     #
     # p1 = Process(target=task, args=(100,)) # 创建一个子进程对象
     # p1.start() # 通知操作系统在内存中开辟一个子进程空间,将主进程所有的资源深copy一份放置到子进程空间中
     # time.sleep(1)
     # print('=====主')
     ​
     ​
     ​
     # import time
     # a = 1
     # b = 2
     # print(a + b)
     # time.sleep(2)
     # print(666)
     ​
     ​
     from multiprocessing import Process
     import time
     ​
     class MyProcess(Process):
     ​
      def __init__(self, name):
      super().__init__()
      self.name = name
     ​
      def run(self): # 子进程的任务
      print(f'{self.name}开始运行了')
      time.sleep(2)
      print(f'{self.name}子进程结束了')
     ​
     ​
     if __name__ == '__main__':
     ​
      p1 = MyProcess('玮哥')
      p1.start()
      time.sleep(1)
      print('=====主')

    注意:在windows中Process()必须放到# if name == 'main':下

     Since Windows has no fork, the multiprocessing module starts a new Python process and imports the calling module. 
     If Process() gets called upon import, then this sets off an infinite succession of new processes (or until your machine runs out of resources).
     This is the reason for hiding calls to Process() inside
     ​
     if __name__ == "__main__"
     since statements inside this if-statement will not get called upon import.
     由于Windows没有fork,多处理模块启动一个新的Python进程并导入调用模块。
     如果在导入时调用Process(),那么这将启动无限继承的新进程(或直到机器耗尽资源)。
     这是隐藏对Process()内部调用的原,使用if __name__ == “__main __”,这个if语句中的语句将不会在导入时被调用。
     ​
     详细解释

python 网络并发 :理论部分的更多相关文章

  1. python网络编程基础(线程与进程、并行与并发、同步与异步、阻塞与非阻塞、CPU密集型与IO密集型)

    python网络编程基础(线程与进程.并行与并发.同步与异步.阻塞与非阻塞.CPU密集型与IO密集型) 目录 线程与进程 并行与并发 同步与异步 阻塞与非阻塞 CPU密集型与IO密集型 线程与进程 进 ...

  2. python网络编程——IO多路复用之select

    1 IO多路复用的概念 原生socket客户端在与服务端建立连接时,即服务端调用accept方法时是阻塞的,同时服务端和客户端在收发数据(调用recv.send.sendall)时也是阻塞的.原生so ...

  3. 笔记之Python网络数据采集

    笔记之Python网络数据采集 非原创即采集 一念清净, 烈焰成池, 一念觉醒, 方登彼岸 网络数据采集, 无非就是写一个自动化程序向网络服务器请求数据, 再对数据进行解析, 提取需要的信息 通常, ...

  4. python网络编程-01

    python网络编程 1.socket模块介绍 ①在网络编程中的一个基本组件就是套接字(socket),socket是两个程序之间的“信息通道”. ②套接字包括两个部分:服务器套接字.客户机套接字 ③ ...

  5. 156个Python网络爬虫资源

    本列表包含Python网页抓取和数据处理相关的库. 网络相关 通用 urllib - 网络库(标准库) requests - 网络库 grab - 网络库(基于pycurl) pycurl - 网络库 ...

  6. 如何利用Python网络爬虫爬取微信朋友圈动态--附代码(下)

    前天给大家分享了如何利用Python网络爬虫爬取微信朋友圈数据的上篇(理论篇),今天给大家分享一下代码实现(实战篇),接着上篇往下继续深入. 一.代码实现 1.修改Scrapy项目中的items.py ...

  7. python多进程并发和多线程并发和协程

    为什么需要并发编程? 如果程序中包含I/O操作,程序会有很高的延迟,CPU会处于等待状态,这样会浪费系统资源,浪费时间 1.Python的并发编程分为多进程并发和多线程并发 多进程并发:运行多个独立的 ...

  8. 使用Python进行并发编程

    让计算机程序并发的运行是一个经常被讨论的话题,今天我想讨论一下Python下的各种并发方式. 并发方式 线程(Thread) 多线程几乎是每一个程序猿在使用每一种语言时都会首先想到用于解决并发的工具( ...

  9. python 网络编程 IO多路复用之epoll

    python网络编程——IO多路复用之epoll 1.内核EPOLL模型讲解     此部分参考http://blog.csdn.net/mango_song/article/details/4264 ...

随机推荐

  1. 导入tensorflow.出现importError: DLL load failed: 找不到指定的模块。

    导入tensorflow.出现importError: DLL load failed: 找不到指定的模块. 原因 这是由于windows上没有相应的动态链接库导致的,tensorflow依赖很多c+ ...

  2. python给图片打马赛克

    图片马赛克 关注公众号"轻松学编程"了解更多. 导包 import numpy as np import matplotlib.pyplot as plt %matplotlib ...

  3. P1526 [NOI2003]智破连环阵

    目录 题意描述 算法分析 闲话 初步分析 具体思路 剪枝一 剪枝二 剪枝三 总结一下 代码实现 预处理 剪枝一 剪枝二 剪枝三 二分图匹配 代码综合 结语 又是被楼教主虐的体无完肤的一天 题意描述 在 ...

  4. Java的浅拷贝与深拷贝

    Java的浅拷贝与深拷贝 Java中,所有的类都继承Object,Object中有clone方法,它被声明为了 protected ,所以我们但是如果要使用该方法就得重写且声明为public,必须在要 ...

  5. Java的内存区域划分

    内存分区简介 老生常谈的问题了,虽然网上一搜一大把,也很详细,但是我还是想写一写,通过自己的总结整理,加深一下印象. 我不知道学习Java内存分区有什么实际作用,但它就是像常识一样,一个使用Java语 ...

  6. 阅源-jdk8-FunctionalInterface注解

    package java.lang; import java.lang.annotation.*; /** * An informative annotation type used to indic ...

  7. Mongodb和Hbase的对比

    Mongodb和Hbase的对比 1.Mongodb bson文档型数据库,整个数据都存在磁盘中,hbase是列式数据库,集群部署时每个familycolumn保存在单独的hdfs文件中. 2.Mon ...

  8. 无字母数字getshell

    无字母数字webshell 预备知识 一些不包含数字和字母的webshell https://www.leavesongs.com/PENETRATION/webshell-without-alpha ...

  9. zabbix自动发现的python方式数据生成

    前言 zabbix里面有个功能是自动发现,比如文件系统和网卡的获取的时候,因为预先无法知道这个网卡的名称,所以就有了这个自动发现的功能,这里我是因为要用到存储池的自动发现,所以需要对数据进行生成 实现 ...

  10. bWAPP----SQL Injection (GET/Search)

    SQL Injection (GET/Search) 输入单引号 报错,在%'附近出错,猜测参数被 '%  %'这种形式包裹,没有任何过滤,直接带入了数据库查询 输入order by查询列 union ...