Production-grade ILC installation includes deployment of 3 Docker images:
- ILC
- ILC Registry
- MySQL database (version 5.7+).
!!! tip ""
We recommend using semver Docker tags (such as 1.1.0
) to pin it to the exact version of the image.
To get more information about exact configuration of the Docker images see [docker-compose.yml]({{ repo.full_url }}/docker-compose.yml){: target=_blank} :octicons-link-external-16:
To upgrade ILC to a higher version, you need to replace running Docker images with a new version in the following order: Registry, ILC. In this way, you will always have a new version of ILC running alongside the up-to-date Registry.
In ILC, most of the settings are configurable via Registry UI or API. There is also a set of system parameters that can only be configured via environment variables passed to the Docker container.
Check the full list of these parameters in the following files:
- [ILC container]({{ repo.full_url }}/ilc/config/custom-environment-variables.json5){: target=_blank} :octicons-link-external-16:
- [Registry container]({{ repo.full_url }}/registry/config/custom-environment-variables.ts){: target=_blank} :octicons-link-external-16:
Once you get ILC up and running, you must remove default access credentials and configure your own. Check the Registry: Authentication / Authorization document for more details.
To deploy ILC in HA fashion, you need to keep at least two instances of both ILC and Registry and deploy MySQL in cluster mode (for example, via AWS RDS Multi-AZ).
ILC uses aggressive caching of the data from the Registry, so it does not require a permanent connection to the Registry or a low latency response from the Registry.
As ILC stores all user data in the Registry DB, you can use regular MySQL backup/restore practices.
ILC supports integration with NewRelic APM and NewRelic Browser. It can also send custom metric to NewRelic Insights.
To enable the integration, you need to pass your NewRelic license key in NR_LICENSE_KEY
environmental variable to ILC and Registry containers.
If you have the NewRelic Browser enabled, you can wrap JavaScript code that NewRelic generates using the NR_CUSTOM_CLIENT_JS_WRAPPER
environmental variable. This approach may be useful for compliance with GDPR customer settings.
For example:
<script type="text/javascript">(function mygdprWrapper(){ %CONTENT% })()</script>`
Custom metrics sent to Insights:
- PageAction with Action Name
routeChange
. It contains the duration of the reroute in miliseconds.