mysql 单例模式好处_mysql的链接单例模式和线程池的优劣性

单例模式代码

from functools import wraps

import pymysql

def single(cls):

"""实现类的单例模式"""

instance_dict = dict()

@wraps(cls)

def single_instance(*args,**kwargs):

if cls not in instance_dict:

instance_dict[cls] = cls(*args,**kwargs)

return instance_dict[cls]

return single_instance

@single

class PyMySQLTest(object):

def __init__(self,db_name):

self.coon = None

self.cursor = None

self.db_name = db_name

try:

self.coon = pymysql.connect(host="xx",port=xx,user="xx",password="xx",database=self.db_name,charset="utf8")

self.cursor = self.coon.cursor()

except Exception as e:

raise e

def get_all(self):

sql = "select cow_number from cow_info where isdelete=0"

self.cursor.execute(sql)

result = self.cursor.fetchall()

print(result)

100个线程测试代码

from single_pool.test_mysql import mysql_test

from threading import Thread

import time

def test():

single_instance = mysql_test.PyMySQLTest("cattle")

single_instance.get_all()

if __name__ == '__main__':

start_time = time.time()

# 创建100个线程链接实例,测试获取数据

for i in range(100):

t = Thread(target=test)

t.start()

end_time = time.time()

print(end_time-start_time)

结果分析

测试10次 时间分别为 0.032 0.031 0.037 0.031 0.032 0.030 0.032 0.030 0.035 0.032

成功的结果

0.031002044677734375

(('1002',), ('1005',), ('2007',), ('3001',), ('3004',), ('868201803000700',), ('868201803000704',), ('868201803000702',), ('868201803000696',), ('868201803000701',), ('868201803000697',), ('868201803000699',), ('868201803000689',), ('868201803000682',), ('868201803000695',), ('868201803000688',), ('868201803000681',), ('868201803000703',), ('868201803000674',), ('868201803000651',), ('180078',), ('180025',), ('130558',), ('160080',), ('160090',), ('170071',), ('170087',), ('170099',), ('170135',), ('150153',), ('160073',), ('170083',), ('150037',), ('150249',), ('160168',), ('160002',), ('170080',), ('140157',), ('160225',), ('140161',), ('140588',), ('160804',), ('140170',), ('160068',), ('16411',), ('160527',), ('180070',), ('180026',), ('180034',), ('180004',), ('1003',), ('130653',), ('160170',), ('180753',), ('180795',), ('180698',), ('180675',), ('20191001',), ('20191002',), ('140680',), ('170058',), ('170159',), ('160059',), ('170095',), ('150092',), ('20200221',), ('20200224',), ('20200226',), ('130739',), ('160169',), ('150641',), ('160829',), ('20200301',), ('2020030111',), ('202003011112',), ('170151',), ('150350',), ('180007',), ('110615',), ('160250',), ('170107',), ('150039',), ('170153',), ('110926',), ('170136',), ('160097',), ('160423',), ('160329',), ('170069',), ('170152',), ('140738',), ('110301',), ('170092',), ('160098',), ('150090',), ('180748',))

(('1002',), ('1005',), ('2007',), ('3001',), ('3004',), ('868201803000700',), ('868201803000704',), ('868201803000702',), ('868201803000696',), ('868201803000701',), ('868201803000697',), ('868201803000699',), ('868201803000689',), ('868201803000682',), ('868201803000695',), ('868201803000688',), ('868201803000681',), ('868201803000703',), ('868201803000674',), ('868201803000651',), ('180078',), ('180025',), ('130558',), ('160080',), ('160090',), ('170071',), ('170087',), ('170099',), ('170135',), ('150153',), ('160073',), ('170083',), ('150037',), ('150249',), ('160168',), ('160002',), ('170080',), ('140157',), ('160225',), ('140161',), ('140588',), ('160804',), ('140170',), ('160068',), ('16411',), ('160527',), ('180070',), ('180026',), ('180034',), ('180004',), ('1003',), ('130653',), ('160170',), ('180753',), ('180795',), ('180698',), ('180675',), ('20191001',), ('20191002',), ('140680',), ('170058',), ('170159',), ('160059',), ('170095',), ('150092',), ('20200221',), ('20200224',), ('20200226',), ('130739',), ('160169',), ('150641',), ('160829',), ('20200301',), ('2020030111',), ('202003011112',), ('170151',), ('150350',), ('180007',), ('110615',), ('160250',), ('170107',), ('150039',), ('170153',), ('110926',), ('170136',), ('160097',), ('160423',), ('160329',), ('170069',), ('170152',), ('140738',), ('110301',), ('170092',), ('160098',), ('150090',), ('180748',))(('1002',), ('1005',), ('2007',), ('3001',), ('3004',), ('868201803000700',), ('868201803000704',), ('868201803000702',), ('868201803000696',), ('868201803000701',), ('868201803000697',), ('868201803000699',), ('868201803000689',), ('868201803000682',), ('868201803000695',), ('868201803000688',), ('868201803000681',), ('868201803000703',), ('868201803000674',), ('868201803000651',), ('180078',), ('180025',), ('130558',), ('160080',), ('160090',), ('170071',), ('170087',), ('170099',), ('170135',), ('150153',), ('160073',), ('170083',), ('150037',), ('150249',), ('160168',), ('160002',), ('170080',), ('140157',), ('160225',), ('140161',), ('140588',), ('160804',), ('140170',), ('160068',), ('16411',), ('160527',), ('180070',), ('180026',), ('180034',), ('180004',), ('1003',), ('130653',), ('160170',), ('180753',), ('180795',), ('180698',), ('180675',), ('20191001',), ('20191002',), ('140680',), ('170058',), ('170159',), ('160059',), ('170095',), ('150092',), ('20200221',), ('20200224',), ('20200226',), ('130739',), ('160169',), ('150641',), ('160829',), ('20200301',), ('2020030111',), ('202003011112',), ('170151',), ('150350',), ('180007',), ('110615',), ('160250',), ('170107',), ('150039',), ('170153',), ('110926',), ('170136',), ('160097',), ('160423',), ('160329',), ('170069',), ('170152',), ('140738',), ('110301',), ('170092',), ('160098',), ('150090',), ('180748',))

失败的结果

pymysql.err.OperationalError: (2003, "Can't connect to MySQL server on 'xx.xx.xx.xx' (timed out)")

socket.timeout: timed out

连接池代码

#

标签:__,self,mysql,single,instance,xx,线程,单例,time

来源: https://www.cnblogs.com/meloncodezhang/p/12567738.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
单例模式是一种常用的设计模式,它可以保证一个类只有一个实例,并提供一个全局访问点。在封装mysql数据库连接类dbconn时,可以使用单例模式来确保只有一个数据库连接实例存在,避免多次连接数据库造成资源浪费和能下降的问题。 具体实现可以在dbconn类中定义一个静态成员变量instance,用于保存唯一的数据库连接实例。在构造函数中,可以通过调用mysql_real_connect函数来建立数据库连接,并将连接句柄保存在成员变量中。在析构函数中,可以调用mysql_close函数来关闭数据库连接。 为了保证线程安全,可以使用双重检查锁定机制来实现单例模式。即在getInstance函数中,先检查instance是否为空,如果为空,则加锁创建一个新的实例,否则直接返回已有的实例。 下面是一个简单的示例代码: ``` class dbconn { private: static dbconn* instance; MYSQL* conn; dbconn() { conn = mysql_real_connect(...); // 建立数据库连接 } ~dbconn() { mysql_close(conn); // 关闭数据库连接 } public: static dbconn* getInstance() { if (instance == nullptr) { std::lock_guard<std::mutex> lock(mutex); if (instance == nullptr) { instance = new dbconn(); } } return instance; } }; dbconn* dbconn::instance = nullptr; ``` 使用时可以通过dbconn::getInstance()来获取数据库连接实例,然后调用相应的mysql函数来执行数据库操作。例如: ``` dbconn* conn = dbconn::getInstance(); mysql_query(conn->conn, "SELECT * FROM table"); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值