MySQL连接hang住问题分析
Linux c多线程连接mysql数据库,每次都是短连接,操作完后就释放连接,有时候会出现mysql_real_connect挂住的现象,挂住超时mysql
【问题现象】:
1. Linux c多线程连接mysql数据库,每次都是短连接,操作完后就释放连接,有时候会出现mysql_real_connect挂住的现象
2. 挂住超时mysql_real_connect返回后报错如下:Lostconnection to MySQL server at 'reading initial communication packet', systemerror: 104,返错后线程号没变,会继续往下运行
【初步原因分析】:
1. mysql_real_connect连接数据库, 没有显式调用超时时间,重连什么的,,使用的默认值:
2. 昨天拿c mysqlclient的源码进行了分析测试,发现以下几个配置项的默认值(如果调mysql_real_connect之前没有设置任何属性,mysql client端的机器上/etc/my.cnf也没有配置)如下:
connect_timeout = 0
read_timeout = 0
write_timeout = 0
reconnect = 0 //1表示自动重连
所以这些参数是需要显式设置的。
{net = {vio = 0x7b8f150, options = {connect_timeout = 0, read_timeout = 0, write_timeout = 0,}
3. Mysqlclient中报错的代码如下(与服务端连接建立后,读解析包的时候失败了):
/*
Part 1: Connection established, read and parse first packet
*/
if ((pkt_length=cli_safe_read(mysql)) == packet_error)
{
if (mysql->net.last_errno == CR_SERVER_LOST)
set_mysql_extended_error(mysql, CR_SERVER_LOST, unknown_sqlstate,
ER(CR_SERVER_LOST_EXTENDED),
"reading initial communication packet",
errno);
fprintf(myfp,"%s after cli_safe_read packet_error \n",cur_time());
goto error;
}
线程阻塞时抓到的堆栈如下:
#0 0x0000003ebe0c5f3b in read () from /lib64/libc.so.6
#1 0x00007f240dd91430 in vio_read () from /usr/lib/libmysql.so.16.0.0
#2 0x00007f240dcf9b05 in my_real_read () from /usr/lib/libmysql.so.16.0.0
#3 0x00007f240dcf9e38 in my_net_read () from /usr/lib/libmysql.so.16.0.0
#4 0x00007f240dcec396 in cli_safe_read () from /usr/lib/libmysql.so.16.0.0
#5 0x00007f240dceea17 in mysql_real_connect () from /usr/lib/libmysql.so.16.0.0

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











이 장에서 가져온 기사는 NavicatforMySQL 소프트웨어에 관한 것입니다. NavicatforMySQL이 로컬 MySQL 데이터베이스에 연결하는 방법을 알고 있습니까? 그런 다음 편집기는 관심 있는 사용자가 아래에서 읽을 수 있는 NavicatforMySQL 방법을 제공합니다. 구경하다. Navicatformysql이 설치된 컴퓨터를 열고 오른쪽 상단에 있는 "연결" 옵션을 클릭하면 팝업되는 새 연결 창에서 연결 이름을 입력하고 호스트 이름을 로컬 데이터베이스로 설정하면 됩니다. "localhost"를 사용하세요. 비밀번호를 비워두세요. 그러면 편리한 데이터베이스에 연결이 성공하면,

Docker를 사용하여 MySQL을 배포한 후 연결 속도가 느려지는 현상이 발생했습니다. 온라인 검색을 통해 최소 컨테이너 설치 중 DNS 확인 등의 모듈이 부족하여 문제가 발생할 수 있음을 발견했습니다. 따라서 연결 시 연결 속도가 매우 느려지는 문제가 발생합니다. 이 문장을 직접 추가하고 docker-compose.yml 구성을 직접 수정합니다. 버전은 "3" services:mysql:image 입니다. :mysql:latestcontainer_name:mysql_composerestart: Alwaysports:-3306:3306명령:--default-a

MySQL 연결 수가 데이터베이스 성능에 미치는 영향 분석 인터넷 애플리케이션의 지속적인 개발로 인해 데이터베이스는 애플리케이션 시스템을 지원하는 중요한 데이터 저장 및 관리 도구가 되었습니다. 데이터베이스 시스템에서 연결 수는 데이터베이스 시스템의 성능 및 안정성과 직결되는 중요한 개념이다. 이 기사에서는 MySQL 데이터베이스의 관점에서 시작하여 연결 수가 데이터베이스 성능에 미치는 영향을 살펴보고 특정 코드 예제를 통해 분석합니다. 1. 연결 수는 얼마나 됩니까? 연결 수는 데이터베이스 시스템이 동시에 지원하는 클라이언트 연결 수를 의미하며 관리할 수도 있습니다.

Python 프로그램에서 MySQL 연결의 높은 동시성 성능을 최적화하는 방법은 무엇입니까? 개요: MySQL은 강력한 성능을 지닌 관계형 데이터베이스이지만 동시성이 높은 경우 Python 프로그램의 연결 및 쿼리 작업이 시스템 성능에 영향을 미칠 수 있습니다. 이 기사에서는 Python 프로그램과 MySQL 데이터베이스의 성능을 향상시키는 몇 가지 최적화 기술을 소개합니다. 연결 풀 사용: 동시성이 높은 상황에서 데이터베이스 연결을 자주 만들고 닫으면 많은 시스템 리소스가 소모됩니다. 따라서 연결 풀링을 사용하면 효과적으로

명령줄에서 MySQL 연결의 높은 동시성 성능을 테스트하는 방법은 무엇입니까? 인터넷 애플리케이션이 지속적으로 대중화됨에 따라 데이터베이스의 높은 동시성 성능은 많은 요구 사항 중 하나가 되었습니다. 인기 있는 오픈 소스 데이터베이스인 MySQL은 높은 동시성 성능으로도 폭넓은 주목을 받아왔습니다. MySQL 연결의 높은 동시성 성능을 테스트하기 전에 몇 가지 개념과 준비 사항을 명확히 해야 합니다. 동시 연결: 동시에 데이터베이스와 연결을 설정하는 여러 클라이언트를 말하며 이러한 연결은 동시에 데이터베이스 작업을 수행합니다. 연결 제한: MySQ

MySQL 연결이 비정상적으로 종료된 후 데이터 손실을 처리하는 방법은 무엇입니까? MySQL 데이터베이스를 사용할 때 여러 가지 이유로 인해 데이터베이스 연결이 비정상적으로 종료되는 경우가 있습니다. 이로 인해 현재 작업이 중단될 뿐만 아니라 제출된 데이터가 손실될 수도 있습니다. 이 문제를 해결하기 위해서는 MySQL 연결이 비정상적으로 종료된 후 데이터 손실에 대처하기 위한 몇 가지 조치가 필요합니다. 먼저, MySQL은 트랜잭션을 지원하는 데이터베이스라는 점을 분명히 해야 합니다. 트랜잭션은 모두 제출된 작업 집합입니다.

MySQL 연결이 재설정되었습니다. 어떻게 처리하나요? MySQL은 다양한 규모의 프로젝트에서 널리 사용되는 일반적으로 사용되는 관계형 데이터베이스 관리 시스템입니다. 하지만 MySQL을 사용하다 보면 가끔 연결이 재설정되는 상황이 발생하는데, 이로 인해 프로젝트에 문제가 발생할 수 있습니다. 이 글에서는 MySQL 연결이 재설정되는 이유와 이 문제를 해결하는 방법을 소개합니다. 연결이 재설정되는 현상은 일반적으로 다음과 같은 이유로 발생합니다. 1. 네트워크 문제: MySQL에 연결된 클라이언트와 서버 간의 네트워크 연결이 불안정한 경우,

MySQL 연결이 재설정되었습니다. 연결 유지를 통해 연결 풀의 상태를 확인하는 방법은 무엇입니까? MySQL 데이터베이스를 사용할 때 연결이 재설정되어 데이터베이스 연결이 중단되는 상황이 자주 발생하며 이는 애플리케이션에 매우 불안정합니다. 이 문제를 해결하려면 연결을 활성 상태로 유지하여 연결 풀의 상태를 확인할 수 있습니다. 연결 유지는 연결이 유휴 상태일 때 특정 쿼리 문을 보내 연결을 활성 상태로 유지하고 서버가 연결을 적극적으로 닫는 것을 방지하는 것을 의미합니다. 이 특정 쿼리 문은 간단한 SE가 될 수 있습니다.
