eZFind Java eating a lot of memory

Author Message

Jacobi Jacobi

Thursday 24 June 2010 5:25:13 am

Hello,

I found two Java jobs in back end eating a lot of memory which make the system very slow, they should be related to ez Find:

1) /bin/bash -c ulimit -S -c 0 >/dev/null 2>&1 ; nohup /usr/bin/java -jar start.jar
2) /usr/bin/java -jar start.jar
 

Any idea what are the purpose of these two Java jobs in back end?

Can I kill them or restart them?

Is there any way to check if this is caused by DB error or Lock error? 

Gaetano Giunta

Thursday 24 June 2010 7:24:57 am

This is the solr indexing engine - used by ezfind. It is normal that it uses quite a lot of memory (and cpu too).

If you stop it, search will not work on your site - unless you deactivate ezfind too.

ps: it is one job, not two - one is the shell launching the other one.

Principal Consultant International Business
Member of the Community Project Board

Ali Nebi

Friday 25 June 2010 5:39:24 am

Hi,

we experienced such problems long time ago. In our analysis we found several things to make solr job faster and less resources consuming.

First of all we needed to set the following parameters in init script when we start solr:

-Dezfind -server -Xms150m -Xmx150m -XX:+UseParallelGC -XX:+AggressiveOpts -XX:NewRatio=5

If your server is 64bits and java version supports 64bits, then you should set above: -server -d64

Usually the problem with memory usage and solr failing is related with java garbage collector and its resources usage.

The other thing i tuned is solrconfig.xml file. There are several section to tune:

- mergeFactor
- ramBufferSizeMB
- maxFieldLength
You can take a look in solr official site for more info how to tune those values and how they affect resources usage and indexing speed.

The other very very important, maybe most important thing that we found was that solr was looping when it was trying to index object relation attributes. It was going in loop and was keeping solr and java to use much more resources than usual.

It is necessary to disable indexing for object relation attributes or to limit indexing level so solr cannot go in loop.

We also have experienced problems when $useFork variable was different then 'false'. When we was runing indexing this way, then java process was stopping to work after some time and wasn't complete its job.

So we continue to use useFork='false' for now.

I hope this will help you to solve your problems.

Best regards, Ali Nebi!

Iguana Information Technologies, SL - http://www.iguanait.com

Gaetano Giunta

Thursday 28 July 2011 11:30:08 pm

Note: according to the solr wiki (http://lucene.apache.org/solr/ ), using -XX:+AggressiveOpts is dangerous with a version 6 jre

Principal Consultant International Business
Member of the Community Project Board

Ali Nebi

Friday 29 July 2011 1:27:50 am

Hi, Gaetano.

Thanks for the note. I didn't know that until know. I will keep this in mind and follow the threads for this.

Iguana Information Technologies, SL - http://www.iguanait.com

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 17 2025 23:46:18
Script start
Timing: Jan 17 2025 23:46:18
Module start 'layout'
Timing: Jan 17 2025 23:46:18
Module start 'content'
Timing: Jan 17 2025 23:46:18
Module end 'content'
Timing: Jan 17 2025 23:46:18
Script end

Main resources:

Total runtime0.0149 sec
Peak memory usage2,048.0000 KB
Database Queries3

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0056 589.0469152.6250
Module start 'layout' 0.00560.0031 741.671939.4453
Module start 'content' 0.00870.0043 781.117293.3047
Module end 'content' 0.01300.0019 874.421938.3047
Script end 0.0149  912.7266 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.002415.8802140.0002
Check MTime0.00117.1266140.0001
Mysql Total
Database connection0.00074.555910.0007
Mysqli_queries0.002818.612430.0009
Looping result0.00000.128010.0000
Template Total0.001610.610.0016
Template load0.00095.803710.0009
Template processing0.00074.757510.0007
Override
Cache load0.00063.965610.0006
General
dbfile0.00031.793380.0000
String conversion0.00000.168040.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0001 secs