首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python 学习手册
Python Cookbook
Python 基础教程
Python Sites
PyPI - Python Package Index
http://www.simple-is-better.com/
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
maiganne
V2EX  ›  Python

一个 Python 往 mysql 写数据出现的问题,帮忙解决下

  •  
  •   maiganne · 2017-04-28 14:05:53 +08:00 · 1809 次点击
    这是一个创建于 996 天前的主题,其中的信息可能已经有所发展或是发生改变。

    用多线程通过 pymysql 向 mysql 写入数据,报错 “ Packet sequence number wrong",是什么原因呢?

    6 回复  |  直到 2017-04-28 14:34:01 +08:00
    idblife
        1
    idblife   2017-04-28 14:09:59 +08:00
    多线程的策略有问题,google 一下就明白了
    另外这个如果想找大家帮忙,需要贴源代码出来
    rocksolid
        2
    rocksolid   2017-04-28 14:10:34 +08:00
    升级 pymysql
    cmlz
        3
    cmlz   2017-04-28 14:13:34 +08:00
    换个 pymysql 版本试试?
    maiganne
        4
    maiganne   2017-04-28 14:21:58 +08:00
    @idblife 我发现每启动一个线程,就要进行一次与数据库的连接,conn=pymysql.connect(**database),这样就不会报错,而所有线程共用一个连接对象 conn 就会出错,不知道这是什么原因
    daybyday
        5
    daybyday   2017-04-28 14:29:43 +08:00
    几种解决方案:
    1. 每个线程拥有自己的连接
    2. 所有线程共用一个连接,加锁互斥使用此连接
    3. 所有线程共用一个连接池,需要考虑线程总数和连接池连接数上限的问题
    maiganne
        6
    maiganne   2017-04-28 14:34:01 +08:00
    @daybyday 感谢答复
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   4135 人在线   最高记录 5168   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 31ms · UTC 05:48 · PVG 13:48 · LAX 21:48 · JFK 00:48
    ♥ Do have faith in what you're doing.