데이터 베이스 MySQL 튜토리얼 mysql数据库连接过多的错误_MySQL

mysql数据库连接过多的错误_MySQL

Jun 01, 2016 pm 01:54 PM
이동하다 데이터베이스 연결 데이터베이스에 연결

统不能连接数据库,关键要看两个数据:
1、数据库系统允许的最大可连接数max_connections。这个参数是可以设置的。如果不设置,默认是100。最大是16384。
2、数据库当前的连接线程数threads_connected。这是动态变化的。


查看max_connections、max_connections的办法见后。

如果 threads_connected == max_connections 时,数据库系统就不能提供更多的连接数了,这时,如果程序还想新建连接线程,数据库系统就会拒绝,如果程序没做太多的错误处理,就会出现类似强坛的报错信息。

因为创建和销毁数据库的连接,都会消耗系统的资源。而且为了避免在同一时间同时打开过多的连接线程,现在编程一般都使用所谓数据库连接池技术。

但数据库连接池技术,并不能避免程序错误导致连接资源消耗殆尽。

这种情况通常发生在程序未能及时释放数据库连接资源或其他原因造成数据库连接资源不能释放,但强坛系统估计不会发生这种低级的编程错误。
该错误的简便的检查办法是,在刷新强坛页面时,不断监视threads_connected的变化。如果max_connections足够大,而 threads_connected值不断增加以至达到max_connections,那么,就应该检查程序了。当然,如果采用数据库连接池技术, threads_connected增长到数据库连接池的最大连接线程数时,就不再增长了。

从强坛出错的情况看,更大的可能性是数据库系统没能进行适当地配置。下面提出一点建议。供参考

让你们的工程师把MySQL的最大允许连接数从默认的100调成32000。这就不会老出现连接过多的问题了。


查看max_connections

进入MySQL,用命令:show variables
查看数据库最大可连接数的变量值:max_connections

查看threads_connected

进入MySQL,用命令:show status
查看当前活动的连接线程变量值:threads_connected


设置max_connections

设置办法是在my.cnf文件中,添加下面的最后红色的一行:

--------------------------------------------------------------------------------

[mysqld]
port=3306
#socket=MySQL
skip-locking
set-variable = key_buffer=16K
set-variable = max_allowed_packet=1M
set-variable = thread_stack=64K
set-variable = table_cache=4
set-variable = sort_buffer=64K
set-variable = net_buffer_length=2K
set-variable = max_connections=32000


--------------------------------------------------------------------------------

修改完毕后,重启MySQL即可。当然,为了确保设置正确,应该查看一下max_connections。

注意:
1、虽然这里写的32000。但实际MySQL服务器允许的最大连接数16384;
2、除max_connections外,上述其他配置应该根据你们系统自身需要进行配置,不必拘泥;
3、添加了最大允许连接数,对系统消耗增加不大。
4、如果你的mysql用的是my.ini作配置文件,设置类似,但设置的格式要稍作变通

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

FastAPI에서 데이터베이스 연결 및 트랜잭션 처리를 구현하는 방법 FastAPI에서 데이터베이스 연결 및 트랜잭션 처리를 구현하는 방법 Jul 30, 2023 am 11:45 AM

FastAPI에서 데이터베이스 연결 및 트랜잭션 처리를 구현하는 방법 소개: 웹 애플리케이션의 급속한 발전으로 데이터베이스 연결 및 트랜잭션 처리가 매우 중요한 주제가 되었습니다. FastAPI는 속도와 사용 편의성으로 인해 개발자들에게 사랑받는 고성능 Python 웹 프레임워크입니다. 이 기사에서는 안정적이고 효율적인 웹 애플리케이션을 구축하는 데 도움이 되도록 FastAPI에서 데이터베이스 연결 및 트랜잭션을 구현하는 방법을 소개합니다. 1부: FastA의 데이터베이스 연결

PHP 데이터베이스 연결을 사용하여 페이징 쿼리를 구현하는 방법 PHP 데이터베이스 연결을 사용하여 페이징 쿼리를 구현하는 방법 Sep 08, 2023 pm 02:28 PM

PHP 데이터베이스 연결을 사용하여 페이징 쿼리를 구현하는 방법 웹 애플리케이션을 개발할 때 데이터베이스를 쿼리하고 페이징 표시를 수행해야 하는 경우가 많습니다. 일반적으로 사용되는 서버측 스크립팅 언어인 PHP는 강력한 데이터베이스 연결 기능을 갖추고 있으며 페이징 쿼리를 쉽게 구현할 수 있습니다. 이 기사에서는 PHP 데이터베이스 연결을 사용하여 페이징 쿼리를 구현하는 방법을 자세히 소개하고 해당 코드 예제를 첨부합니다. 데이터베이스 준비 시작하기 전에 쿼리할 데이터가 포함된 데이터베이스를 준비해야 합니다. 여기서는 MySQL 데이터베이스를 예로 들어 보겠습니다.

4050 그래픽 카드에 적합한 게임은 무엇입니까? 4050 그래픽 카드에 적합한 게임은 무엇입니까? Jan 06, 2024 pm 05:01 PM

엔비디아의 게이밍 그래픽 카드는 어떤 게임을 할 수 있는지가 가장 중요하기 때문에 4050 그래픽 카드를 사고 싶은 친구들은 당연히 이 그래픽 카드가 어떤 게임을 할 수 있을지 궁금해합니다. 사실 모든 게임을 할 수 있어야죠. . 4050 그래픽 카드는 어떤 게임을 구동할 수 있습니까? 답변: 4050 그래픽 카드는 시중에서 판매되는 모든 컴퓨터 게임을 구동할 수 있어야 합니다. 성능은 적어도 현재 3060ti와 비슷하며, 3060ti는 현재 모든 PC 게임을 구동할 수 있습니다. (아래 3060ti 테스트를 통해 4050의 성능을 예측하겠습니다.) 1. 게임 테스트로 보면 3060ti는 1080p 해상도에서 150fps 이상을 안정적으로 유지할 수 있습니다. 2. 따라서 2k 해상도에서 직접 성능을 테스트해보겠습니다.

C#의 일반적인 데이터베이스 연결 및 데이터 읽기 및 쓰기 문제 C#의 일반적인 데이터베이스 연결 및 데이터 읽기 및 쓰기 문제 Oct 10, 2023 pm 07:24 PM

C#의 일반적인 데이터베이스 연결 및 데이터 읽기 및 쓰기 문제에는 특정 코드 예제가 필요합니다. C# 개발에서는 데이터베이스 연결 및 데이터 읽기 및 쓰기 문제가 자주 발생합니다. 이러한 문제를 올바르게 처리하는 것이 코드 품질과 성능을 보장하는 열쇠입니다. 이 기사에서는 몇 가지 일반적인 데이터베이스 연결과 데이터 읽기 및 쓰기 문제를 소개하고 독자가 이러한 문제를 더 잘 이해하고 해결하는 데 도움이 되는 특정 코드 예제를 제공합니다. 데이터베이스 연결 문제 1.1 연결 문자열 오류 데이터베이스에 연결할 때 발생하는 일반적인 오류는 연결 문자열이 올바르지 않다는 것입니다. 연결 문자열에는 데이터베이스에 대한 연결이 포함됩니다.

PHP 데이터베이스 연결이 실패하는 이유는 무엇입니까? PHP 데이터베이스 연결이 실패하는 이유는 무엇입니까? Jun 05, 2024 pm 07:55 PM

PHP 데이터베이스 연결이 실패하는 이유는 데이터베이스 서버가 실행되지 않음, 잘못된 호스트 이름 또는 포트, 잘못된 데이터베이스 자격 증명 또는 적절한 권한 부족 등입니다. 해결 방법에는 서버 시작, 호스트 이름 및 포트 확인, 자격 ​​증명 확인, 권한 수정, 방화벽 설정 조정이 포함됩니다.

고급 PHP 데이터베이스 연결: 트랜잭션, 잠금 및 동시성 제어 고급 PHP 데이터베이스 연결: 트랜잭션, 잠금 및 동시성 제어 Jun 01, 2024 am 11:43 AM

고급 PHP 데이터베이스 연결에는 데이터 무결성을 보장하고 오류를 방지하기 위한 트랜잭션, 잠금 및 동시성 제어가 포함됩니다. 트랜잭션은 startTransaction(), commit() 및 Rollback() 메서드를 통해 관리되는 작업 집합의 원자 단위입니다. 잠금은 PDO::LOCK_SHARED 및 PDO::LOCK_EXCLUSIVE를 통한 데이터에 대한 동시 액세스를 방지합니다. 동시성 제어는 MySQL 격리 수준(커밋되지 않은 읽기, 커밋된 읽기, 반복 가능한 읽기, 직렬화)을 통해 여러 트랜잭션에 대한 액세스를 조정합니다. 실제 애플리케이션에서는 데이터 무결성을 보장하고 재고 문제를 방지하기 위해 쇼핑 웹사이트의 제품 재고 관리에 트랜잭션, 잠금 및 동시성 제어가 사용됩니다.

mybatis에서 데이터베이스 연결을 구성하는 방법 mybatis에서 데이터베이스 연결을 구성하는 방법 Jan 15, 2024 pm 02:12 PM

Mybatis 구성 데이터베이스 연결 방법: 1. 데이터 소스를 지정합니다. 2. 트랜잭션 관리자를 구성합니다. 3. 유형 프로세서 및 매퍼를 구성합니다. 5. 별칭을 구성합니다. 자세한 소개: 1. "mybatis-config.xml" 파일에서 데이터 소스를 구성해야 합니다. 데이터 소스는 데이터베이스 연결을 제공하는 인터페이스입니다. 데이터베이스 트랜잭션의 정상성을 처리하려면 트랜잭션 관리자도 구성해야 합니다. 3. 유형 프로세서 및 매퍼 등을 구성합니다.

데이터베이스 연결 및 운영, SQL 쿼리 처리 방법 데이터베이스 연결 및 운영, SQL 쿼리 처리 방법 Aug 02, 2023 am 09:06 AM

데이터베이스를 연결하고 운영하는 방법과 SQL 쿼리를 처리하는 방법은 애플리케이션을 개발하는 과정에서 데이터베이스 연결과 운영이 매우 중요한 부분입니다. 데이터베이스는 데이터를 저장하고 관리하는 중요한 도구이며, SQL(StructuredQueryLanguage)은 데이터베이스를 쿼리하고 운영하기 위한 표준 언어입니다. 이 기사에서는 데이터베이스를 연결하고 운영하는 방법을 배우고 SQL 쿼리를 처리하기 위한 몇 가지 코드 예제를 보여줍니다. 데이터베이스에 연결: 먼저 진행하려면 데이터베이스에 연결해야 합니다.

See all articles