These PostgreSQL configuration variables can influence PL/Java's operation:
check_function_bodies
check_function_bodies
affects
how strictly PL/Java validates a new function at the time of a
CREATE FUNCTION
(or when installing a jar file with CREATE FUNCTION
among its deployment actions). With check_function_bodies
set to on
,
PL/Java will make sure that the referenced class and method can be loaded
and resolved. If the referenced class depends on classes in other jars,
those other jars must be already installed and on the class path, so
loading jars with dependencies in the wrong order can incur validation
errors. With check_function_bodies
set to off
, only basic syntax is
checked at CREATE FUNCTION
time, so it is possible to declare functions
or install jars in any order, postponing any errors about unresolved
dependencies until later when the functions are used.dynamic_library_path
dynamic_library_path
influences
where the PL/Java native code object (.so
, .dll
, .bundle
, etc.) can
be found, if the full path is not given to the LOAD
command.server_encoding
UTF8
as the database and server
encoding is strongly recommended. If a different encoding is used, it
should be any of the available fully defined character encodings. In
particular, the PostgreSQL pseudo-encoding SQL_ASCII
does not fully
define what any values outside ASCII represent; it is usable, but
subject to limitations.pljava.debug
on
, stops the process on first entry to
PL/Java before the Java virtual machine is started. The process cannot
proceed until a debugger is attached and used to set the static
Backend.c
variable pljavaDebug
to zero. This may be useful for debugging
PL/Java problems only seen in the context of some larger application
that can't be stepped through.pljava.enable
off
prevents PL/Java startup from completing, until
the variable is later set on
. It can be useful when
installing PL/Java on PostgreSQL versions before 9.2.pljava.implementors
postgresql
. A deployment descriptor that contains commands with
other implementor names can achieve a rudimentary kind of conditional
execution if earlier commands adjust this list of names. Commas separate
elements of this list. Elements that are not regular identifiers need to be
surrounded by double-quotes; prior to PostgreSQL 11, that syntax can be used
directly in a SET
command, while in 11 and after, such a value needs to be
a (single-quoted) string explicitly containing the double quotes.pljava.java_thread_pg_entry
allow
, error
, block
, or throw
controlling PL/Java's thread
management. Java makes heavy use of threading, while PostgreSQL may not be
accessed by multiple threads concurrently. PL/Java's historical behavior is
allow
, which serializes access by Java threads into PostgreSQL, allowing
a different Java thread in only when the current one calls or returns into
Java. PL/Java formerly made some use of Java object finalizers, which
required this approach, as finalizers run in their own thread.
PL/Java itself no longer requires the ability for any thread to access
PostgreSQL other than the original main thread. User code developed for
PL/Java, however, may still rely on that ability. To test whether it does,
the error
or throw
setting can be used here, and any attempt by a Java
thread other
than the main one to enter PostgreSQL will incur an exception (and stack
trace, written to the server's standard error channel). When confident that
there is no code that will need to enter PostgreSQL except on the main
thread, the block
setting can be used. That will eliminate PL/Java's
frequent lock acquisitions and releases when the main thread crosses between
PostgreSQL and Java, and will simply indefinitely block any other Java
thread that attempts to enter PostgreSQL. This is an efficient setting, but
can lead to blocked threads or a deadlocked backend if used with code that
does attempt to access PG from more than one thread. (A JMX client, like
JConsole, can identify the blocked threads, should that occur.)
The throw
setting is like error
but more efficient: under the error
setting, attempted entry by the wrong thread is detected in the native C
code, only after a lock operation and call through JNI. Under the throw
setting, the lock operations are elided and an entry attempt by the wrong
thread results in no JNI call and an exception thrown directly in Java.
pljava.libjvm_location
libjvm
shared
object (filename typically ending with .so
, .dll
, or .dylib
).
To determine the proper setting, see finding the libjvm
library.pljava.module_path
If additional modular jars are added to the module path,
--add-modules
in pljava.vmoptions
will make them readable by
PL/Java code.
For more on PL/Java's “module path” and “class path”, see PL/Java and the Java Platform Module System.
pljava.policy_urls
%22
in the URL convention. Between double-quoted URLs, a comma is the
list delimiter.
The Java installation's java.security
file usually defines two policy
file locations:
The list in pljava.policy_urls
will modify the list from the Java
installation, by default after the first entry, keeping the Java-supplied
systemwide policy but replacing the customary per-user file (there
probably isn't one in the home of the postgres
user, and if there is
it is probably not tailored for PL/Java).
Any entry in this list can start with n=
(inside the quotes) for a
positive integer n, to specify which entry of Java's policy location list
it will replace (entry 1 is the systemwide policy, 2 the customary user
location). URLs not prefixed with n=
will follow consecutively. If the
first entry is not so prefixed, 2=
is assumed.
A final entry of =
(in the required double quotes) will prevent
use of any remaining entries in the Java site-configured list.
This setting defaults to
"file:${org.postgresql.sysconfdir}/pljava.policy","="
pljava.release_lingering_savepoints
off
(the default), they will be rolled back. If on
, they will be
released/committed. If possible, rather than setting this variable on
,
it would be safer to fix the function to release its own savepoints when
appropriate.
A savepoint continues to exist after being used as a rollback target. This is JDBC-specified behavior, but was not PL/Java's behavior before release 1.5.3, so code may exist that did not explicitly release or roll back a savepoint after rolling back to it once. To avoid a behavior change for such code, PL/Java will always release a savepoint that is still live at function return, regardless of this setting, if the savepoint has already been rolled back.
pljava.statement_cache_size
pljava.vmoptions
java
command (windows,
Unix family). The string is split on whitespace unless found
between single or double quotes. A backslash treats the following
character literally, but the backslash itself remains in the string,
so not all values can be expressed with these rules. If the server
encoding is not UTF8
, only ASCII characters should be used in
pljava.vmoptions
. The exact quoting and encoding rules for this variable
may be adjusted in a future PL/Java version.
Some important settings can be made here, and are described on the VM options page.