An Oracle Support Gotcha When Upgrading EBS R12 to

If you are not aware, My Oracle Support enforces the limits to patch access during extended support of a product. If you try to download a patch that is in extended support, you get an error message telling you to contact Support Sales. I have no problem with this in general. However, I do have a problem when I cannot get patches that are required for a product still under premier support.

A major example of this occurs when trying to upgrade R12 to because Oracle uses time zone version 14 which means I need to upgrade the R12 tech stack to use time zone version 14 files. According to note 563019.1, this means applying the time zone patch (9742718) to the 10.1.2 Oracle Home in the apps tier. Unfortunately, in spite the fact that R12 is still under premier support, it is not possible to download the required patch since 10.1 is in extended support.

This has not always been the case, If you were upgrading to, you would require the version 11 time zone patch (8524113). You can download this patch with a valid EBS CSI. You can also download patch 7695050, the required DST pre-req patch for time zone versions greater than 10. You cannot download version 13, 14 or 15 (the most current) patches at this time.

Hopefully, Oracle will get this resolved soon. Until then, all you can do is open an SR and have the analyst send you the required patch. Expect several iterations of them telling you to contact sales while you patiently explain this is to patch R12 which is still in premier support.

I will update this blog as soon as I can find a better solution (or Oracle fixes the access to the patch).

Update 8 March 2011: The patches still appear to be blocked, but I have been assured that Oracle is working to resolve the issue internally. They expect the patches to be available for download soon.

Update 31 March 2011: Still not available.  Hopefully this will be resolved before Collaborate.

Update 14 April 2011: Still not available.

Unix Script Security

I have received a lot of questions about this area recently. Here are a couple of tips and tricks I use to provide security within shell scripts.

Note: The syntax I will use is for Bourne type shells. The same concepts apply to csh, but the syntax changes.

The first scripting security issue for DBAs that we need to address is the problem of passwords in scripts. Many scripts we write as DBAs, especially applications DBAs, need to connect to the Oracle database. Unfortunately, these scripts frequently contain hardcoded passwords. This has two major problems, security and maintenance. Fortunately, the solution can be simple. In a secure location, have the system administrators create a file belonging to root in the dba (or oinstall) group with permissions 660 (owner read/write, group read/write, everyone else no access). For example, /etc/sysconfig/SID is a good choice in Linux. In this file, put your passwords.



Your scripts can source this file as part of the configuration at the start of the script. Then anywhere in the script that you need to use the password, you use the variable. In other words instead of sqlplus apps/apps, you use sqlplus apps/$APPS. Of course, that would still show the password with a ps command. An even better solution is to use i/o redirection inside the script:

. /u01/app/oracle/db/tech_st/10.2.0/VIS_vis12.env
if [ -f /etc/sysconfig/$ORACLE_SID ]; then
  . /etc/sysconfig/$ORACLE_SID
sqlplus /nologin <<EOF
connect apps/$APPS
select * from dual;

After making this change,  no one who sees the script will learn the apps password,  no one who happens to issue a ps command while the script is running will learn the password, and the act of changing the password in /etc/sysconfig/SID will update all of your scripts.

Now that we have solved the major security issue within our own scripts, let’s address scripts that need to be run as root. In a segregated environment, that is one where the DBAs do not have root, sudo can be a useful tool to allow this functionality.

For example to allow the oracle user to run from $ORACLE_HOME, you could make the following entry in /etc/sudoers (use visudo to edit this file):

oracle ALL = NOPASSWD: /u01/app/oracle/db/tech_st/10.2.0/

Of course, this is is now a major security violation.  Since this script is in a directory owned by oracle, anyone who can connect to the system as oracle, can run any command they want as root simply by editing  Obviously, the DBA team will continue to have to call the system administrators to have run when needed.  However, there are other commands that it may be more convenient to have the dba team able to run.  Examples of this may include viewing the system log, mounting and unmounting a backup or stage disk, or if cloning is done using some form of snapshot or mirroring on a SAN or NAS device, merging and splitting the mirrors.  One way to allow this is to have the system administration team write scripts to accomplish these functions and place them in a directory owned by root.  You can take the security a step further and make the directory only accessible to root.

For example (as root):

mkdir /usr/local/superuser_scripts
chown 700 /usr/local/superuser_scripts

Only root can access this directory.  If we want to allow the DBA team access to view the last 100 entries in /var/log/messages, we create a script tail100msg in /usr/local/superuser_scripts:

tail -100 /var/log/messages

In /etc/sudoers, the following line is added.

oracle ALL = NOPASSWD: /usr/local/superuser_scripts/tail100msg

If the oracle user, gives the command: sudo /usr/local/superuser_scripts/tail100msg, they will see the last 100 lines of /var/log/messages.  However, they have to know the script exists, because oracle cannot do an ls in /usr/local/superuser_scripts to see what is there.

You have to be extremely careful if you allow parameters to any scripts written for this purpose.  You have to follow all the same protections against attacks through substitution variables that are followed in sql scripts.

Do you have any other techniques you use to improve the security of the scripts you use?