찾다
데이터 베이스MySQL 튜토리얼MySQL 서버 연결 프로세스 분석

Mysqld는 MySQL 서버의 주요 프로세스입니다. mysqld는 MySQL의 진정한 핵심이라고 할 수 있으며, 모든 작업은 mysqld 프로세스를 중심으로 이루어집니다. 따라서 거대한 mysql을 분석해 보면 mysqld의 코드가 가장 획기적인 것입니다.

모든 것은 친숙한 main() 함수에서 시작됩니다. 실제로는 mysqld_main() 함수에서 시작됩니다. 이 코드는 모두 mysqld.cc에 있습니다. mysqld_main()은 win_main)()을 호출한다. win_main() 함수는 주로 일부 초기화 작업을 수행합니다.

초기화 작업이 완료되면 MySQL은 연결을 수락할 준비가 됩니다. 그러면 우리의 주인공인 Handle_connections_methods() 함수가 나타납니다. 이 함수의 주요 작업은 TCP/IP, 명명된 파이프 및 공유 메모리의 세 가지 방식으로 연결을 허용하는 세 가지 새로운 하위 프로세스를 만드는 것입니다. 일반적인 상황에서 고객은 가장 유연한 통신 방법인 TCP/IP(소켓)을 사용하여 MySQL 서버에 연결합니다. 그러나 임베디드 소프트웨어의 응용 환경에서는 후자의 두 가지 통신 방법을 사용해야 합니다.

  • 간소화된 handler_connections_methods() 함수:

static void handle_connections_methods()
{
  mysql_mutex_lock(&LOCK_thread_count);
  mysql_cond_init(key_COND_handler_count, &COND_handler_count, NULL);
  handler_count=0;
  handler_count++;
  mysql_thread_create(key_thread_handle_con_namedpipes, &hThread, &connection_attrib, handle_connections_namedpipes, 0));
  handler_count++;
  mysql_thread_create(key_thread_handle_con_sockets, &hThread, &connection_attrib, handle_connections_sockets_thread, 0));
  handler_count++;
  mysql_thread_create(key_thread_handle_con_sharedmem, &hThread, &connection_attrib, handle_connections_shared_memory, 0))
  while (handler_count > 0)
    mysql_cond_wait(&COND_handler_count, &LOCK_thread_count);
  mysql_mutex_unlock(&LOCK_thread_count);
}

3개의 새 스레드를 생성한 후, handler_connectins_methods() 함수는 긴 루프에 들어가지 않습니다. 세 개의 연결 스레드가 모두 종료될 때까지 종료합니다. 여기서는 주로 소켓 연결 스레드를 살펴봅니다. 우리의 연구 개체는 이 handler_connections_sockets_thread입니다. 이 스레드는 자체적으로 초기화된 후 직접 handler_connections_sockets()를 호출합니다.

handle_connections_sockets() 함수는 select()를 사용하여 mysqld의 수신 포트를 호출한 다음 클라이언트 연결을 기다립니다. 클라이언트가 연결되면 이 함수에 THD 유형 변수가 생성됩니다. 이 변수는 연결 설정부터 시작하여 SQL 구문 분석, 쿼리 실행, 결과 반환 등에 이르는 "소셜 나비"입니다. 이 변수는 항상 존재하며, 한마디로 매우 중요한 변수입니다.

명령 전송 스테이션인 struct st_vio 구조도 있습니다. vio 유형 구조는 "Social Butterfly" THD에도 정의되어 있습니다. 이 구조의 기능은 스토리지 소켓에서 통신 내용을 읽은 다음 해당 값을 THD의 vio 변수에 할당하는 것입니다. VIO 유형은 요청 내용, 시간, 요청 소켓 주소 등을 포함하여 요청을 자세히 설명합니다. 다음에 일어나는 일은 이 "소셜 나비"를 서비스 스레드에 전달하는 것이며, create_thread_to_handle_connection()은 이 함수를 구현합니다.

  • 다음은 삭제된 코드입니다

void create_thread_to_handle_connection(THD *thd)
{
  if (cached_thread_count > wake_thread)
  {
    mysql_cond_signal(&COND_thread_cache);
  }
  else
  {
    mysql_thread_create(key_thread_one_connection, &thd->real_id, &connection_attrib, handle_one_connection, (void*) thd)));    
  }
}

유휴 캐시 스레드가 있는지 확인하는 함수입니다(MySQL에서는 후속 서비스 스레드의 연결을 끊지 않습니다). 즉시 삭제되고 대신 캐시됩니다. 캐시 스레드가 있으면 캐시 스레드를 사용하고, 그렇지 않은 경우 새 스레드를 생성하여 연결을 제공합니다. 이 시점에서 연결이 서비스 스레드에 진입했으며 연결 스레드가 반환되어 계속해서 연결을 기다립니다.

다음 내용은 모두 서비스 스레드에 구현되어 있습니다. 관심 있는 학생은 "MySQL 심층 이해"에 매우 자세한 코드 추적이 있습니다. 참조용으로 함수 호출 시퀀스를 첨부했습니다.

handle_one_connection()
mysql_thread_create()
handle_one_connection()
do_handle_one_connection()
init_new_connection_thread()
init_new_connection_handler_thread()
do_command()
dispatch_command()
mysql_parse()
mysql_execuate_command()

이상은 MySQL 서버 접속 과정에 대한 분석입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
图文详解mysql架构原理图文详解mysql架构原理May 17, 2022 pm 05:54 PM

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

mysql的msi与zip版本有什么区别mysql的msi与zip版本有什么区别May 16, 2022 pm 04:33 PM

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

mysql怎么去掉第一个字符mysql怎么去掉第一个字符May 19, 2022 am 10:21 AM

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

mysql怎么替换换行符mysql怎么替换换行符Apr 18, 2022 pm 03:14 PM

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

mysql怎么将varchar转换为int类型mysql怎么将varchar转换为int类型May 12, 2022 pm 04:51 PM

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

MySQL复制技术之异步复制和半同步复制MySQL复制技术之异步复制和半同步复制Apr 25, 2022 pm 07:21 PM

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

mysql怎么判断是否是数字类型mysql怎么判断是否是数字类型May 16, 2022 am 10:09 AM

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。

带你把MySQL索引吃透了带你把MySQL索引吃透了Apr 22, 2022 am 11:48 AM

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

See all articles

핫 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를 무료로 생성하십시오.

뜨거운 도구

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구