Flask ==> scoped_session
from sqlalchemy.orm import sessionmaker from sqlalchemy import create_engine from sqlalchemy.orm import scoped_session engine = create_engine( "mysql+pymysql://root:123@47.93.4.198:3306/s6?charset=utf8", max_overflow=0, # 超过连接池大小外最多创建的连接 pool_size=5, # 连接池大小 pool_timeout=30, # 池中没有线程最多等待的时间,否则报错 pool_recycle=-1 # 多久之后对线程池中的线程进行一次连接的回收(重置) ) SessionFactory = sessionmaker(bind=engine) # 方式一:由于无法提供线程共享功能,所有在开发时要注意,在每个线程中自己创建 session。 # from sqlalchemy.orm.session import Session # 自己具有操作数据库的:'close', 'commit', 'connection', 'delete', 'execute', 'expire',..... session = SessionFactory() # print('原生session',session) # 操作 sql语句 session.close() # 方式二:支持线程安全,为每个线程创建一个session,单线程就不会创建多个。 # - threading.Local 用过的地方:数据库连接池 # - 唯一标识 用过的地方:session,request,gevent,app # ScopedSession对象 # self.registry(), 加括号 创建session # self.registry(), 加括号 创建session # self.registry(), 加括号 创建session from greenlet import getcurrent as get_ident session = scoped_session(SessionFactory,get_ident) # get_ident(): 可以获取当前线程的唯一标识 # session.add # 操作 sql语句 session.remove()
小结:
1.scoped_session的的功能: 支持了线程安全。
方式一:手动维护,各种操作都需要自己完成。由于无法提供线程共享功能,所有在开发时要注意,在每个线程中自己创建 session。
方式二:支持线程安全,为每个线程创建一个session,单线程就不会创建多个。
- threading.Local 用过的地方:数据库连接池
- 唯一标识 用过的地方:session,request,gevent,app
2.两种方式的写法不一样,但是,它们的本质是一样的。还是操作原生sql的基础上(方式1),(方式2)在(方式1)的基础上,多加了个线程安全。
通过local本地实现的。get_ident(): 可以获取当前线程的唯一标识