MySQL 프로덕션 데이터베이스의 비정상적인 메모리 증가 문제를 해결하는 방법
performance_schema 수정
회사의 생산 환경은 Alibaba Cloud RDS를 사용하기 때문에 매개변수를 수정하는 것이 비교적 편리합니다. 기본performance_schema는 0인데 이번에는 1로 수정합니다. 매개변수를 수정하고 제출한 후에는 업무량이 적을 때 데이터베이스를 다시 시작하는 것이 좋습니다.
메모리 모니터링 켜기
MySQL 데이터베이스에 로그인하고 다음 SQL을 실행한 후 메모리 모니터링을 켜세요.
update performance_schema.setup_instruments set enabled = 'yes' where name like 'memory%';
개봉 후 확인하세요.
select * from performance_schema.setup_instruments where name like 'memory%innodb%' limit 5;
**참고: **이 명령은 온라인으로 메모리 통계를 열기 위한 것이므로 열기 전 새로 추가된 메모리 개체만 계산됩니다. 일정 시간 동안 기다리는 것이 좋습니다. 다음 단계를 수행하기 전에 메모리 사용량이 많은 스레드를 쉽게 찾을 수 있습니다.
메모리 소비 찾기
통계 이벤트는 메모리를 소비합니다
select event_name, SUM_NUMBER_OF_BYTES_ALLOC from performance_schema.memory_summary_global_by_event_name order by SUM_NUMBER_OF_BYTES_ALLOC desc LIMIT 10; +---------------------------------------+-------------------------------------+ | event_name | SUM_NUMBER_OF_BYTES_ALLOC | +---------------------------------------+-------------------------------------+ | memory/sql/Filesort_buffer::sort_keys | 763523904056 | | memory/memory/HP_PTRS | 118017336096 | | memory/sql/thd::main_mem_root | 114026214600 | | memory/mysys/IO_CACHE | 59723548888 | | memory/sql/QUICK_RANGE_SELECT::alloc | 14381459680 | | memory/sql/test_quick_select | 12859304736 | | memory/innodb/mem0mem | 7607681148 | | memory/sql/String::value | 1405409537 | | memory/sql/TABLE | 1117918354 | | memory/innodb/btr0sea | 984013872 | +---------------------------------------+-------------------------------------+
메모리 소비가 가장 많은 이벤트는 Filesort_buffer라는 것을 알 수 있습니다. 이는 정렬과 관련이 있을 것입니다.
스레드 메모리 소비 통계
select thread_id, event_name, SUM_NUMBER_OF_BYTES_ALLOC from performance_schema.memory_summary_by_thread_by_event_name order by SUM_NUMBER_OF_BYTES_ALLOC desc limit 10; +---------------------+---------------------------------------+-------------------------------------+ | thread_id | event_name | SUM_NUMBER_OF_BYTES_ALLOC | +---------------------+---------------------------------------+-------------------------------------+ | 105 | memory/memory/HP_PTRS | 69680198792 | | 183 | memory/sql/Filesort_buffer::sort_keys | 49210098808 | | 154 | memory/sql/Filesort_buffer::sort_keys | 43304339072 | | 217 | memory/sql/Filesort_buffer::sort_keys | 37752275360 | | 2773 | memory/sql/Filesort_buffer::sort_keys | 31460644712 | | 218 | memory/sql/Filesort_buffer::sort_keys | 31128994280 | | 2331 | memory/sql/Filesort_buffer::sort_keys | 28763981248 | | 106 | memory/memory/HP_PTRS | 27938197584 | | 191 | memory/sql/Filesort_buffer::sort_keys | 27701610224 | | 179 | memory/sql/Filesort_buffer::sort_keys | 25624723968 | +---------------------+---------------------------------------+-------------------------------------+
메모리를 많이 소비하는 스레드가 Filesort_buffer
와 관련이 있는 것을 볼 수 있습니다. Filesort_buffer
相关。
定位具体SQL
根据前边我们查到的thread_id
앞서 찾은
thread_id
를 기반으로 해당 SQL을 찾으려면 로그로 이동하세요. Alibaba Cloud RDS 감사 로그는 비교적 강력합니다. thread_id를 기반으로 직접 검색합니다.
위 내용은 MySQL 프로덕션 데이터베이스의 비정상적인 메모리 증가 문제를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

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

PHP에서 환경 변수를 설정하는 세 가지 주요 방법이 있습니다. 1. php.ini를 통한 글로벌 구성; 2. 웹 서버 (예 : Apache의 Setenv 또는 nginx의 FastCGI_Param)를 통과했습니다. 3. PHP 스크립트에서 putenv () 함수를 사용하십시오. 그 중에서 Php.ini는 전역적이고 드물게 변화하는 구성에 적합하며 웹 서버 구성은 분리 해야하는 시나리오에 적합하며 Putenv ()는 임시 변수에 적합합니다. 영구 정책에는 구성 파일 (예 : php.ini 또는 웹 서버 구성)이 포함되어 있습니다. 보안 관리 민감한 정보는 하드 코딩을 피해야하며 사용하는 것이 좋습니다.

PHP는 프론트 엔드 입력, 데이터베이스 스토리지 및 외부 AI 서비스를 연결하는 데 책임이있는 지능형 고객 서비스에서 커넥터 및 브레인 센터의 역할을 수행합니다. 2.이를 구현할 때는 멀티 레이어 아키텍처를 구축해야합니다. 프론트 엔드는 사용자 메시지, PHP 백엔드 전처리 및 경로 요청을 수신하고 먼저 로컬 지식 기반과 일치하며 놓치고 OpenAI 또는 DialogFlow와 같은 외부 AI 서비스를 호출하여 지능적인 답장을 얻습니다. 3. 세션 관리는 컨텍스트 연속성을 보장하기 위해 PHP에 의해 MySQL 및 기타 데이터베이스에 기록됩니다. 4. 통합 AI 서비스는 guzzle을 사용하여 HTTP 요청을 보내고 Apikeys를 안전하게 저장하며 오류 처리 및 응답 분석을 잘 수행해야합니다. 5. 데이터베이스 디자인에는 세션, 메시지, 지식 기반 및 사용자 테이블이 포함되어야하며, 인덱스를 합리적으로 빌드하고 보안 및 성능을 보장하며 로봇 메모리를 지원해야합니다.

PHP 컨테이너가 자동 구성을 지원할 수 있도록 핵심은 CI (Continuous Integration) 프로세스를 구성하는 데 있습니다. 1. DockerFile을 사용하여 기본 이미지, 확장 설치, 종속성 관리 및 권한 설정을 포함하여 PHP 환경을 정의합니다. 2. Gitlabci와 같은 CI/CD 도구를 구성하고 .gitlab-ci.yml 파일을 통해 빌드, 테스트 및 배포 단계를 정의하여 자동 구성, 테스트 및 배포를 달성합니다. 3. PHPUNIT와 같은 테스트 프레임 워크를 통합하여 코드 변경 후 테스트가 자동으로 실행되도록합니다. 4. Kubernetes와 같은 자동 배포 전략을 사용하여 배포 .yaml 파일을 통해 배포 구성을 정의합니다. 5. Dockerfile 최적화 및 다단계 구조를 채택하십시오

독립적 인 PHP 작업 컨테이너 환경 구축은 Docker를 통해 구현할 수 있습니다. 특정 단계는 다음과 같습니다. 1. Docker 및 DockerCompose를 기초로 설치하십시오. 2. DockerFile 및 Crontab 파일을 저장하기위한 독립 디렉토리를 만듭니다. 3. PHPCLI 환경을 정의하고 CRON 및 필요한 확장을 설치하려면 dockerfile을 작성하십시오. 4. 타이밍 작업을 정의하기 위해 Crontab 파일을 작성하십시오. 5. docker-compose.yml 마운트 스크립트 디렉토리를 작성하고 환경 변수를 구성하십시오. 6. 컨테이너를 시작하고 로그를 확인하십시오. 웹 컨테이너에서 타이밍 작업을 수행하는 것과 비교할 때 독립 컨테이너는 자원 격리, 순수한 환경, 강력한 안정성 및 쉬운 확장의 장점이 있습니다. 로깅 및 오류 캡처를 보장합니다

로깅 방법 선택 : 초기 단계에서는 PHP에 내장 Error_Log ()를 사용할 수 있습니다. 프로젝트가 확장되면 독백과 같은 성숙한 라이브러리로 전환하고 여러 처리기 및 로그 레벨을 지원하며 로그에 타임 스탬프, 레벨, 파일 줄 번호 및 오류 세부 정보가 포함되어 있는지 확인하십시오. 2. 디자인 저장 구조 : 소량의 로그를 파일에 저장할 수 있으며 많은 로그가 있으면 많은 분석이 있으면 데이터베이스를 선택하십시오. MySQL/PostgreSQL을 사용하여 구조화 된 데이터에 사용하십시오. Elasticsearch Kibana는 반 구조화/비 구조화에 권장됩니다. 동시에, 그것은 백업 및 정기적 인 청소 전략을 위해 공식화됩니다. 3. 개발 및 분석 인터페이스 : 검색, 필터링, 집계 및 시각화 기능이 있어야합니다. Kibana에 직접 통합되거나 PHP 프레임 워크 차트 라이브러리를 사용하여 단순성과 인터페이스의 용이성에 중점을 둔 자체 개발을 개발할 수 있습니다.

PHP 환경과 생산 사이의 불일치 문제를 해결하기 위해 핵심은 Kubernetes의 컨테이너화 및 오케스트레이션 기능을 사용하여 환경 일관성을 달성하는 것입니다. 특정 단계는 다음과 같습니다. 1. 모든 PHP 버전, 확장, 종속성 및 웹 서버 구성을 포함하여 통합 된 Docker 이미지를 구축하여 동일한 이미지가 개발 및 생산에 사용되도록합니다. 2. Kubernetes의 구성 및 비밀을 사용하여 비 민감하고 민감한 구성을 관리하고 볼륨 마운트 또는 환경 가변 주입을 통해 다양한 환경 구성의 유연한 스위칭을 달성합니다. 3. Unified Kubernetes 배포 정의 파일 (배포 및 서비스 등)을 통한 응용 프로그램 동작 일관성을 보장하고 버전 제어에 포함시킵니다. 4.

1. PHP 전자 상거래 백엔드의 주류 프레임 워크에는 Laravel (빠른 개발, 강력한 생태학), Symfony (엔터프라이즈 수준, 안정적인 구조), YII (우수한 성능, 표준화 된 모듈에 적합); 2. 기술 스택에는 MySQL Redis 캐시, Rabbitmq/Kafka 메시지 대기열, Nginx PHP-FPM 및 프론트 엔드 분리가 장착되어 있어야합니다. 3. 높은 동시성 아키텍처는 계층화되고 모듈화되어야하며 데이터베이스는 분리/분산 데이터베이스를 읽고 쓰고, 캐시 및 CDN으로 가속화되고, 작업의 비동기 처리,로드 밸런싱 및 세션 공유, 점차 마이크로 서비스 및 모니터링 및 경보 시스템을 설정해야합니다. 4. 다중 수익 창출 경로에는 제품 가격 차이 또는 플랫폼 커미션, 사이트 광고, SAAS 구독, 맞춤형 개발 및 플러그인 시장, API 연결이 포함됩니다.

이 기사는 eloquentorm을 사용하여 고급 조건부 쿼리 및 Laravel 프레임 워크에서 관련 데이터의 필터링을 수행하여 데이터베이스 관계에서 "조건부 연결"을 구현 해야하는 방법을 탐색하는 것을 목표로합니다. 이 기사는 MySQL에서 외국 키의 실제 역할을 명확히하고, 조건을 충족하고 데이터 검색의 정확성을 개선하는 관련 데이터를 유연하게 필터링하기 위해 클로저 기능과 결합 된 방법과 함께 Eloquent 's를 통해 실로 된 연관성 모델에 조항을 적용하는 방법을 자세히 설명합니다.
