찾다
백엔드 개발Golang대규모 트랜잭션 실행 시 메모리 소비 감소

대규모 트랜잭션 실행 시 메모리 소비 감소

PHP 편집자 Youzi는 오늘 중요한 기술, 즉 대규모 트랜잭션을 실행할 때 메모리 소비를 줄이는 방법을 소개합니다. 많은 양의 데이터를 처리하거나 복잡한 작업을 수행할 때 메모리 소비는 심각한 문제가 될 수 있습니다. 이 문제를 해결하려면 코드의 효율성과 성능을 향상시키기 위한 몇 가지 최적화 조치를 취해야 합니다. 이 기사에서는 메모리 소비를 줄이고 대규모 트랜잭션을 처리할 때 메모리 리소스를 보다 효율적으로 사용하는 데 도움이 되는 몇 가지 방법과 기술을 자세히 소개합니다.

질문 내용

인터넷의 예제를 따르고 다음 sqlite 매개변수를 사용하여 삽입 쿼리 속도를 향상시켰습니다.

으아악

내 코드는 다음과 같습니다.

으아악

이제 쿼리는 빠르게 실행되지만 RAM을 너무 많이 소모합니다. 데이터는 RAM에 저장되기 때문에 실행이 끝나면 데이터베이스 파일에만 저장됩니다.

데이터를 주기적으로 데이터베이스 파일에 저장하면 실행 시간이 조금 늘어나지만 메모리 소모는 줄어들 수 있다고 생각합니다. "i"가 변경될 때마다 트랜잭션이 시작되고 모든 "j"가 완료되면 트랜잭션이 종료됩니다.

으아악

이제 데이터는 청크 단위로 파일에 기록되어야 하고 램에는 데이터 청크가 하나만 있어야 한다고 생각합니다.

하지만 실행 중에는 데이터가 파일에 저장되지 않고 램이 계속 채워집니다. 즉, 첫 번째 코드 옵션과 두 번째 코드 옵션의 실행에는 차이가 없습니다.

트랜잭션의 "커밋"이 호출되면 데이터를 파일에 저장하고 램을 지워야 한다고 생각합니다. 내가 뭘 잘못하고 있는지 말해주세요.

Solution

PRAGMAcache_size매개변수는 페이지 수입니다(일반적으로 페이지당 4k바이트).

PRAGMA cache_size = 1000000;페이지 캐시에는 최대 4GB의 RAM이 할당됩니다. 페이지 캐시는 필요할 때 최대 크기까지 할당되지만 연결이 닫힐 때까지 해제되지 않습니다.

많은 수의 행을 삽입하므로 결국 다른 페이지에 있게 되므로 캐시가 채워질 때까지 디스크에 기록된 모든 페이지를 캐시에 보관하게 됩니다.

메모리 소비를 줄이려면 값을 1000(4MB에 해당)으로 줄이거나 간단히 삭제하세요. 기본 캐시는 2MB이며 행만 삽입하는 경우에는 충분합니다.

또한 COMMIT를 호출할 때(또는 캐시가 충분하지 않은 경우 커밋하기 전에) 데이터가 디스크에 기록된다는 점에 유의하세요. 그러나 Sqlite는 나중에 디스크에서 다시 읽는 것을 방지하기 위해 필요할 경우를 대비하여 캐시에 복사본을 보관합니다.

위 내용은 대규모 트랜잭션 실행 시 메모리 소비 감소의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 stackoverflow에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Go Language Pack 가져 오기 : 밑줄과 밑줄이없는 밑줄의 차이점은 무엇입니까?Go Language Pack 가져 오기 : 밑줄과 밑줄이없는 밑줄의 차이점은 무엇입니까?Mar 03, 2025 pm 05:17 PM

이 기사에서는 GO의 패키지 가져 오기 메커니즘을 설명합니다. 명명 된 수입 (예 : 가져 오기 & quot; fmt & quot;) 및 빈 가져 오기 (예 : import _ & quot; fmt & quot;). 명명 된 가져 오기는 패키지 내용을 액세스 할 수있게하고 빈 수입은 t 만 실행합니다.

MySQL 쿼리 결과 목록을 GO 언어로 사용자 정의 구조 슬라이스로 변환하는 방법은 무엇입니까?MySQL 쿼리 결과 목록을 GO 언어로 사용자 정의 구조 슬라이스로 변환하는 방법은 무엇입니까?Mar 03, 2025 pm 05:18 PM

이 기사에서는 MySQL 쿼리 결과를 GO 구조 슬라이스로 효율적으로 변환합니다. 수동 구문 분석을 피하고 최적의 성능을 위해 데이터베이스/SQL의 스캔 방법을 사용하는 것을 강조합니다. DB 태그 및 Robus를 사용한 구조물 필드 매핑에 대한 모범 사례

Beego 프레임 워크에서 페이지간에 단기 정보 전송을 구현하는 방법은 무엇입니까?Beego 프레임 워크에서 페이지간에 단기 정보 전송을 구현하는 방법은 무엇입니까?Mar 03, 2025 pm 05:22 PM

이 기사에서는 웹 애플리케이션에서 페이지 간 데이터 전송에 대한 Beego의 NewFlash () 기능을 설명합니다. NewFlash ()를 사용하여 컨트롤러간에 임시 메시지 (성공, 오류, 경고)를 표시하여 세션 메커니즘을 활용하는 데 중점을 둡니다. 한계

GO에서 제네릭에 대한 사용자 정의 유형 제약 조건을 어떻게 정의 할 수 있습니까?GO에서 제네릭에 대한 사용자 정의 유형 제약 조건을 어떻게 정의 할 수 있습니까?Mar 10, 2025 pm 03:20 PM

이 기사에서는 GO의 제네릭에 대한 사용자 정의 유형 제약 조건을 살펴 봅니다. 인터페이스가 일반 함수에 대한 최소 유형 ​​요구 사항을 정의하여 유형 안전 및 코드 재사성을 향상시키는 방법에 대해 자세히 설명합니다. 이 기사는 또한 한계와 모범 사례에 대해 설명합니다

이동 중에 테스트를 위해 모의 개체와 스터브를 작성하려면 어떻게합니까?이동 중에 테스트를 위해 모의 개체와 스터브를 작성하려면 어떻게합니까?Mar 10, 2025 pm 05:38 PM

이 기사는 단위 테스트를 위해 이동 중에 모의와 스터브를 만드는 것을 보여줍니다. 인터페이스 사용을 강조하고 모의 구현의 예를 제공하며 모의 집중 유지 및 어설 션 라이브러리 사용과 같은 모범 사례에 대해 설명합니다. 기사

편리하게 GO 언어로 파일을 작성하는 방법?편리하게 GO 언어로 파일을 작성하는 방법?Mar 03, 2025 pm 05:15 PM

이 기사는 OS.WriteFile (작은 파일에 적합)과 OS.OpenFile 및 Buffered Writes (큰 파일에 최적)를 비교하여 효율적인 파일 쓰기를 자세히 설명합니다. 강력한 오류 처리, 연기 사용 및 특정 오류 확인을 강조합니다.

GO에서 단위 테스트를 어떻게 작성합니까?GO에서 단위 테스트를 어떻게 작성합니까?Mar 21, 2025 pm 06:34 PM

이 기사는 GO에서 단위 테스트 작성, 모범 사례, 조롱 기술 및 효율적인 테스트 관리를위한 도구를 다루는 것에 대해 논의합니다.

추적 도구를 사용하여 GO 응용 프로그램의 실행 흐름을 이해하려면 어떻게해야합니까?추적 도구를 사용하여 GO 응용 프로그램의 실행 흐름을 이해하려면 어떻게해야합니까?Mar 10, 2025 pm 05:36 PM

이 기사는 추적 도구를 사용하여 GO 응용 프로그램 실행 흐름을 분석합니다. 수동 및 자동 계측 기술, Jaeger, Zipkin 및 OpenTelemetry와 같은 도구 비교 및 ​​효과적인 데이터 시각화를 강조합니다.

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

뜨거운 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!