iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python3 进程锁
  • 229
分享到

python3 进程锁

进程 2023-01-31 01:01:02 229人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

多进程抢占资源 当多个进程使用同一份数据资源的时候,就会引发数据安全或顺序混乱问题。 import os import time import random from multiprocessing import Proc

多进程抢占资源
当多个进程使用同一份数据资源的时候,就会引发数据安全或顺序混乱问题。

	import os
	import time
	import random
	from multiprocessing import Process,Lock
	
	def work(n):
	    print('%s: %s is runing' % (n,os.getpid()))
	    time.sleep(random.random())
	    print('%s: %s is down' % (n, os.getpid()))
	  
	
	if __name__ == '__main__':
	    for i in range(3): # 利用for循环模拟多进程
	        p=Process(target=work,args=(i,))
	        p.start()
	        
输出结果:
0: 10974 is runing
1: 10975 is runing
2: 10976 is runing
1: 10975 is down
2: 10976 is down
0: 10974 is down

# 由并发变成了串行,牺牲了运行效率,但避免了竞争
import os
import time
import random
from multiprocessing import Process,Lock

def work(lock,n):
    lock.acquire()
    print('%s: %s is runing' % (n,os.getpid()))
    time.sleep(random.random())
    print('%s: %s is down' % (n, os.getpid()))
    lock.release()

if __name__ == '__main__':
    lock = Lock()
    for i in range(3):
        p=Process(target=work,args=(lock,i))
        p.start()

输出结果:
0: 10986 is runing
0: 10986 is down
1: 10987 is runing
1: 10987 is down
2: 10988 is runing
2: 10988 is down

上面这种情况虽然使用加锁的形式实现了顺序的执行,但是程序又重新变成串行了,这样确实会浪费了时间,却保证了数据的安全。这个过程类似于数据库事务


例子:模拟抢票

没有加锁的情况,虽然实现了并发,但是数据不安全,本来只有一张票,但是还是会有多个人抢到,这显然不符合现实

# 文件db的内容为:{"count":1}
# 注意一定要用双引号,不然JSON无法识别
# 并发运行,效率高,但竞争写同一文件,数据写入错乱

from multiprocessing import Process
import time,json,random

def search():
    dic = json.load(open('db'))
    print('\033[43m剩余票数%s\033[0m' % dic['count'])

def get():
    dic = json.load(open('db'))
    time.sleep(0.1)   # 模拟读数据延迟
    if dic['count'] > 0:
        dic['count'] -= 1
        time.sleep(0.2)  # 模拟写数据延迟
        json.dump(dic,open('db','w'))
        print('\033[43m购票成功\033[0m')

def task():
    search()
    get()

if __name__ == '__main__':
    for i in range(100):    # 模拟并发100个客户端抢票
        p=Process(target=task)
        p.start()

加锁

# 文件db的内容为:{"count":5}
# 注意一定要用双引号,不然json无法识别
# 并发运行,效率高,但竞争写同一文件,数据写入错乱

from multiprocessing import Process,Lock
import time,json,random

def search():
    dic=json.load(open('db'))
    print('\033[43m剩余票数:%s\033[0m' % dic['count'])

def get():
    dic=json.load(open('db'))
    time.sleep(random.random()) # 模拟读数据的网络延迟
    if dic['count'] > 0:
        dic['count'] -= 1
        time.sleep(random.random()) # 模拟写数据的网络延迟
        json.dump(dic,open('db','w'))
        print('\033[43m购票成功\033[0m')

    else:
        print('\033[43m余票不足\033[0m')

def task(lock):
    search()
    lock.acquire()
    get()
    lock.release()

if __name__ == '__main__':
    lock=Lock()
    for i in range(100): # 模拟并发100个客户端
        p=Process(target=task,args=(lock,))
        p.start()

输出结果:
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
剩余票数:5
购票成功
购票成功
购票成功
购票成功
购票成功
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足
余票不足

Process finished with exit code 0

因为只有5张票,因此加锁后只会有5个人买到票,保证了数据的安全性。

--结束END--

本文标题: python3 进程锁

本文链接: https://www.lsjlt.com/news/184154.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • python3 进程锁
    多进程抢占资源 当多个进程使用同一份数据资源的时候,就会引发数据安全或顺序混乱问题。 import os import time import random from multiprocessing import Proc...
    99+
    2023-01-31
    进程
  • python3--进程
    进程顾名思义,进程即正在执行的一个过程。进程是对正在运行程序的一个抽象。进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一。操作系统的其他所有内容都是围绕进程的概念展开的一 操作系统...
    99+
    2023-01-30
    进程
  • python3进程和线程
    进程基本概念 进程是执行中的程序, 也就是说进程是动态的, 程序是静态的 进程是操作系统分配资源的最小单位,有一个进程控制块(PCB), 有自己唯一的一个进程标识符(PID) 进程之间相互独立, 内存不共享 每个进程都是一个实体, ...
    99+
    2023-01-31
    线程 进程
  • python3多进程实现
    python多进程的主要方式有两种,一种是使用os模块的fork方法,另一种方法是使用multiprocessing模块,这两种方法的就别在于前者仅适用于Unix/Linux操作系统,后者是跨平台的实现方式 1.使用fork方法实...
    99+
    2023-01-31
    进程
  • Python进程锁和进程池
    进程锁进程与进程之间是独立的,为何需要锁?对于进程,屏幕的输出只有一个,此时就涉及到资源的竞争。在Linux的Python2.x中可能出现问题。这仅仅是一种情况,多个进程之间虽然是独立的,但仅限于内存和运算,如果涉及到其它一些资源,就可能存...
    99+
    2023-01-31
    进程 Python
  • python3--线程,锁,同步锁,递归锁,信号量,事件,条件和定时器,队列,线程池
    线程什么是线程?线程是cpu调度的最小单位进程是资源分配的最小单位进程和线程是什么关系?  线程是在进程中的 一个执行单位  多进程 本质上开启的这个进程里就有一个线程  多线程 单纯的在当前进程中开启了多个线...
    99+
    2023-01-30
    递归 线程 信号量
  • python3--进程同步(multiprocess.Lock, Semaphore, Event)
    socket基于tcp协议的多进程聊天(异步)server端代码import socket from multiprocessing import Process def chat(conn...
    99+
    2023-01-30
    进程 multiprocess Event
  • Python3中最常用的5种线程锁的应用
    本篇内容主要讲解“Python3中最常用的5种线程锁的应用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python3中最常用的5种线程锁的应用”吧!目录前言线程安全锁的作用Lock() 同步锁...
    99+
    2023-06-20
  • python3--进程,线程,协程效率对比
    需求:写一个脚本,判断192.168.11.0/24网络里,当前在线ip有哪些?知识点:1 使用subprocess模块,来调用系统命令,执行ping 192.168.11.xxx 命令2 调用系统命令执行ping命令的时候,会有返回值(p...
    99+
    2023-01-30
    线程 进程 效率
  • Python3教程——5、Python3
            一、Pycharm常用快捷键 有颜色的为很常用,或不易发现   编辑类: Ctrl + Space 基本的代码完成(类、方法、属性) Ctrl + Alt + Space 类名完成 Ctrl + Shift + Ent...
    99+
    2023-01-31
    教程
  • Python3实用编程技巧进阶
    var 立即前往 = " http://icourse8.com/Python3_pcjqjj.html "; 章节信息 第1章 课程简介(本课程基于py3.x并赠送py2.x的讲解) 第2章 数据结构与算法相关问题与解决技巧 ...
    99+
    2023-01-31
    进阶 编程技巧
  • Python3 异步编程之进程与线程-1
    Python3 异步编程之进程与线程-1一、了解进程间通信进程间通信进程线程线程 vs 进程IO模型并发 vs 并行异步 vs 同步二、多线程与多进程的用法计算密集型 vs I/O密集型GIL多线程多进程三、协程的好处与用法协程yieldy...
    99+
    2023-01-31
    线程 进程
  • Python3中最常用的5种线程锁实例总结
    目录前言线程安全锁的作用Lock() 同步锁基本介绍使用方式死锁现象with语句RLock() 递归锁基本介绍使用方式with语句Condition() 条件锁基本介绍使用方式wit...
    99+
    2022-11-12
  • Python3的进程和线程你了解吗
    目录1.概述2.多进程3.子进程4.进程间通信5.多线程6.Lock7.ThreadLocal8.进程VS线程9.分布式进程总结1.概述 """ 基础知识: 1.多任务:操作系统可以...
    99+
    2022-11-13
  • 用python3的多进程和协程处理MyS
    本文介绍用python3的多进程 + 协程处理MySQL的数据,主要逻辑是拉取MySQL的数据,然后使用flashtext匹配关键字,在存回MySQL,代码如下(async_mysql.py): import time import asy...
    99+
    2023-01-31
    进程 和协 MyS
  • Python3 串口两进程同时读写
    通过两个进程分别读写串口,并把发送与接收到的内容记录在blog中,收到q时程序结束并退出import threading,time import serial import string class SerThread: de...
    99+
    2023-01-31
    串口 进程
  • python3--中的进程操作--multiprocess模块
    在python程序中的进程操作运行中的程序就是一个进程。所有的进程都是通过它的父进程来创建的。因此,运行起来的python程序也是一个进程,那么我们也可以在程序中再创建进程。多个进程可以实现并发效果,也就是说,当我们的程序中存在多个进程的时...
    99+
    2023-01-30
    模块 进程 操作
  • Oracle 解除锁定进程
    一、碰到的问题:    1、修改表结构时,Oracle提示“资源正忙,要求制定NOWAIT……”——此处我修改的是字段长度,从200增加到1000. &nb...
    99+
    2022-10-18
  • Python进程池与进程锁实例分析
    本篇内容主要讲解“Python进程池与进程锁实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python进程池与进程锁实例分析”吧!进程池什么是进程池上一章节关于进程的问题我们提到过,进程...
    99+
    2023-06-29
  • python3 教程
    查看Python版本 我们可以使用一下命令来查看我们使用的Python版本: python -V 以上命令执行结果如下: python 3.3.2 你也可以进入python的交换式编程模式,查看版本: Python 3.3.2 (v3.3...
    99+
    2023-01-31
    教程
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作