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. 仅用六种字符来完成Hello World,你能做到吗?

    Hello World 对于每一个开发者来说都不陌生,因为在我们学习任何一个语言或框架的时候,都会有一个Hello World的案例来帮助我们快速入门. 如果我们使用JavaScript来输出Hell ...

  2. NER的数据处理

    import os class TransferData: def __init__(self): cur = '/'.join(os.path.abspath(__file__).split('/' ...

  3. php 获取抖音id

    <?php public function getid($dy_url){ $header=get_headers($dy_url); $str = "/^.*?(\d+).*/&qu ...

  4. Git常用命令【ZeyFra】

    // 账户设置 git config --global user.name "ZeyFra" git config --global user.email "zeyfra ...

  5. TCP Persist 坚持定时器

    1.坚持定时器在接收方通告接收窗口为0,阻止发送端继续发送数据时设定. 由于连接接收端的发送窗口通告不可靠(只有数据才会确认),如果一个确认丢失了,双方就有可能因为等待对方而使连接终止: 接收放等待接 ...

  6. linux netfilter ----iptable_filter

    内核中将filter模块被组织成了一个独立的模块,每个这样独立的模块中都有个类似的init()初始化函数:首先来看一下filter模块是如何将自己的钩子函数注册到netfilter所管辖的几个hook ...

  7. sql sever 2008基础知识

    下面是一些总结,如果执行时发现错误,可以查看错误消息进行解决,也可上网查资料 数据库的组成: 主数据文件:有且只有一个,扩展名为.mdf. 次数据文件:可以没有,也可以有任意个.扩展名为.ndf. 日 ...

  8. linux文本模式和文本替换功能

    linux文本有:正常模式,编辑模式,可视化模式,命令模式. 正常模式进入编辑模式下的快捷键: i  --光标当前位置输入 a --光标位置后输入(append) I --行首输入 A --行尾输入 ...

  9. Mac OS终端利器 iTem2 配置大全

    转载链接:https://www.cnblogs.com/diyxiaoshitou/p/9017413.html 之前一直使用 Mac OS 自带的终端,用起来虽然有些不太方便,但总体来说还是可以接 ...

  10. [head first 设计模式] 第一章 策略模式

    [head first 设计模式] 第一章 策略模式 让我们先从一个简单的鸭子模拟器开始讲起. 假设有个简单的鸭子模拟器,游戏中会出现各种鸭子,此系统的原始设计如下,设计了一个鸭子超类,并让各种鸭子继 ...