基于scopedsession实现线程安全

技术基于scopedsession实现线程安全 基于scoped_session实现线程安全一、基于scoped_session实现线程安全
from sqlalchemy.orm import ses

基于作用域_会话实现线程安全

一、基于scoped_session实现线程安全

来自sqlalchemy.orm导入sessionmaker

从sqlalchemy导入创建引擎

从sqlalchemy.orm导入作用域会话

从模型导入用户

engine=create _ engine(' MySQL pymysql ://root :123 @ 127。0 .0 .1:3306/db _ flask ',max_overflow=0,pool_size=5)

会话=会话创建者(绑定=引擎)

'''

# 线程安全,基于本地线程实现每个线程用同一个会议

# 特殊的:作用域_会话中有原来方法的会议中的一下方法:

public_methods=(

__包含“__”、“__iter__”、“add”、“add_all”、“begin”、“begin_nested”,

关闭','提交','连接','删除','执行','过期,

expire_all ',' expect ge ',' expect ge _ all ',' flush ',' get_bind ',

is_modified ',' bulk_save_objects ',' bulk_insert_mappings ',

批量_更新_映射,

合并','查询','刷新','回滚,

"标量"

)

'''

#作用域_会话类并没有继承会话,但是却又它的所有方法

会话=作用域_会话(会话)

# ############# 执行ORM操作#############

obj1=用户(名称='randy ')

session.add(obj1)

# 提交事务

session.commit()

# 关闭会议

session.close()

二、底层实现原理

2.1作用域_会话进入类

从sqlalchemy.orm导入作用域会话

会话=作用域_会话(会话)

用于会话中的方法public_methods:

setattr(scoped_session,方法,仪器(方法))

public_methods=(

__包含_ _ ',

__iter__ ',

添加,

add_all ',

开始,

begin_nested ',

关闭,

提交,

连接,

删除,

执行,

过期,

expire_all ',

删除,

'全部删除,

齐平,

get_bind ',

is_modified ',

bulk_save_objects ',

大容量插入映射,

批量_更新_映射,

合并,

查询,

刷新,

回滚,

标量,

)

首先进入点击作用域_会话进入作用域_会话类查看如下内容

用于会话中的方法public_methods:

setattr(scoped_session,方法,仪器(方法))

为scoped_sesion类设置属性

公共方法中内容:

这是在会议类中的内容

public_methods=(

__包含_ _ ',

__iter__ ',

添加,

add_all ',

开始,

begin_nested ',

关闭,

提交,

连接,

删除,

执行,

过期,

expire_all ',

删除,

'全部删除,

齐平,

get_bind ',

is_modified ',

bulk_save_objects ',

大容量插入映射,

批量_更新_映射,

合并,

查询,

刷新,

回滚,

标量,

)

setattr(scoped_session,方法,仪器(方法))这句中的工具是一个闭包函数

改闭包函数中实现了对数据库中具体操作

self.registry()中实现如下,为其实现了一个线程

类作用域_会话(对象):

会话工厂=无

def __init__(self,session_factory,scopefunc=None):

自我。会话工厂=会话工厂

if scopefunc:

自我。registry=ScopedRegistry(session _ factory,scopefunc)

else:

自我。注册表=线程本地注册表(会话工厂)

线程内容如下,最终利用线程中的本地()模块中实现线程的安全,也就是操作数据的安全:

类threadlocalregistry(ScopedRegistry):

def __init__(self,createfunc):

self.createfunc=createfunc

self.registry=threading.local()

总结:

会话=作用域_会话(会话)这个会议是那一个操作过来就是哪一个操作,只操作自己对数据的操作,从而保证了线程的安全

在当下的阶段,必将由程序员来主导,甚至比以往更甚。

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/74733.html

(0)

相关推荐

  • 怎么解决MySQL中ERROR 1044 (42000)报错问题

    技术怎么解决MySQL中ERROR 1044 (42000)报错问题这篇文章主要讲解了“怎么解决MySQL中ERROR 1044 (42000)报错问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路

    攻略 2021年11月18日
  • 偶数的概念,奇数和偶数的概念0是什么数

    技术偶数的概念,奇数和偶数的概念0是什么数1993年我国颁布的《中华人民共和国国家标准》(GB3100-3102-93)《量和单位》(11-2.9)P311页,规定自然数包括0。在以往的教学中,关于自然数的组成,有两种情

    生活 2021年10月24日
  • mysql创建删除索引(mysql中如何删除索引)

    技术mysql如何删除index索引小编给大家分享一下mysql如何删除index索引,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

    攻略 2021年12月21日
  • 如何使用Python开发定制界面

    技术如何使用Python开发定制界面这篇文章主要介绍了如何使用Python开发定制界面,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1 准备SD卡8G以上

    攻略 2021年11月12日
  • C#打印源码的具体实现是怎样的

    技术C#打印源码的具体实现是怎样的本篇文章给大家分享的是有关C#打印源码的具体实现是怎样的,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。C#打印源码也是打印

    攻略 2021年11月24日
  • MySQL中行转列、列转行、连接字符串 concat、concat_ws、group_concat函数怎么用

    技术MySQL中行转列、列转行、连接字符串 concat、concat_ws、group_concat函数怎么用这篇文章主要介绍MySQL中行转列、列转行、连接字符串 concat、concat_ws、group_c

    攻略 2021年10月29日