190 likes | 349 Views
Managing Oracle Database Processes. By Lecturer / Aisha Dawood. Managing Oracle Database Processes. Dedicated and Shared Server Processes Configuring Oracle Database for Shared Server Oracle Database Background Processes Managing Processes for Parallel SQL Execution
E N D
Managing Oracle Database Processes By Lecturer / Aisha Dawood
Managing Oracle Database Processes • Dedicated and Shared Server Processes • Configuring Oracle Database for Shared Server • Oracle Database Background Processes • Managing Processes for Parallel SQL Execution • Managing Processes for External Procedures • Terminating Sessions • Monitoring the Operation of Your Database
Managing Oracle Database Processes • Oracle Database creates server processes to handle the requests of user processes connected to an instance. A server process can be either of the following: • A dedicated server process, which services only one user process • A shared server process, which can service multiple user processes
Dedicated Server Processes • Figure 4–1, "Oracle Database Dedicated Server Processes" illustrates how dedicated server processes work.
Dedicated Server Processes • In general, it is better to be connected through a dispatcher and use a shared server process. This is illustrated in Figure 4–2, "Oracle Database Shared Server Processes". • A shared server process can be more efficient because it keeps the number of processes required for the running instance low.
Dedicated Server Processes • In the following situations, however, users and administrators should explicitly • connect to an instance using a dedicated server process: • To submit a batch job (for example, when a job can allow little or no idle time for the server process) • To use Recovery Manager (RMAN) to back up, restore, or recover a database
Shared Server Processes • Consider an order entry system with dedicated server processes. A customer phones the order desk and places an order, and the clerk taking the call enters the order into the database. • For most of the transaction, the clerk is on the telephone talking to the customer. A server process is not needed during this time, so the server process dedicated to the clerk's user process remains idle. The system is slower for other clerks entering orders, because the idle server process is holding system resources. • Description for shared server processes in Ch4. • Advantages of Shared server processes: • A significant advantage of shared server architecture over the dedicated server model is the reduction of system resources, enabling the support of an increased number of users. • For even better resource management, shared server can be configured for connection pooling. Connection pooling lets a dispatcher support more users by enabling the database server to time-out protocol connections and to use those connections to service an active session. • Further, shared server can be configured for session multiplexing, which combines multiple sessions for transmission over a single network connection in order to conserve the operating system's resources.
Configuring Oracle Database for Shared Server • Shared memory resources are preconfigured to allow the enabling of shared server at run time. You need not configure it by specifying parameters in your initialization parameter file, but you can do so if that better suits your environment. You can start dispatchers and shared server processes (shared servers) dynamically using the ALTER SYSTEM statement. • This section discusses how to enable shared server and how to set or alter shared server initialization parameters. It contains the following topics: • Initialization Parameters for Shared Server • Enabling Shared Server • Configuring Dispatchers • Monitoring Shared Server
Configuring Oracle Database for Shared Server • Initialization Parameters for Shared Server The following initialization parameters control shared server operation: ■ SHARED_SERVERS: Specifies the initial number of shared servers to start and the minimum number of shared servers to keep. This is the only required parameter for using shared servers. ■ MAX_SHARED_SERVERS: Specifies the maximum number of shared servers that can run simultaneously. ■ SHARED_SERVER_SESSIONS: Specifies the total number of shared server user sessions that can run simultaneously. Setting this parameter enables you to reserve user sessions for dedicated servers. ■ DISPATCHERS: Configures dispatcher processes in the shared server architecture. ■ MAX_DISPATCHERS: Specifies the maximum number of dispatcher processes that can run simultaneously. ■ CIRCUITS: Specifies the total number of virtual circuits that are available for inbound and outbound network sessions.
Configuring Oracle Database for Shared Server • Shared server is enabled by setting the SHARED_SERVERS initialization parameter to a value greater than 0. The other shared server initialization parameters need not be set. • Because shared server requires at least one dispatcher in order to work, a dispatcher is brought up even if no dispatcher has been configured. Dispatchers are discussed in • Shared server can be started dynamically by setting the SHARED_SERVERS parameter to a nonzero value with the ALTER SYSTEM statement, or SHARED_SERVERS can be included at database startup in the initialization parameter file. If SHARED_SERVERS is not included in the initialization parameter file, or is included but is set to 0, then shared server is not enabled at database startup.
Determining a Value for SHARED_SERVERS • The SHARED_SERVERS initialization parameter specifies the minimum number of shared servers that you want created when the instance is started. After instance startup, Oracle Database can dynamically adjust the number of shared servers based on how busy existing shared servers are and the length of the request queue. • In typical systems, the number of shared servers stabilizes at a ratio of one shared server for every ten connections. • For OLTP applications, when the rate of requests is low, or when the ratio of server usage to request is low, the connections-to-servers ratio could be higher. In contrast, in applications where the rate of requests is high or the server usage-to-request ratio is high, the connections-to-server ratio could be lower. • The PMON (process monitor) background process cannot terminate shared servers below the value specified by SHARED_SERVERS. Therefore, you can use this parameter to stabilize the load and minimize strain on the system by preventing PMON from terminating and then restarting shared servers because of coincidental fluctuations in load.
Determining a Value for SHARED_SERVERS • If you know the average load on your system, you can set SHARED_SERVERS to an optimal value. The following example shows how you can use this parameter: • Assume a database is being used by a telemarketing center staffed by 1000 agents. On average, each agent spends 90% of the time talking to customers and only 10% of the time looking up and updating records. To keep the shared servers from being terminated as agents talk to customers and then spawned again as agents access the database, a DBA specifies that the optimal number of shared servers is 100. However, not all work shifts are staffed at the same level. On the night shift, only 200 agents are needed. Since SHARED_SERVERS is a dynamic parameter, a DBA reduces the number of shared servers to 20 at night, thus allowing resources to be freed up for other tasks such as batch jobs.
Decreasing the Number of Shared Server Processes • You can decrease the minimum number of shared servers that must be kept active by dynamically setting the SHARED_SERVERS parameter to a lower value. Thereafter, until the number of shared servers is decreased to the value of the SHARED_SERVERS parameter, any shared servers that become inactive are marked by PMON for termination. • The following statement reduces the number of shared servers: ALTER SYSTEM SET SHARED_SERVERS = 5;
Limiting the Number of Shared Server Processes • The MAX_SHARED_SERVERS parameter specifies the maximum number of shared servers that can be automatically created by PMON. • It has no default value. If no value is specified, then PMON starts as many shared servers as is required by the load, subject to these limitations: • The process limit (set by the PROCESSES initialization parameter) • A minimum number of free process slots • System resources • The value of SHARED_SERVERS overrides the value of MAX_SHARED_SERVERS. Therefore, you can force PMON to start more shared servers than the MAX_SHARED_SERVERS value by setting SHARED_SERVERS to a value higher than MAX_SHARED_SERVERS. You can subsequently place a new upper limit on the number of shared servers by dynamically altering the MAX_SHARED_SERVERS to a value higher than SHARED_SERVERS. • Why to limit the number of shared servers? • The primary reason to limit the number of shared servers is to reserve resources, such as memory and CPU time, for other processes. • For example, consider the case of the telemarketing center discussed previously: The DBA wants to reserve two thirds of the resources for batch jobs at night. He sets MAX_SHARED_SERVERS to less than one third of the maximum number of processes (PROCESSES). By doing so, the DBA ensures that even if all agents happen to access the database at the same time, batch jobs can connect to dedicated servers without having to wait for the shared servers to be brought down after processing agents‘ requests. • Another reason to limit the number of shared servers is to prevent the concurrent run of too many server processes from slowing down the system due to heavy swapping, although PROCESSES can serve as the upper bound for this rather than MAX_SHARED_SERVERS. • Still other reasons to limit the number of shared servers are testing, debugging, performance analysis, and tuning. For example, to see how many shared servers are needed to efficiently support a certain user community, you can vary
Limiting the Number of Shared Server Processes • Limiting the Number of Shared Server Sessions • The SHARED_SERVER_SESSIONS initialization parameter specifies the maximum number of concurrent shared server user sessions. Setting this parameter, which is a dynamic parameter, lets you reserve database sessions for dedicated servers. This in turn ensures that administrative tasks that require dedicated servers, such as backing up or recovering the database, are not preempted by shared server sessions. • This parameter has no default value. If it is not specified, the system can create shared server sessions as needed, limited by the SESSIONS initialization parameter. • Protecting Shared Memory • The CIRCUITS parameter sets a maximum limit on the number of virtual circuits that can be created in shared memory. This parameter has no default. If it is not specified, then the system can create circuits as needed, limited by the DISPATCHERS initialization parameter and system resources.
Configuring Dispatchers • The DISPATCHERS initialization parameter configures dispatcher processes in the shared server architecture. At least one dispatcher process is required for shared server to work. If you do not specify a dispatcher, but you enable shared server by setting SHARED_SERVER to a nonzero value, then by default Oracle Database creates one dispatcher for the TCP protocol. The equivalent DISPATCHERS explicit setting of the initialization parameter for this configuration is: • dispatchers="(PROTOCOL=tcp)" • You can configure more dispatchers, using the DISPATCHERS initialization parameter, if either of the following conditions apply: ■ You need to configure a protocol other than TCP/IP. You configure a protocol • address with one of the following attributes of the DISPATCHERS parameter: • – ADDRESS • – DESCRIPTION • – PROTOCOL ■ You want to configure one or more of the optional dispatcher attributes: • – DISPATCHERS • – CONNECTIONS • – SESSIONS • – TICKS • – LISTENER • – MULTIPLEX • – POOL • – SERVICE
Configuring Dispatchers • DISPATCHERS Initialization Parameter Attributes ( return to chapter 4)
Determining the Number of Dispatchers • Once you know the number of possible connections for each process for the operating system, calculate the initial number of dispatchers to create during instance startup, for each network protocol, using the following formula: • Number of dispatchers = CEIL ( max. concurrent sessions / connections for each dispatcher ) • CEIL returns the result roundest up to the next whole integer. • For example, assume a system that can support 970 connections for each process, and that has: ■ A maximum of 4000 sessions concurrently connected through TCP/IP and ■ A maximum of 2,500 sessions concurrently connected through TCP/IP with SSL • The DISPATCHERS attribute for TCP/IP should be set to a minimum of five dispatchers (4000 / 970), and for TCP/IP with SSL three dispatchers (2500 / 970: • DISPATCHERS='(PROT=tcp)(DISP=5)', '(PROT-tcps)(DISP=3)‘ Depending on performance, you may need to adjust the number of dispatchers.
Setting the Initial Number of Dispatchers • You can specify multiple dispatcher configurations by setting DISPATCHERS to a comma separated list of strings, or by specifying multiple DISPATCHERS parameters in the initialization file. If you specify DISPATCHERS multiple times, the lines must be adjacent to each other in the initialization parameter file. Internally, Oracle Database assigns an INDEX value (beginning with zero) to each DISPATCHERS parameter. You can later refer to that DISPATCHERS parameter in an ALTER SYSTEM statement by its index number. • Some examples of setting the DISPATCHERS initialization parameter follow. • Example: This is a typical example of setting the DISPATCHERS initialization parameter. DISPATCHERS="(PROTOCOL=TCP)(DISPATCHERS=2)" • Example: Forcing the IP Address Used for Dispatchers The following hypothetical example will create two dispatchers that will listen on the specified IP address. The address must be a valid IP address for the host that the instance is on. (The host may be configured with multiple IP addresses.) DISPATCHERS="(ADDRESS=(PROTOCOL=TCP)(HOST=144.25.16.201))(DISPATCHERS=2)" • Example: Forcing the Port Used by Dispatchers To force the dispatchers to use a specific port as the listening endpoint, add the PORT attribute as follows: DISPATCHERS="(ADDRESS=(PROTOCOL=TCP)(PORT=5000))" DISPATCHERS="(ADDRESS=(PROTOCOL=TCP)(PORT=5001))"