310 likes | 330 Views
How Healthy is your Apps Environment? Easy Health Checks for Apps 11i . Lynne Paulus Oracle Applications DBA Fair Isaac. 11i Health Checks: Objectives. Describe ‘Health’ conditions to check in 11i environment Highlight issues you may want to monitor
E N D
How Healthy is your Apps Environment? Easy Health Checks for Apps 11i Lynne Paulus Oracle Applications DBA Fair Isaac
11i Health Checks: Objectives • Describe ‘Health’ conditions to check in 11i environment • Highlight issues you may want to monitor • Supply SQL statements that do health checks
Fair Isaac and Oracle Apps • Fair Isaac: Decision Support Software - approx 3,000 employees • Bay Area = San Rafael • San Diego, Minnesota and many other locations (Int’l) • Live on Oracle Apps since 1992 • Currently on 11.5.10.2 • Upgraded Nov 2005 from 11.5.8 • Modules = Financials, Projects, HR, OM, many CRM modules • All employees use 11i for Time and Expenses (OTL/iExpense) • Just went live on Project Resource Management
11i Health Check Characteristics • Overview of your environment’s health at a point-in-time • Not event driven - No alert as soon as condition occurs • Does not replace DB monitoring Software • For critical DB monitoring we use Quest Foglight - notify immediately of critical conditions • Examples: DB down, low disk space
11i Health Check Characteristics • Use format which is easy to extend • I use simple SQL script run as unix Cron job • Script emails the spool file to DBAs and Sys Admins • Some checks apply to all 11i - some may not apply to your environment • Examples • May be on different version of 11i with different logic • You may not have HR fully implemented so some employee information may not be available
11i Health Checks: Two Categories • 1) Warnings: You normally expect no rows returned • General, User Security, Profiles, Custom Direct Chgs, Module Specific, Std DB Checks • 2) General Health Checks: (categories overlap with Warnings but general checks often return data) • Invalid Objects • General DB • User Load Checks • Application Users • Profiles • Module Specific
11i Health Checks: Two Frequencies Frequencies: 1) Daily: Includes both Warnings and General Checks • Will cover these checks in more detail 2) Weekly: • Objects created in last month (DBAs should usually know why objects got created, if not research them) • Count users whose password will expire in next several weeks (look for bubbles of high password expiration)
Section Warning Health Checks
Sample output from Warning Section +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ++ Warning Section: +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Confirm not in Maintenance Mode - should see no rows no rows selected User Security AND Access Issues section: Show any logins whose password is NOT set to expire in 90 days no rows selected Non-DBAs who have System Administrator or Applic Develop Responsibility no rows selected Terminated employees who still have an active login to Oracle Apps USER_NAME TERM_DATE -------------------- -------------------- LYNNEPAULUS 06-Jan-06
Warning Health Checks • Confirm DB not in Maintenance Mode • Profile Option = 'Applications Maintenance Mode‘ • When Profile set to ‘NORMAL’ means not in Maint Mode so application should function normally • If start Forms and Apache while in Maint Mode, users have access problems but startup looks successful • We added this Profile check to our Application Start shell script • We get a warning and application does not start • Makes obvious dbas forgot to turn Maint Mode off
Warning Health Checks • User Warnings • Users lacking password expiration setup • For automating new employee login accounts see Jordan Kraft’s paper OAUG June 2005 • Non-DBAs/Sys Admins who have System Administrator responsibility USER_NAME END_DATE TODAY RESPONSIBILITY --------- -------- --------- ------------------------ JASONBURGOS 14-JAN-06 System Administrator • Terminated employees with active FND login account USER_NAME TERM_DATE -------------------- --------- LYNNEPAULUS 06-Jan-06
Warning Health Checks • Profile Warnings • Confirm Examine function is password protected • Profile = ‘Utilities:Diagnostics’ • When ‘Y’ then allows Help->Diagnostics->Examine without requiring Apps password – Also protects other Help->Diagnostics actions • Cryptic Logic so helpful to explain logic of setting in SQL script
Warning Health Checks • Custom Direct Changes Warnings • Standard objects you customized (not ‘extensions’) • Keep to absolute minimum - avoid like plague • Lose your changes when Oracle patches or upgrades object • Health Check to see whether object changed recently – Alerts you that you may have lost your change • Examples • Views customized for better performance or logic (e.g. ADP Views) • Package Changes: iExpense Approval - emergency customization to allow CEO to enter Expense Report Owner Object Name Created Last DDL ---- -------------------- --------- --------- APPS AP_WEB_DB_HR_INT_PKG 08-OCT-99 13-JAN-06
Warning Health Checks • Module Specific Warnings • Receivables (AR) • Orphaned rows in ar_journal_interim_all table • Caused by AR ‘Journal Entries Report' ending in Error • Check with Support on how to correct • Projects (PA) • Orphaned rows in pa_unbilled_rec_reporting table • Caused by 'MGT: Unbilled Receivables Aging' ending in Error • Check with Support on how to correct
Warning Health Checks • General DB Warnings • Locked db user accounts • We have setup some DB accounts to ‘lock’ after 3 invalid password tries • We only have invalid password logic on custom schemas • Expansion in Undo Tablespace • Can go unnoticed and take a lot more disk space (ours grew from 3 GB to 11 GB during upgrade) Tablespace Total MB Used MB Avail MB Percent Free ------------ --------- --------- --------- ----------- APPS_UNDOTS1 3,518.00 389.19 3,128.81 88.94
Sample output from Warning Section ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ++ Warning Section: ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Confirm not in Maintenance Mode - should see no rows no rows selected User Security AND Access Issues section: Show any logins whose password is NOT set to expire in 90 days no rows selected Non-DBAs who have System Administrator or Applic Develop Responsibility no rows selected Terminated employees who still have an active login to Oracle Apps USER_NAME TERM_DATE -------------------- -------------------- LYNNEPAULUS 06-Jan-06
Section General Health Checks
General Health Checks • General Health Checks - normally expect to return rows • Invalid Objects: • Apps (we currently have 4 that are always invalid) • We do not expect more than our ‘normal’ invalids (compile apps) • Custom Schema (we normally have zero invalids) OWNER OBJECT_NAME OBJECT_TYPE CREATED -------- ------------------------------ ------------ --------- APPS MRP_AN_ONHAND_SUPPLIES_V VIEW 23-AUG-01 APPS MRP_AP_ONHAND_SUPPLIES_V VIEW 23-AUG-01 APPS MRP_AP_OPERATION_RESOURCES_V VIEW 23-AUG-01 APPS MRP_SN_OPR_RESS_T2 TRIGGER 23-AUG-01
General Health Checks • General RDBMS Checks • Show count of failed DB logins (this does not include failed 11i logins) • Popular with auditors • List expired Schema accounts USERNAME CREATED DEFAULT TS TEMP STATUS LOCK_DATE -------------- --------- ---------- ---- ------ -------------- AD_MONITOR 12-NOV-05 TOOLS TEMP EXPIRE 11/12/05 12:34
General Health Checks • User Load Checks: • Current Forms user count • Self-Service User count (in last hour since lack logoff time) • High Water Mark for Oracle Connections since last DB start • Current Total sessions • JDBC Thin Client connections – sometimes not released TIME OF DAY Forms connects Self Service Current Sess HighWater JDBC Thin ----------------------- ------------------------ ----------------- ------------------- --------------- --------------- 10-JAN-06 05:45 229 132 722 994 359
General Health Checks • User Checks • Users whose FND Login Account password has become INVALID (11.5.10.2) • Caused by too many failed login attempts USER_NAME LASTLOGON PASS_DATE ENCRYPTED_PASSWORD -------------------- --------- --------- ---------------- JAMESADAMS 20-May-05 04-Apr-05 INVALID JOHNNYGABRON 04-Jan-06 06-Jan-06 INVALID LYNNEPAULUS 30-Dec-05 06-Jan-06 INVALID ROBERTBOLTON 22-Dec-05 06-Jan-06 INVALID ROBERTKRENKE 22-Dec-05 23-Sep-05 INVALID RONPERALTA 08-Jan-06 22-Dec-05 INVALID SKALSTABAKTON 22-Dec-05 06-Jan-06 INVALID TRACEYMARSHALL 20-Dec-05 07-Oct-05 INVALID USMANCHADRY 22-Dec-05 22-Dec-05 INVALID
General Health Checks • Profile General Checks • Site level Profiles changed in last 30 days USER_PROF_NAME value USER_NAME UPDATE_DATE ---------------------------------------- --------------- ---------- ----------- Applications Maintenance Mode NORMAL ANONYMOUS 08-Jan-2006 ICX: Discoverer End User Layer Language US LYNNEPAULU 07-Jan-2006 PA: Percentage Of Resource's Capacity 0 NATEBRUNNE 05-Jan-2006 PA: Resource Utilization Calculation Met CAPACITY NATEBRUNNE 06-Jan-2006 PA: Resource Utilization Period Type GL NATEBRUNNE 06-Jan-2006 PA: Starting Assignment Status 104 NATEBRUNNE 11-Jan-2006 PA: Utilization Calculation Begin Date 01-DEC-2005 NATEBRUNNE 06-Jan-2006 PA: Utilization Records Per Set 1000 NATEBRUNNE 06-Jan-2006 WF: Mailer Cancellation Email N NATEBRUNNE 03-Jan-2006
General Health Checks • Profile General Checks • Non-User Level Profile Settings relating to Trace or Debug • User Level Profile Settings relating to Trace or Debug prof_id LEVEL_ID USER_NAME PROF_NAME value ------- ---------- --------------- ------------------------- ----- 4176 10004 KIRKMEITZ FND: Debug Log Enabled Y 1528 10004 DOUGHAYES PA: Debug Mode Y 1528 10004 MIKEMARTIN PA: Debug Mode Y
General Health Checks • Module Specific Checks • Vary widely from site to site • General Ledger: GL consolidation tables that may be orphaned • iProcurement: Check for stuck Web requisitions • Research ‘Purge System Saved Requisition’ Con Program • OM: Check OE Processing Msgs for Number AND types of rows • Research ‘Message Purge’ Concurrent Program to clean
Section Health Check Tips
11i Health Check Tips: • How much time needed to monitor Health Check Report? • Warning section first - Expect no rows so scan is quick • General Section - Scan for differences • Use easy to maintain format - Keep it Simple • My unix shell script emails SQL spool file to Apps DBAs • Independent of monitoring Software • Easy to expand • I add additional checks at least once a month – takes about 5 minutes to expand • Any time new condition ‘bites’ us, I add to health check
11i Health Check Tips: • Good place to store logic behind certain issues • Captures SQL logic used to find data and reason why we care • Acts as repository of Apps exception conditions – better than using own memory to remember details of issues • Use as Reference as to where certain data stored • Add comments about when a check will change (e.g. after migrate to 11.5.10, this condition can be resolved by Con Pgm) • Consider including ‘as time allows’ reminders • We have more tasks than can get to so include queries that remind of outstanding issues (e.g. GL Consolidation tables)
11i Health Check Tips: • Treat Health Check script as important source code • Archive off current version before making any changes • Add Change Log entry at top of script for audit trail • We do not include in our Change Control process since script modifies no data • Better to error on side of having too many checks than too few • Put less important queries near end of script • Must change my health check script to work at your site • Your health check driver logic will probably vary from mine • My driver is unix shell script - runs from Unix Cron • Could use Oracle Alerts, 3rd party software, etc
Conclusion: • My health check SQL script available on NorCal OAUG Web site: http://www.norcaloaug.org/2006_training_day/TDpresentations.htm • Filename = ck_apps_health.sql • Many Apps Health Checks can be done automatically • If you don’t implement automated Health Checks • Modify my SQL script for your site and run manually • Review output - look for changes in 11i you want to make • For Example - Password Protect ‘Examine’ feature
Off-Topic Comments: • We found 11.5.10.2 pretty stable for application modules • We’ve had lots of issues with Users, Responsibility Assignments and Workflow Role tables? Redesign of this logic was extensive so it seems ‘bleeding edge’ • Re-assign Fnd User to employee – caused all user’s responsibility assignments to be duplicated and corrupted • Be very cautious of direct updates to fnd_user table • Lots of Lock contention - Eventually crashed DB after killing lock holder
Q and A: • General Questions: • Who is using DataGuard with 11i? • How do you monitor who is currently logged into Forms and Self-Service? • Do you have your users time-out when inactive? • How quickly? • How do you get semi-exclusive access to 11i? • How often do you do routine maintenance of Concurrent Manager Tables? • What other 11i health checks do you run? • Who has implemented Project Resource Management?