search
HomeDatabaseMysql TutorialMySQL server has gone away两种有效的解决办法_MySQL

bitsCN.com

第一种方法, 当然是增加你的 wait-timeout值,这个参数是在my.cnf(在Windows下台下面是my.ini)中设置,我的数据库负荷稍微大一点,所以,我设置的值 为10,(这个值的单位是秒,意思是当一个数据库连接在10秒钟内没有任何操作的话,就会强行关闭,我使用的不是永久链接 (mysql_pconnect),用的是mysql_connect,关于这个wait-timeout的效果你可以在MySQL的进程列表中看到 (show processlist) ),你可以把这个wait-timeout设置成更大,比如300秒,呵呵,一般来讲300秒足够用了,其实你也可以不用设置,MySQL默认是8个小 时。情况由你的服务器和站点来定。
第二种方法:
这也是我个人认为最好的方法,即检查MySQL的链接状态,使其重新链接。
可 能大家都知道有mysql_ping这么一个函数,在很多资料中都说这个mysql_ping的API会检查数据库是否链接,如果是断开的话会尝试重新连 接,但在我的测试过程中发现事实并不是这样子的,是有条件的,必须要通过mysql_options这个C API传递相关参数,让MYSQL有断开自动链接的选项(MySQL默认为不自动连接),但我测试中发现PHP的MySQL的API中并不带这个函数,你 重新编辑MySQL吧,呵呵。但mysql_ping这个函数还是终于能用得上的,只是要在其中有一个小小的操作技巧:
这是我的的数据库操作类中间的一个函数
function ping(){
if(!mysql_ping($this->link)){
mysql_close($this->link); //注意:一定要先执行数据库关闭,这是关键
$this->connect($this->t_dbhost,$this->t_dbuser,$this->t_dbpw,$this->t_dbname,$this->t_pconnect);
}
}
我需要调用这个函数的代码可能是这样子的
for($i=0;$i $str=file_get_contents(’http://www.aol.com’);
}
$db->ping(); //经过前面的网页抓取后,或者会导致数据库连接关闭,检查并重新连接
$db->query(’select * from table’);
ping()这个函数先检测数据连接是否正常,如果被关闭,整个把当前脚本的MYSQL实例关闭,再重新连接。
经过这样处理后,可以非常有效的解决MySQL server has gone away这样的问题,而且不会对系统造成额外的开销。

作者“网站建设技术交流”

bitsCN.com
Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
如何在FastAPI中实现数据库连接和事务处理如何在FastAPI中实现数据库连接和事务处理Jul 30, 2023 am 11:45 AM

如何在FastAPI中实现数据库连接和事务处理引言:随着Web应用程序的快速发展,数据库连接和事务处理成为了一个非常重要的主题。FastAPI是一个高性能的PythonWeb框架,因其快速和易于使用而受到开发者的喜爱。在本文中,我们将介绍如何在FastAPI中实现数据库连接和事务处理,以帮助您构建可靠和高效的Web应用程序。第一部分:数据库连接在FastA

PHP报错:无法连接数据库的解决方法PHP报错:无法连接数据库的解决方法Jul 12, 2023 pm 06:07 PM

PHP报错:无法连接数据库的解决方法在使用PHP开发过程中,经常会遇到无法连接数据库的问题。这是非常常见的错误,但是却给开发人员带来不小的困扰。本文将介绍一些常见的解决方法,并提供相应的代码示例,帮助开发人员快速解决该问题。检查数据库连接信息首先,应该检查数据库连接信息是否正确。通常,数据库连接信息包括主机名、用户名、密码和数据库名。正确无误的数据库连接信息

如何连接和操作数据库以及处理SQL查询如何连接和操作数据库以及处理SQL查询Aug 02, 2023 am 09:06 AM

如何连接和操作数据库以及处理SQL查询在开发应用程序的过程中,数据库连接和操作是非常重要的一部分。数据库是存储和管理数据的重要工具,而SQL(StructuredQueryLanguage)是用于查询和操作数据库的标准语言。在本文中,我们将学习如何连接和操作数据库,并展示一些处理SQL查询的代码示例。连接数据库:首先,我们需要连接到数据库才能进行

如何使用PDO连接到Microsoft Access数据库如何使用PDO连接到Microsoft Access数据库Jul 29, 2023 pm 10:17 PM

如何使用PDO连接到MicrosoftAccess数据库MicrosoftAccess是一款常用的关系数据库管理系统,它提供了用户友好的图形化界面和强大的数据管理功能。对于许多开发人员而言,使用PHP来连接到MicrosoftAccess数据库是个挑战。然而,通过使用PHP的PDO(PHPDataObject)扩展,连接到Access数据库变得相

如何优化PHP的数据库连接和查询性能?如何优化PHP的数据库连接和查询性能?Jun 29, 2023 am 10:25 AM

如何优化PHP的数据库连接和查询性能?数据库是Web开发中不可或缺的一部分,而PHP作为一种广泛使用的服务器端脚本语言,其与数据库的连接和查询性能对于整个系统的性能至关重要。本文将介绍一些优化PHP数据库连接和查询性能的技巧和建议。使用持久化连接:在PHP中,每次执行数据库查询时都会建立一次数据库连接。而持久化连接可以在多次查询中重用同一个数据库连接,从而减

PHP使用ORM框架连接数据库的方法PHP使用ORM框架连接数据库的方法May 15, 2023 pm 09:51 PM

PHP使用ORM框架连接数据库的方法ORM(Object-RelationalMapping)框架是一种将对象模型和关系型数据库模型进行映射的技术。它可以让开发者使用对象的方式来操作数据库,从而避免了手写SQL语句的繁琐和容易出错的问题。ORM框架在PHP中使用广泛,如Laravel的EloquentORM、Symfony的DoctrineORM等。在

Java代码Web开发问题的解决方案是什么?Java代码Web开发问题的解决方案是什么?Jun 30, 2023 pm 09:58 PM

如何解决Java中遇到的Web开发问题在Java的Web开发过程中,我们常常会遇到一些代码问题,这些问题可能会导致程序无法正常运行,甚至会影响系统的性能和安全性。为了有效地解决这些问题,我们需要深入了解Java的特性和常见的Web开发问题,并学会使用相应的技术和工具来解决它们。一、Java中常见的Web开发问题内存泄漏:在Java的Web开发中,内存泄漏是一

如何使用MySQL进行数据库连接?如何使用MySQL进行数据库连接?Jul 30, 2023 pm 08:54 PM

如何使用MySQL进行数据库连接?MySQL是一种广泛应用的关系型数据库管理系统,它是开源的,具有高性能、可靠性和可扩展性。在开发中,我们经常需要与MySQL数据库进行连接,以进行数据的增删改查等操作。本文将介绍如何使用MySQL进行数据库连接,并提供相应的代码示例。首先,我们需要确保已经安装了MySQL数据库,并且知道要连接的数据库的主机名、端口号、数据库

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.