6 Troubleshooting
This chapter includes the following sections:
6.1 General
This section covers the following topics:
6.1.1 Changing the number of worker threads for a batch processor
The number of worker threads can be modified for any of the batch processors. For example, perform the following steps to change the number of worker threads for the import processor. In this example, the thread count is being changed from 10 to 1:
-
Stop the Capture Managed Server.
-
In the WebLogic Server Administration Console, click Deployments in the Domain Structure tree on the left. The Summary of Deployments page displays.
-
In the Deployments table, expand the Capture deployment node.
-
Expand the Modules node under the Capture deployment node and select oddc-core.jar. The settings page for oddc-core.jar displays.
-
Select the Configuration tab and then the Workload subtab.
-
Select ImportProcessorMgr from the list of Application Scoped Work Managers. The settings page for ImportProcessorMgr displays.
-
Select ImportProcessorMaxThreads from the list of Application Scoped Work Manager Components. The settings page for ImportProcessorMaxThreads displays.
-
Set the value of the Count field to 1 (from 10).
-
Click Save.
Perform the following steps to confirm the changes to the thread count setting:
- Start the Capture Managed Server.
- In the WebLogic Server Administration Console, expand the Services node in the Domain Structure tree on the left.
- Expand the Messaging node under Services and click JMS Modules. The JMS Modules page displays.
- In the JMS Modules table, select capture-jms-module. The settings page for capture-jms-module displays.
- In the Summary of Resources table, select capture-batchinput-queue. The settings page for capture-batchinput-queue displays.
- Select the Monitoring tab. In the Destinations table, the values in the Consumers Current and the Consumers High columns should be 1.
6.1.2 Creating a hash partition to improve database performance
You can use a hash partition of the EBATCTITEMS table to minimize the database wait event enq: HW– contention, which prevents the database from scaling. This event occurs when many threads are trying to update and add new BLOB items to ECBATCHTITEMS, as follows:
table - "UPDATE ECBATCHITEMS SET ECITEMDATA=:1 WHERE ECITEMID=:2"
Creating a hash partition minimizes this contention because different items will be in eight different partitions. See Creating a Hash Partition to Improve Database Performance in Installing and Configuring Oracle WebCenter Content.
Note:
The use of a hash partition on an Oracle Database has licensing implications since it requires the purchase of an "Oracle Partitioning" license. Please refer to this document: http://docs.oracle.com/cd/B28359_01/license.111/b28287.pdf.
6.2 Commit Processor
This section covers troubleshooting topics related to the Commit Processor.
6.2.1 Testing the PDF Image-Only document export driver outside of Capture
To test the Outside In Technology (OIT) PDF Export utility, it is necessary to supply a TIFF file to test the export. Perform the following steps:
Using Linux
-
Open a terminal window.
-
Change to the
{Middleware Home}/oit/linux64/lib/contentaccess
directory.Note: The default
{Middleware Home}
path on Linux is/Oracle/Middleware/Oracle_Home
. -
Enter the following command, which first sets the LD_LIBRARY_PATH variable to the current directory (".") and then executes the PDFExport64 utility:
env LD_LIBRARY_PATH=. ../../../../wccapture/capture/bin/linux/PDFExport64 -i {TIFF file to read} -o {PDF file to create} -l {log file to create} -f {Path to font folder}
Example:
env LD_LIBRARY_PATH=. ../../../../wccapture/capture/bin/linux/PDFExport64 -i /tmp/sample.tif -o /tmp/test.pdf -l /tmp/pdfexport.log -f /usr/share/X11/fonts
The logging of the OIT PDF Export utility will be captured in the log file specified in the command above (example:
/tmp/pdfexport.log
).
Using Windows
6.3 Client
This section covers the following topics:
6.3.1 Setting logging in the Capture client
Perform the following steps to enable additional Java logging for the Capture client:
-
Begin modifying the WebCenter Enterprise Capture Client desktop shortcut by right-clicking on the shortcut icon and selecting Properties from the menu.
-
On the Shortcut tab, click inside the Target field and position the cursor at the end of the line. Type in a space followed by
"-showconsole"
(without the quotes). -
Click OK to save the changes. The next time you start the Capture client using the desktop shortcut, a debug console will display providing additional logging information.
Perform the following steps in the Capture client to activate batch logging:
For issues involving a TWAIN driven scanning device, a TWAIN log is automatically created:
C:\Users\WINDOWS_USER\AppData\Local\Temp\capture_twain.log
6.3.2 Scanning in black/white with Kofax VRS TWAIN driver
When scanning in black/white in the Capture client using the Kofax VRS TWAIN driver, the black and white areas are inverted in the scanned images.
Perform the following steps to resolve this issue:
- Login to the Capture client.
- Click the drop-down list arrow in the upper right corner of the window and select Preferences. The Preferences window displays.
- Select the Prevent File Mode Transfer field.
- Click Save.
The above settings may cause performance issues when scanning color images with a large DPI value, for example, a DPI value between 300 and 600.
6.4 Document Conversion Processor
This section covers the following topics:
6.4.1 "Image export failed with code 3" error in Conversion Processor (OIT conversion)
The "Image export failed with code 3" error message is a generic error message related to the OIT conversion in Capture. To gather a more detailed error message, you will need to set the CAPTUREOITEXPORTLOG
environment variable to generate a log file.
Using Linux
To set the environment variable in Linux, you need to modify the setDomainEnv.sh file which is located in {Oracle Home}/user_projects/domains/{Capture domain}/bin
directory.
Add the following two lines to the end of the file:
CAPTUREOITEXPORTLOG="/scratch/captureoit.log"
export CAPTUREOITEXPORTLOG
You can change "/scratch"
to any other directory if it exists and is writable. After you add the environmental variable, restart the Capture Managed Server and duplicate the issue. Then examine the captureoit.log file to see the more detailed error message.
Using Windows
To set the environment variable in Windows, you need to modify the setDomainEnv.cmd file which is located in {Oracle Home}\user_projects\domains\{Capture domain}\bin
directory.
Add the following line to the end of the file:
set CAPTUREOITEXPORTLOG="C:\temp\captureoit.log"
You can change "C:\temp"
to any other directory if it exists and is writable. After you add the environmental variable, restart the Capture Managed Server and duplicate the issue. Then examine the captureoit.log file to see the more detailed error message.
6.4.2 Running CaptureOITExport to debug issues related to converting to TIFF
Capture uses OIT libraries for performing the conversion to TIFF. Internally, it uses CaptureOITExport for the conversion. It will create OIT specific logs which can be useful to resolve OIT related errors.
Using Linux
-
Open a shell prompt and change directories to
{Oracle WebCenter Home}/oit/linux64/lib/contentaccess
. -
For conversions to work on some platforms, certain environment variables must be set. On a Linux operating system running XWindows, when redirecting the display to a system with suitable graphic capabilities, export
DISPLAY
to a valid X Server before starting the conversion.Note: On Oracle Linux, the display server is available. On AIX server, it might need to be installed separately.
-
Create an OIT specific log file. Export the
CAPTUREOITEXPORTLOG
environment variable to create the log file specified. -
Create an input file which contains the parameters for conversion. The name of the input file is
/test/testuser/input.txt
and contains the following lines:BEGINSESSION|1|/test/testuser/Test_07.docx|/test/testuser/output/out.tif|FI_TIFF~1|0|0|0|/test/testuser/output/che.lst|300 quit
-
Run
CaptureOITExport64
.Example:
export DISPLAY=:0 export CAPTUREOITEXPORTLOG=/test/testuser/oit.log ../../../../wccapture/capture/bin/linux/CaptureOITExport64 < /test/testuser/input.txt CaptureOITExport Started. ACKSESSION FINISHSESSION INITIATETERMINATE
In the above example:
-
/test/testuser/Test_07.docx
: Input Microsoft Word document file -
/test/testuser/output/out.tif
: Output TIFF -
/test/testuser/output/che.lst
: Contains the list of pages for the multi page TIFF
-
Using Windows
Example:
6.5 Resolve Linux Image Conversion and Rendering Issues
This section discusses the symptoms, cause, troubleshooting steps, and solutions to the problem to fix the Linux image conversion and rendering issues in Capture.
- Image export failed with Code 3
- XOpenDisplay failed
- Unable to fully render document
- Failed image conversion and cannot be stored in cache at this time
- A cache exception occurred
- Transformation process returned error code 135
- A failure occurred while encrypting the document
- Failed to launch CaptureOITExport
- Error launching the external transformation process
To resolve the above errors, perform the following troubleshooting steps:
- Check
DISPLAY
andGDFONTPATH
environment variables:If
DISPLAY
is not set or is not set to a valid value, an error will occur. TheGDFONTPATH
environment variable must be set to a validTrueType
font directory path. On Oracle Linux machine, the defaultTrueType
font directory is/user/share/fonts/liberation
. The directory contains six.TTF
font files. There is noGDFONTPATH MBean
for Capture.If Capture and Imaging are running on the same server, the
DISPLAY
variable will be set for both processes, because they both depend on the filesetDomainEnv.sh
for this setting. In this environment, Imaging will also use the X server for image conversion.To check if the running process has theDISPLAY
and/orGDFONTPATH
environment variables set:$ ps –ef | grep <capture_server1 or IPM_server1>
For example, to find the process ID (PID), enter the following command:
Sample output:
[example@linuxtest2 ~]$ ps -ef | grep capture_server1 example 1184 802 9 Sep24 ? 2-13:25:39 /usr/java/jdk1.8.0_171-amd64/bin/java -server -Xms256m -Xmx1024m -cp /oracle2/Middleware12c/wlserver/server/lib/weblogic-launcher.jar -Dlaunch.use.env.classpath=true -Dweblogic.Name=capture_server1<actual output truncated>
1184 is the PID of the Capture server. It’s usually a 4 or 5 digit decimal number.
To query the running process for the
DISPLAY
andGDFONTPATH
environment variable values as follows:On Linux:
$ ps ewww <capture_server1 PID> | tr ' ' '\n' | grep \= | grep DISPLAY $ ps ewww <capture_server1 PID> | tr ' ' '\n' | grep \= | grep GDFONTPATH
On Solaris:
$ pargs –e <capture_server1 PID> | grep DISPLAY $ pargs –e <capture_server1 PID> | grep GDFONTPATH
Example:
$ ps ewww 1184 | tr ' ' '\n' | grep \= | grep DISPLAY
Output:
DISPLAY=10.148.51.219:0
$ ps ewww 1184 | tr ' ' '\n' | grep \= | grep GDFONTPATH
Output:
GDFONTPATH=/usr/share/fonts/liberation
Sample bad output:
$ ps ewww 1184 | tr ' ' '\n' | grep \= | grep DISPLAY
<no output displayed>
$ ps ewww 1184 | tr ' ' '\n' | grep \= | grep GDFONTPATH
<no output displayed>
Problem resolution:
The following environment variables should be set as needed in the file
setDomainEnv.sh
($DOMAIN_HOME/bin/
):1 DISPLAY=<machine name or IP>:<display>:<port> export DISPLAY GDFONTPATH=<path to .ttf font files> export GDFONTPATH
If one or both variables are defined, they may be set in thesetDomainEnv.sh
file ($DOMAIN_HOME/bin/setDomainEnv.sh
), but they also can be set at many other places on the system. TheDISPLAY
andGDFONTPATH
variables can be set in other process startup scripts such as.profile
,.bash_profile
and so on. If theDISPLAY
variable is not required, add the following command in thesetDomainEnv.sh
file to remove the variable from the process:unset DISPLAY
Note:
TheGDFONTPATH
environment variable must always be set.If there is no
DISPLAY
orGDFONTPATH
variable defined, the reason is that the filesetDomainEnv.sh
($DOMAIN_HOME/bin/
) does not include the definitions of these variables. If they are defined, but not created or set in thesetDomainEnv.sh
file, defining them in thesetDomainEnv.sh
file will overwrite the preset values.The value of
DISPLAY
will often be set tolocalhost:n.0
. That refers to the server, display n, port 0 which is fine as long as an X server is running on the local server. TheGDFONTPATH
variable must also be set in the filesetSOADomainEnv.sh
($DOMAIN_HOME/bin/
) if SOA is running on the same server.After making the necessary changes to the
setDomainEnv.sh
file, restart the entire domain and then retest.If the problem is still not solved, continue troubleshooting.
- Verify that X server is running:
If Capture is not running on the server, skip to Step 4. If Capture is running on the server, an X server must be running. The known options are X, VNC (several flavors of Linux), Gnome Desktop Manager (GDM), or Virtual Frame Buffers (VFB, Solaris-only). There are other software packages available that do the same thing.
Command:$ ps -ef | grep ‘X ‘ | grep –v grep
Sample Output:root 6497 1 0 Sep23 tty7 00:00:01 X :0
Sample bad or non-existent output:$ ps -ef | grep vfb | grep –v grep $ ps -ef | grep gdm | grep –v gdm $ ps -ef | grep vnc | grep –v vnc
Interpretation of the sample output:- There is an X server running with
DISPLAY
set tolocalhost:0.0
- There is no VFB (for Solaris only), GDM, or VNC running on this host.
Problem detection and resolution:
The configuring and running an X server is beyond the scope of Oracle support. The system administrator needs to perform these operations.
For a Capture issue, an X server must be running regardless of which type it is (X, VNC, GDM, VFB or any other kind).
- There is an X server running with
- Verify X server configuration and permissions:
If using VNC, add the following line in the VNC configuration file
/etc/sysconfig/vncservers
.VNCSERVERS="0:root 1:oracle"
where
oracle
is the user account of the Capture server. To have more detailed description about this configuration, see Configuring VNC Server on Linux. If this line is changed, stop and restart the VNC server for display 1. The above two steps are often the source of the problem. If those are fine, follow the next steps. - Check OIT libraries’ location and consistency:
The OIT libraries are located at
$ECM_HOME/oit/<platform>/lib/contentaccess
. For Solaris, navigate to thesolaris/lib location
, and not to thesolaris-x86/lib
location.Navigate to the location:$ cd $ECM_HOME/oit/<platform>/lib/contentaccess
Check that all the required components are installed.
On Linux and Solaris:$ ldd libos_gd.so $ ldd libos_xwin.so
On AIX, enter the command:$ dump –H libos_gd.so $ dump –H libos_xwin.so
Sample Output:$ cd /oracle/Middleware/Oracle_ECM1/oit/linux/lib/contentaccess $ ldd libos_gd.so linux-gate.so.1 => (0xf777b000) libwv_gdlib.so => /oracle/Middleware/Oracle_ECM1/oit/linux/lib/contentaccess/./libwv_gdlib.so (0xf7753000) libwv_core.so => /oracle/Middleware/Oracle_ECM1/oit/linux/lib/contentaccess/./libwv_core.so (0xf737d000) libm.so.6 => /lib/libm.so.6 (0xf7353000) libpthread.so.0 => /lib/libpthread.so.0 (0xf7337000) libstdc++.so.6 => /usr/lib/libstdc++.so.6 (0xf724c000) libgcc_s.so.1 => /lib/libgcc_s.so.1 (0xf722e000) libc.so.6 => /lib/libc.so.6 (0xf7097000) libfreetype.so.6 => /oracle/Middleware/Oracle_ECM1/oit/linux/lib/contentaccess/./libfreetype.so.6 (0xf702c000) libdl.so.2 => /lib/libdl.so.2 (0xf7026000) /lib/ld-linux.so.2 (0xf777c000) libz.so.1 => /lib/libz.so.1 (0xf7012000)
If something is missing, the line clearly states that it’s missing. For example:libcsfml-window.so.2.2 => not found libcsfml-graphics.so.2.2 => not found
Problem detection and resolution:
If there are libraries missing, the system administrators must be engaged to install the missing package(s) prior to continuing. The installation of the required packages is beyond the scope of Oracle support.
- Double check Imaging OIT location:
If the problem is solved for Capture, skip this step and go to Step 6.
- Check OIT libraries’ version:
Check version manually, where platform can be Linux, Solaris, etc..
$ cd $ECM_HOME/oit/<platform>/lib/contentaccess $ for i in *; do echo $i; strings $i | grep _VER; done