How are you monitoring this usage?
I ask since you mention "85% used physical memory".
A few notes:
- No Java server process, Windchill or otherwise, should be configured in such a way that its memory may end up being swapped between physical and virtual memory. JVM heaps swap very badly and performance will be really awful.'
- For most cases the important thing to look at with JVMs is the heap allocation. And there the important thing to look at is the memory usage after garbage collection. If you look at memory usage prior to garbage collection, then you really don't learn much. You know that at most the amount of memory usage reported is being used -- but you have literally no idea how much of that is actually being referenced vs. how much would be quickly freed upon a garbage collection. Thus for Java and Windchill's JMX statistics and thresholds, the most critical ones are those with "Coll" in their names -- as these indicate statistics and thresholds after a garbage collection. As for overall heap statistics, the only real ways to get information on heap usage after a garbage collection are to (a) force one and then examine the heap usage immediately thereafter or (b) enable GC logging and read the GC logs. If you disable explicit GC, then you disable approach (a) and a number of mechanisms in Windchill that are intended to deal with low memory situations.
- Generally speaking if you're not seeing a substantial percentage of time being spent in garbage collection and not running out of memory upon any operation, then you're okay as far as memory is concerned. Of course the question is if you don't have a good amount of free JVM heap at idle, then how many requests and of what size of operations can you expect to handle before running into such issues.
- As far as clearing memory without shutting down the server, there's no real way to do this. You could invoke an explicit GC (again assuming you've not disabled this) via a JMX client like VisualVM or JConsole, but that just frees memory that the JVM itself would have freed when it needed more memory. Memory not freed by garbage collection is not freed because something is referencing and thus using it. If it isn't really necessary, then it should not be referenced/used. If the amount of memory used continues to grow without a plateau, then that would seem to indicate a memory leak -- and the only real way to get to the bottom of this is to force a heap dump [ideally when the system is idle in this case] and then analyze this (or, more likely, get PTC technical support to analyze this).
- PermGen memory usage should generally grow only when the Java process in question uses classes (and thus features/functionalities) that it hasn't used yet. This tends to grow slowly after initial startup and plateau over time. You can run this quite close to full -- as long as you never actually get an OutOfMemoryError due to perm gen. The out-of-the-box perm gen sizing is intended to suffice, though it may not in cases.
Sorry to be long-winded, but I think that pretty well covers it.