Error's when updating server

Hi devs,

We have been hosting a large number of sites since 2015 but we have found in the last year that the servers have developed two issues.

Firstly we are finding that lucee service sometimes (often) will completely die if we change anything in the server admin panel (for example editing a datasource or changing the performance/caching config).

The symptoms evinced are:

  1. the lucee admin panel hangs on the save
  2. requests to all of the the sites result in timeouts
  3. whenever it happens we look into the logs and find these things:

“Apache Native” warnings in the catalina.out

04-Jul-2018 11:09:46.186 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: /usr/java/packages/lib/amd64:/usr/lib64:/lib64:/lib:/usr/lib

[mod_cfml] ERROR (sent to client): 503: Time Between Contexts has not been fulfilled. Please wait a few moments and try again.

04-Jul-2018 11:09:38.218 WARNING [127.0.0.1-startStop-2] org.apache.catalina.loader.WebappClassLoaderBase.clearReferencesThreads The web application [ROOT] appears to have started a thread named [FelixDispatchQueue] but has failed to stop it. This is very likely to create a memory leak. Stack trace of thread:

04-Jul-2018 11:09:38.218 WARNING [127.0.0.1-startStop-2] org.apache.catalina.loader.WebappClassLoaderBase.clearReferencesThreads The web application [ROOT] appears to have started a thread named [FelixFrameworkWiring] but has failed to stop it. This is very likely to create a memory leak. Stack trace of thread:

04-Jul-2018 11:09:38.219 WARNING [127.0.0.1-startStop-2] org.apache.catalina.loader.WebappClassLoaderBase.clearReferencesThreads The web application [ROOT] appears to have started a thread named [FelixStartLevel] but has failed to stop it. This is very likely to create a memory leak.

At this point we have to stop and start the lucee_ctl service and then the second problem happens.

LUCEE ERRORS ON APPLICATIONS STARTING

The applications all error in the first few responses. It is as if Lucee is trying to serve pages when it had not finished firing up the application.

A refresh or two and the servers run veru smoothly until the next time we touch the config.

A common error is the one below where lucee can not even process an include without erroring:

The Error Occurred in
/var/www/html/some-installation/some-website/Application.cfc: line 4
2:
3: // pull in boilerplate
4: include “…/application-base.cfm”;
5:
6: // called by the application-base code

called from /var/www/html/some-installation/some-website/Application.cfc: line 1
Java Stacktrace lucee.runtime.exp.NativeException: String index out of range: -18
at java.lang.String.substring(String.java:1931)
at lucee.runtime.PageSourceImpl.getPhyscalFile(PageSourceImpl.java:480)
at lucee.runtime.PageSourceImpl.loadPhysical(PageSourceImpl.java:290)
at lucee.runtime.PageSourceImpl.loadPageThrowTemplateException(PageSourceImpl.java:219)
at lucee.runtime.PageSourceImpl.loadPage(PageSourceImpl.java:946)
at lucee.runtime.PageContextImpl._doInclude(PageContextImpl.java:934)
at lucee.runtime.PageContextImpl._doInclude(PageContextImpl.java:833)
at lucee.runtime.PageContextImpl.doInclude(PageContextImpl.java:817)
at application_cfc$cf.initComponent(/Application.cfc:4)
at application_cfc$cf.newInstance(/Application.cfc:1)
at lucee.runtime.component.ComponentLoader.initComponent(ComponentLoader.java:556)
at lucee.runtime.component.ComponentLoader._loadComponent(ComponentLoader.java:493)
at lucee.runtime.component.ComponentLoader.loadComponent(ComponentLoader.java:377)
at lucee.runtime.listener.ModernAppListener._onRequest(ModernAppListener.java:112)
at lucee.runtime.listener.MixedAppListener.onRequest(MixedAppListener.java:43)
at lucee.runtime.PageContextImpl.execute(PageContextImpl.java:2405)

Some notes on the servers

The servers in question are:
3 servers all clones of each other load balanced through HAproxy.

Ubuntu 1404
28GB RAM
2 Cores
5GB+ free of disk space
45+ medium-traffic websites (haproxy reports each server handling about 50K sessions an hour)
45+ low traffic CMS applications
Apache 2
Lucee 5.2.5.20 (upgrade being tested, before you mention it )
Remote Mysql 5.5 DB cluster

Has anyone seen this before?

Could it be we have too many applications on the same host? when we are not changing any configs the servers tend to be pretty stable the issues seem to only occur once we make a change in the admin panels.

Many thanks for any input

Regards, all

VerseOne