Discussions
Categories
- 385.5K All Categories
- 5.1K Data
- 2.5K Big Data Appliance
- 2.5K Data Science
- 453.4K Databases
- 223.2K General Database Discussions
- 3.8K Java and JavaScript in the Database
- 47 Multilingual Engine
- 606 MySQL Community Space
- 486 NoSQL Database
- 7.9K Oracle Database Express Edition (XE)
- 3.2K ORDS, SODA & JSON in the Database
- 585 SQLcl
- 4K SQL Developer Data Modeler
- 188K SQL & PL/SQL
- 21.5K SQL Developer
- 46 Data Integration
- 46 GoldenGate
- 298.4K Development
- 4 Application Development
- 20 Developer Projects
- 166 Programming Languages
- 295K Development Tools
- 150 DevOps
- 3.1K QA/Testing
- 646.7K Java
- 37 Java Learning Subscription
- 37.1K Database Connectivity
- 201 Java Community Process
- 108 Java 25
- 22.2K Java APIs
- 138.3K Java Development Tools
- 165.4K Java EE (Java Enterprise Edition)
- 22 Java Essentials
- 176 Java 8 Questions
- 86K Java Programming
- 82 Java Puzzle Ball
- 65.1K New To Java
- 1.7K Training / Learning / Certification
- 13.8K Java HotSpot Virtual Machine
- 94.3K Java SE
- 13.8K Java Security
- 208 Java User Groups
- 25 JavaScript - Nashorn
- Programs
- 667 LiveLabs
- 41 Workshops
- 10.3K Software
- 6.7K Berkeley DB Family
- 3.6K JHeadstart
- 6K Other Languages
- 2.3K Chinese
- 207 Deutsche Oracle Community
- 1.1K Español
- 1.9K Japanese
- 474 Portuguese
Oracle 19c CDB/PDB CPU caging

Hi,
What is the recommended best practice to control resource utilization for CPU resources at CDB and PDB level?
- Define/set CDB CPU_COUNT and enable default resource manager and then set CPU_COUNT at PDB level (within each PDB) and enable resource manager within PDB?
- Define/Set CDB CPU_COUNT and enable resource manager at CDB level and then use the resource manager to create a performance profile at PDB level using shares?
Thanks,
Jayanath
Answers
-
What are the business requirements?
Hard limits can be problematic. If for example a hard limit of 10% CPU utilisation is used, with 50% of the current CPU being idle and unused - that additional 50% of available CPU cannot be used, despite CPU availability, due to the 10% hard limit.
Resources (CPU & memory & I/O) not used are wasted resources. It cannot be "saved" for future use as if there is some kind of resource savings account to draw resources against sometime in the future.
-
It is recommended to use a resource manager to manage database resources, which can be assigned to different database resources for different sessions.
Using package dbms_resource_manager;
-
@Billy Verreynne,
These are PROD boxes, Three node rac migration from AIX to Linux. As of now, these databases are CDB: PDB (1:1), running as three distinct instances in AIX.
On the Linux side, we are planning to onboard all three into a single CDB multitenant instance. No plans to over-provision instances. they will be rightsized to forecasted workloads. (CPU/Memory will be allocated accordingly but no I/O profiles will be implemented as of now)
The environment is not Exadata.
Hope this helps.
Regards,
Jayanath