Donnerstag, 10. November 2016

Export Datapump: No locks available (NFS Share)

It's time for a new post, istn't it?

I recently had the problem that an expdp command failed with the following message:

ORA-39001: invalid argument value
ORA-39000: bad dump file specification
ORA-31641: unable to create dump file "/backup/exp.dmp"
ORA-27086: unable to lock file - already in use
Linux-x86_64 Error: 37: No locks available
Additional information: 9
Additional information: 37

The problem is related with that the NFS server which provides the NFS share. It has no locking service installed and/or configured. There are two options, you either install a locking service on the NFS server or change the mount options.

The option "noac" needs to be replaced with "nolock".

In my case I did the following change to /etc/fstab:

# Before
10.10.10.10:/Oracle  /backup  nfs  rw,rsize=32768,wsize=32768,tcp,vers=3,hard,intr,noac  0 0
# After 
10.10.10.10:/Oracle  /backup  nfs  rw,rsize=32768,wsize=32768,tcp,vers=3,hard,intr,nolock  0 0

That's IT.

Montag, 29. Februar 2016

SQLPlus Ausgabe in Variable Speichern

In Linux ist es sehr einfach, eine Variable mit der Ausgabe von einem SQLPlus-Befehl zu füllen. Unter Windows ist das eine halbe Doktorarbeit.

Vielen Dank an Damir Vadas für seinen sehr hilfreichen Post in seinem Blog (Thank you Damir Vadas for your helpful post on this subject):
"How to redirect sqlplus result in Windows batch script"

echo set timi off head off^&echo. select  MIN(sequence#) from v$log where thread#=1; | sqlplus -s "/ as sysdba" | findstr . > result.tmp
FOR /F %i IN (result.tmp) DO @set MIN1=%i
@echo %MIN1%
del result.tmp


Quelle: http://damir-vadas.blogspot.de/2010/11/how-to-redirect-sqlplus-result-in.html

That's IT

Dienstag, 9. Februar 2016

Katastrophe: Windows 64Bit, Oracle DB 64Bit und Oracle Client 32Bit

Von Zeit zu Zeit ist man als Oracle-DBA dazu gezwungen, Datenbanken unter Windows zu betreiben. Als wenn das nicht genug Ärger bedeutet, soll auch noch neben der 64Bit Datenbank ein 32Bit Client installiert werden.

Es gibt eine ganze Sammlung (Oracle Note 1157463.1) von Problemen die unter Windows auftreten wenn man versucht, ein zweites oder drittes Oracle-Produkt zu installieren. Mit Oracle-Produkt meine ich nicht Java oder ähnliches, sondern alles was mit dem Oracle Universal Installer installiert wird.

Neben verschiedenen Java-Problemen, Chaos im Inventory oder andere Kleinigkeiten gibt es noch dieses Problem:

Der OUI wurde mit "Als Administrator ausführen" ausgeführt und startet ganz normal. Am Ende des Assistenten klickt man auf "Install". Der Installationsdialog erscheint für 1-3 Sekunden und verschwindet wieder. Wer in den Installationslogs nach weiteren Informationen sucht, wird nicht fündig denn diese sind leer. Das Verhalten wurde in der Oracle-Community bereits diskutiert, leider ohne Erfolg: https://community.oracle.com/thread/2192825?tstart=0
Dieses Problem scheint auch nicht immer aufzutreten, denn sonst gäbe es im Internet sicher schon mehrere Komplettlösungen dazu.

Das Problem liegt an den Registry-Einträgen im Zusammenhang mit dem Oracle Inventory Pfad.

Nach der Installation von Oracle DB 64Bit gibt es den Registry-Key "inst_loc" unter [HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE]. Dieser verweist auf das Oracle-Inventory unter "C:\Program Files\Oracle\Inventory".

Der 32Bit-Installer sucht zusätzlich nach dem Registry-Key "inst_loc" in [HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Oracle]. Diesen gibt es noch nicht und da dies ein 32Bit-Installer ist, müsste dementsprechend der Pfad "C:\Program Files (x86)\Oracle\Inventory" heißen. Den Konflikt zwischen den beiden Keys/Pfaden kann der Installer dann scheinbar nicht lösen und stürzt ab.

Wenn dieser Pfad vor der Installation des Oracle Client 32Bit manuell angelegt wird, funktioniert die Installation. Es kommt also darauf an, dass die beiden Registry-Keys [HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\inst_loc] und [HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Oracle\inst_loc] auf den selben Pfad zeigen.

That's IT