Skip to main content

What is PGA (Program Global Area) in Oracle Database?

  1. PGA
    The Program/ Process Global Area (PGA) is a private memory region that contains the data and control information for a server process. Only a server process can access the PGA. Oracle Database reads and writes information in the PGA on behalf of the server process.
    PGA stands for Process Global Area. This is memory reserved for each process that uses Oracle. It contains the context area. Oracle sets this area's size based on the values of the initialization parameters:
    OPEN_LINKS. The number of database links allowed open per user.
    DB_FILES. The number of database files allowed for the database (up to the value of MAX_DATAFILES).
    LOG_FILES. The maximum number of redo log file groups (up to the value of MAX_LOGFILES).
    The PGA also contains session-related information if MTS is not used.
    In environments where MTS is used, the session information is placed in the SHARED_POOL region of the SGA if the LARGE POOL (in Oracle8,8i and 9i) is not configured.
    This session information consists of the user's private SQL area and other session-specific data. The PGA will always hold the user's stack information. The section of the shared or LARGE POOL allocated for the user is called the UGA, which stands for Users Global Area.
    Another contributor to the memory footprint of each process is the size of the SORT_AREA_SIZE and SORT_AREA_RETAINED_SIZE parameters. When a process executes a sort memory, the size of SORT_AREA_SIZE is allocated to the user. If SORT_AREA_RETAINED_SIZE is also set, then this amount of memory is reduced to that value and allowed to grow to SORT_AREA_SIZE. If the sort requires more space than is specified in SORT_AREA_SIZE, the sort is broken into SORT_AREA_SIZED chunks, which are swapped out to disk as needed.h

Comments

Popular posts from this blog

Hi! I'm Java...

Java is a computer programming language. It enables programmers to write computer instructions using English based commands, instead of having to write in numeric codes. It’s known as a “high-level” language because it can be read and written easily by humans. Like English, Java has a set of rules that determine how the instructions are written. These rules are known as its “syntax”. Once a program has been written, the high-level instructions are translated into numeric codes that computers can understand and execute. Who Created Java? In the early nineties, Java was created by a team led by James Gosling for Sun Microsystems. It was originally designed for use on digital mobile devices, such as cell phones. However, when Java 1.0 was released to the public in 1996, its main focus had shifted to use on the Internet. It provided more interactivity with users by giving developers a way to produce animated webpages . Over the years it has evolved as a successful language for ...

I'm the Server Operating System

Server Operating System A server operating system is software that was especially developed to serve as a platform for running multi-user computer programs, applications that are networked and programs critical to business computing. This type of operating system (OS) often comes bundled with the most common types of applications deployed in the client-server model, a term used to indicate the exchange of information between computers. For example, a hypertext transfer protocol (HTTP) or web server hosts or "holds" the text files, images files and scripts that work together to form a website. When someone connects to the Internet and types in a web address, the server that holds the files of the site delivers or "serves" the requested pages to the client computer or the machine that made the request. Frequently used applications in the client-server model handle operations for sharing files and printers across a network, hosting and serving web pages via the ...

A Hit Count Using Java Servlet's Session Tracking

import java.io.*; import javax.servlet.*; import javax.servlet.http.*; public class SessionTracker extends HttpServlet {         public void doGet(HttpServletRequest req,HttpServletResponse res)         throws ServletException,IOException         {                res.setContentType("text/html");                PrintWriter out=res.getWriter();                HttpSession session=req.getSession(true);                Integer count=(Integer)session.getValue("tracker.count");                if(count==null)       ...