unset JAVA_HOME export PATH=$ORACLE_HOME/jdk/bin:$PATH cd $ORACLE_HOME/OPatch ./opatch lsinventory If opatch.pl is corrupted, reinstall OPatch from a clean download:
mv $ORACLE_HOME/OPatch $ORACLE_HOME/OPatch.bak unzip p6880880_*.zip -d $ORACLE_HOME chmod +x $ORACLE_HOME/OPatch/opatch Edit $ORACLE_HOME/OPatch/opatch.properties and add:
my $java_cmd = "java -$majorVer.$minorVer-"; if (! -x $java_cmd) die "java -$majorVer.$minorVer- could not be located. opatch cannot proceed"; Step 4 – Check Environment Variables env |
set JAVA_HOME=C:\PROGRA~1\Java\jdk1.8.0_202 Or use opatch.bat with -jre flag:
ls -l $ORACLE_HOME/jdk/bin/java ls -l $ORACLE_HOME/jre/bin/java which java If none exist → . Step 2 – Test Java Executability $ORACLE_HOME/jdk/bin/java -version If it fails with “Permission denied” or “cannot execute” → Root cause 3.4 (SELinux/permissions). Step 3 – Inspect OPatch Perl Files file $ORACLE_HOME/OPatch/opatch.pl perl -c $ORACLE_HOME/OPatch/opatch.pl Look for “syntax OK”. If you see compilation errors or mixed line endings → Root cause 3.2 . Step 4 – Check Environment Variables env | grep -E "JAVA_HOME|CLASSPATH|PATH" If JAVA_HOME points to a nonexistent or wrong Java version, unset it: unset JAVA_HOME and retry. Step 5 – Force OPatch’s Java Detection Verbose Run: usually triggered by environment pollution
#!/bin/bash unset JAVA_HOME unset CLASSPATH unset LD_LIBRARY_PATH export ORACLE_HOME=/u01/app/oracle/product/19.3.0/dbhome_1 export PATH=$ORACLE_HOME/OPatch:$ORACLE_HOME/jdk/bin:$PATH exec $ORACLE_HOME/OPatch/opatch "$@" Before any patching, run:
Introduction For Oracle Database administrators and middleware specialists, few things are as simultaneously routine and nerve-wracking as applying patches using OPatch (the Oracle patch management utility). The error message: “java -1.6- could not be located. opatch cannot proceed. opatch returns with error code 1” is a classic, cryptic failure that has haunted patching attempts across Oracle Fusion Middleware, WebLogic Server, and even some database-side Java components. At first glance, it appears to be a simple missing Java version. In reality, this error exposes deep intricacies in how OPatch discovers, validates, and invokes Java, how environment variables interact with internal Oracle scripts, and how version string parsing can fail in non-obvious ways. corrupted Perl scripts
Look at a sanitized snippet from older opatch.pl or opatch_generic.pl :
java.home=/path/to/valid/jdk This bypasses auto-detection entirely. chcon -t bin_t $ORACLE_HOME/jdk/bin/java restorecon -v $ORACLE_HOME/jdk/bin/java Or temporarily disable (not recommended for production): setenforce 0 . 5.5 Windows-Specific Fix Wrap JAVA_HOME in short path names:
$ORACLE_HOME/OPatch/opatch lsinventory -debug Search for “Java detection” or “JAVA_COMMAND”. If you see java -1.6- in the debug output → The Perl variable substitution failed at a low level. $ORACLE_HOME/OPatch/opatch version If version ≥ 13.9 and your Java is 1.6 → Root cause 3.5 . 5. Resolution Strategies 5.1 Quick Fix (Most Common) Unset JAVA_HOME – Often the system JAVA_HOME conflicts with the Oracle home’s embedded Java.
$ORACLE_HOME/OPatch/opatch lsinventory -invPtrLoc $ORACLE_HOME/oraInst.loc > /dev/null if [ $? -eq 1 ]; then echo "Java detection failure - abort patching" exit 1 fi The error “java -1.6- could not be located. opatch cannot proceed. opatch returns with error code 1” is not a simple “missing Java 1.6” problem. It is a symptom of broken Java discovery logic within OPatch , usually triggered by environment pollution, corrupted Perl scripts, or permission issues. The “-1.6-” is an artifact of uninitialized variables, not a version requirement.
¡Atención! sitio con contenido para adultos
Para acceder debes aceptar las siguientes condiciones: