Oracle에서는 "alter system set pga_aggregate_target=numeric value..." 명령을 사용하여 pga의 크기를 수정할 수 있습니다. pga는 "Program Global Area"의 약어로, 서비스 프로세스를 포함하는 프로그램 캐시 영역입니다. 데이터 및 제어 정보 영역.
이 튜토리얼의 운영 환경: Windows 10 시스템, Oracle 버전 12c, Dell G3 컴퓨터.
pga 크기를 수정하는 구문은
alter system set pga_aggregate_target=数值...
예제는 다음과 같습니다
ORACLE에서 PGA(Program Global Area, Program Cache Area라고도 함)는 다음과 같은 블록입니다. 서비스 프로세스 데이터와 제어 정보 메모리 영역을 포함합니다. 구체적인 기능은 다음과 같습니다.
PGA는 고정 PGA와 가변 PGA(PGA 힙 또는 PGA 스택이라고도 함)로 구성됩니다. 고정 PGA 용량은 크기가 고정되어 있으며 다수의 원자 변수, 작은 데이터 구조 및 변수 PGA에 대한 포인터를 포함합니다.
PGA는 서비스 프로세스가 시작되고 공유되지 않을 때 Oracle에 의해 생성됩니다.
오라클 프로세스는 PGA를 소유합니다. PGA는 이를 소유한 서비스 프로세스에서만 액세스할 수 있으며, 이 프로세스의 Oracle 코드만 읽고 쓸 수 있습니다.
PGA에는 프로세스에서 사용하는 운영 체제 리소스에 대한 정보와 프로세스 상태에 대한 일부 정보가 포함되어 있습니다. 프로세스에서 사용하는 Oracle 공유 리소스에 대한 정보는 SGA(System Global Area)에 있습니다. 이렇게 하면 프로세스가 종료될 때 이러한 리소스가 적시에 해제되고 지워질 수 있습니다.
PGA는 SGA와 유사합니다. Oracle 데이터베이스 시스템이 세션을 위해 서버 메모리에 할당하는 영역입니다.
둘의 기능과 공유 수준도 다릅니다. SGA는 시스템의 모든 프로세스에서 공유됩니다. 여러 사용자가 동시에 루틴에 연결되면 모든 사용자 프로세스와 서비스 프로세스가 이 SGA 영역을 공유할 수 있습니다. SGA의 주요 목적은 프로세스 간 통신과 서로 다른 사용자 간의 서비스 프로세스를 위한 플랫폼을 제공하는 것입니다.
지식 확장
PGA와 SGA의 차이점
PGA(프로그램 캐시 영역)는 SGA(시스템 전역 영역)와 유사합니다. 세션을 위해 서버 메모리에서 Oracle 데이터베이스 시스템에 할당된 영역입니다. 그러나 둘의 기능이 다르고 공유하는 정도도 다릅니다.
SGA 시스템 전역 영역은 이름에서 알 수 있듯이 시스템의 모든 프로세스에서 공유됩니다. 여러 사용자가 동시에 루틴에 연결되면 모든 사용자 프로세스와 서비스 프로세스가 이 SGA 영역을 공유하고 사용할 수 있습니다. 이러한 이유로, 이 SGA의 주요 목적은 서로 다른 사용자 간의 프로세스 및 서비스 프로세스에 대한 통신 플랫폼을 제공하는 것입니다. 이 기능 외에도 또 다른 중요한 기능은 다양한 데이터베이스의 운영이 주로 이 SGA 영역에서 완료된다는 것입니다.
PGA 프로그램 버퍼는 주로 특정 사용자 프로세스를 제공하는 데 사용됩니다. 이 메모리 영역은 공유되지 않으며 사용자의 서비스 프로세스 자체만이 자신의 PGA 영역에 접근할 수 있다. 생생한 비유를 하자면, SGA는 운영 체제의 공유 폴더와 같습니다. 다양한 사용자가 이를 데이터 교환 플랫폼으로 사용할 수 있습니다. PGA는 운영 체제의 개인 폴더와 같습니다. 이 폴더의 소유자만 액세스할 수 있으며 다른 사용자는 액세스할 수 없습니다. 프로그램 캐시 영역은 다른 사용자의 프로세스에 공개되지 않지만 이 메모리 영역은 여전히 이 메모리 영역과 분리될 수 없는 데이터 정렬, 권한 제어 등과 같은 몇 가지 중요한 임무를 수행합니다.
추천 튜토리얼: "Oracle Video Tutorial"
위 내용은 오라클에서 PGA를 수정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!