|
In order to simplify testing, I asked our java developer to create asimple
method to call from rpg that made no connections at all to the iSeries. Ivariables
created an rpgle program to call the method. I have code that adds a link
to the directory, adds the .jar to the environmental variable, uses
getJniEnv and BegObjGroup (jniutil), calls the java method (defined as a
Static Extproc), ends the object group, removes the environmental
and removes the link. When I then check the .jar file on the ifs theusage
is 'in use' under the job that I ran the rpg program in. I am unable toconclusion
restore that object or release it in any way until that session is signed
off.
Having said all that and testing past versions, I've come to the
that this was most likely the case for years on installs, we are justseeing
it more often as the use of java has become more prevalent. If have found[mailto:java400-l-bounces@xxxxxxxxxxxx]
nothing in my searches as a work around, unless anyone has any ideas.
Thanks
-----Original Message-----
From: java400-l-bounces@xxxxxxxxxxxx
On Behalf Of Dan Kimmelthe
Sent: Tuesday, November 02, 2010 10:36 AM
To: Java Programming on and around the IBM i
Subject: RE: .jar files in use on a restore
Are you talking about database connections or connections to run native
commands and programs?
JDBC connections use JT400.jar (JTOPEN.jar) and classes from the jre. I
doubt you're replacing any of those. What jars are failing to replace? Are
they your own code?
If you are using the non-thread-safe versions of the connection commands,
those connections occur in jni programs that run within the same job as
jvm. The thread-safe versions are all native java and jdk codecommunicating
with server jobs that usually run in the QUSRWRK subsystem. That mightmake
a difference when trying to shut down the jvm via the activation group to[mailto:java400-l-bounces@xxxxxxxxxxxx]
free up connections to your jar files.
Just as an afterthought, are you doing anything to your java environment
that would free up hard links before you end the activiation group?
-----Original Message-----
From: java400-l-bounces@xxxxxxxxxxxx
On Behalf Of Anna Abtended
Sent: Tuesday, November 02, 2010 7:33 AM
To: 'Java Programming on and around the IBM i'
Subject: RE: .jar files in use on a restore
The activation group is ended at the end of the rpg processes and also
at the beginning of an install/upgrade. As this seems to be intermittent[mailto:java400-l-bounces@xxxxxxxxxxxx]
and a fairly new occurrence, I'm leaning toward something the java code is
doing in creating an iSeries connection. I am running more tests on our
systems to see if I can get more details.
-----Original Message-----
From: java400-l-bounces@xxxxxxxxxxxx
On Behalf Of Dan Kimmelyou're
Sent: Monday, November 01, 2010 6:06 PM
To: Java Programming on and around the IBM i
Subject: RE: .jar files in use on a restore
As long as that RPG program has pointers to the instantiated object,
not going to be able to replace the jars containing the code for thatto
object. There are other ways to do it, but you're probably going to have
end the activation group where the RPG program is running in order toremove
the locks on the jar files. I don't think the traditional methods ofjar
detecting locks are going to find locks on your jar files. WRKOBJLCK, for
instance, looks for objects referenced by the job and a jar file is not an
object. However, the file is "in use".
When RPG uses a java method, RPG invokes the JVM and the JVM "opens" the
files. The JVM doesn't need the jar file anymore after the class andobject
are instantiated in memory and might close it, except for garbagejob.
collection. The JVM must hold a lock on the jar file as long as it is
running as it might need to read the class from the jar again if garbage
collection has removed the class object when RPG needs to build a new
instance.
Depending on the operating system level, the jvm may run in a separate
In any case it is a unique thread or threads whether in the same job asthe
RPG or in its own job. All the stuff that connects the RPG to the jvm isin
an activation group. If you have the RPG program running in someactivation
group outside the default activation group, the jvm-glue probably runs inagain.
the same activation group. If your RPG program is running in the default
activation group all that glue is probably in its own activation group. I
say probably here, because I'm reporting behavior as I see it; I don't
actually have documentation on this.
So my take on how to do the upgrade you describe would be to have the CL
that runs the RPG program end the activation group that contains the RPG
program; do the jar file replaces; then start the RPG program back up
This should work in just about all operating systems and versions of java.[mailto:java400-l-bounces@xxxxxxxxxxxx]
Anyone else care to contribute?
-----Original Message-----
From: java400-l-bounces@xxxxxxxxxxxx
On Behalf Of Anna Abtand
Sent: Monday, November 01, 2010 4:07 PM
To: 'Java Programming on and around the IBM i'
Subject: RE: .jar files in use on a restore
There was no OS upgrade or PTF applied on our systems since the problem
started, I do not know about clients. We run v5r3, v5r4, and v5r6 here
support back to v5r2 for our customer base. RPG invokes the jvm and setsrpg
the class path and environmental variables and begins and ends the object
group. RPG calls the methods within an instantiated object. Before any
upgrades locks on all rpg objects are checked and the upgrade will not
continue if it cannot allocate all objects. The basic processing on the
side has been the same for a number of years. Some java methods were[mailto:java400-l-bounces@xxxxxxxxxxxx]
connecting to the iSeries for data retrieval.
-----Original Message-----
From: java400-l-bounces@xxxxxxxxxxxx
On Behalf Of Dan Kimmelmore
Sent: Monday, November 01, 2010 4:28 PM
To: Java Programming on and around the IBM i
Subject: RE: .jar files in use on a restore
I think the connection pool is a red herring. The problem probably has
to do with an OS upgrade or PTF applied in the last year. I'd need to knowa
lot more to offer any other suggestions. What OS version? What kind ofin
programs use the jar files? How is the jvm invoked? Where does the rpg
program enter the picture? Is the rpg program calling methods on objects
the jar files? Do you stop all instances of the rpg program before[mailto:java400-l-bounces@xxxxxxxxxxxx]
attempting to replace the jar files?
-----Original Message-----
From: java400-l-bounces@xxxxxxxxxxxx
On Behalf Of Anna Abtstate.
Sent: Monday, November 01, 2010 2:38 PM
To: java400-l@xxxxxxxxxxxx
Subject: .jar files in use on a restore
Recently we have run into an issue when trying to run upgrades of our
software. I have a clle program that does a restore to an ifs directory
with new .jar files. There have been instances lately where objects have
not been restored because they are in use. Speaking with our java
programmers I did learn that there was a change made in the past year to
create a connection pool and keep it open for a longer period of time for
performance enhancing reasons. Doing some testing, we removed the
connection and are now sending the data from the rpg programs to the java
methods. We are still finding that the .jar files stay in a "in use"
Can anyone tell me how we might get around this or why this seems to beof
happening all of a sudden? We even did a simple test adding a classpath
3 .jar files and running 2 programs, the first opens a connection andprints
and the second closes the connection. Those 3 files still are in use andsignature
unable to run a restore against.
--
This is the Java Programming on and around the IBM i (JAVA400-L) mailing
list To post a message email: JAVA400-L@xxxxxxxxxxxx To subscribe,
unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/java400-l
or email: JAVA400-L-request@xxxxxxxxxxxx Before posting, please take a
moment to review the archives at http://archive.midrange.com/java400-l.
--
This is the Java Programming on and around the IBM i (JAVA400-L) mailing
list To post a message email: JAVA400-L@xxxxxxxxxxxx To subscribe,
unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/java400-l
or email: JAVA400-L-request@xxxxxxxxxxxx Before posting, please take a
moment to review the archives at http://archive.midrange.com/java400-l.
__________ Information from ESET NOD32 Antivirus, version of virus
database 5583 (20101101) __________signature
The message was checked by ESET NOD32 Antivirus.
http://www.eset.com
--
This is the Java Programming on and around the IBM i (JAVA400-L) mailing
list To post a message email: JAVA400-L@xxxxxxxxxxxx To subscribe,
unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/java400-l
or email: JAVA400-L-request@xxxxxxxxxxxx Before posting, please take a
moment to review the archives at http://archive.midrange.com/java400-l.
--
This is the Java Programming on and around the IBM i (JAVA400-L) mailing
list
To post a message email: JAVA400-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/java400-l
or email: JAVA400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/java400-l.
__________ Information from ESET NOD32 Antivirus, version of virus
database 5584 (20101102) __________signature
The message was checked by ESET NOD32 Antivirus.
http://www.eset.com
--
This is the Java Programming on and around the IBM i (JAVA400-L) mailing
list
To post a message email: JAVA400-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/java400-l
or email: JAVA400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/java400-l.
--
This is the Java Programming on and around the IBM i (JAVA400-L) mailing
list
To post a message email: JAVA400-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/java400-l
or email: JAVA400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/java400-l.
__________ Information from ESET NOD32 Antivirus, version of virus
database 5585 (20101102) __________list
The message was checked by ESET NOD32 Antivirus.
http://www.eset.com
--
This is the Java Programming on and around the IBM i (JAVA400-L) mailing
To post a message email: JAVA400-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/java400-l
or email: JAVA400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/java400-l.
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.