Configuring Docker Images via Environment Parameters
To customize the Simplifier Container (simplifierag/simplifier) there are following options provided:
Docker Environment Parameter | Default Value | Example Value | Description |
DB |
mysql | RDBM type for the main Simplifier database and the plugin databases.
Supported values are “mysql” and “oracle” |
|
MYSQL_HOST |
simplifier-mysql.example.com | Hostname of the database server for the main Simplifier database | |
MYSQL_PORT |
3306 | 3306 | Port of Database Server for the main Simplifier database |
MYSQL_USER |
simplifier | Username of Database Connection Credentials for the main Simplifier database | |
MYSQL_PASSWORD |
MyC0mPle!Pa$$word | Password of Database Connection Credentials for the main Simplifier database | |
MYSQL_DB |
simplifier | Database Name for the main Simplifier Database, used as prefix for plugin databases | |
MONITORING_DBMS |
mysql | Only mysql is supported as monitoring database | |
MONITORING_DB |
Database Name for the monitoring database | ||
MONITORING_DB_HOST |
Hostname of the MySQL server for the monitoring database | ||
MONITORING_DB_USER |
Username for the monitoring database | ||
MONITORING_DB_PASS |
Password for the monitoring database | ||
MONITORING_DB_PORT |
Port for the monitoring database | ||
MONITORING_DB_JDBC_URL |
Alternativly to the single values, you can provide one complete jdbc URL to connect to the monitoring database | ||
PLUGINLIST |
jsonStore,keyValueStorePlugin | Comma Separated Lists of Plugins which should be started | |
VIRTUAL_HOST |
mysimplifier.mycompany.de | DNS Name of Simplifier | |
JVM_PARAMETER |
-Xmx16g
-Xms2g -XX:MaxMetaspaceSize=512m -XX:+UseG1GC -XX:+UseStringDeduplication -XX:-UseGCOverheadLimit -Xss256m |
JVM Settings for Simplifier service | |
CLUSTER_MEMBER_NAME |
NODE_1 | If set, cluster member name of simplifier server, else ignored | |
JMX_AGENT |
true or false | ||
FIREBASE_SETTINGS_PATH |
file path to configure a custom Firebase account used for push notififications | ||
ENV_STATISTICS_EVENT_WRITTEN_BUFFER_HOURS |
Number of Hours that are used as a buffer for statistic aggregation. | ||
FEATURE_SSBO_JS_DEBUGGING |
false | true or false
If set to true, experimental feature for debugging server side business objects is activated. Available since Release 8 EHP 2 |
|
FEATURE_LEGACY_OPCUA |
false | true or false
If set to true, legacy OPC UA connector is available in Connector overview. Available since Release 8 EHP 2 |
|
SYSADMIN |
false | true or false
If set to true, the sysadmin ipc channel is opened. Some admin tasks can then be started via CLI |
|
DEBUG_CHROME_DEV_TOOLS_EXPOSED_HOST |
If FEATURE_SSBO_JS_DEBUGGING is set to true:
this must be set to the domain name used for debugging. In most cases this is the same value as VIRTUAL_HOST |
||
DEBUG_CHROME_DEV_TOOLS_EXPOSED_PORT |
2992 | If FEATURE_SSBO_JS_DEBUGGING is set to true:
The optional exposed port that will be used for generation the chrome dev-tools link. |
|
DEBUG_CHROME_DEV_TOOLS_PORT |
2992 | If FEATURE_SSBO_JS_DEBUGGING is set to true:
The port that is opened for the chrome dev-tools to connect to. |
To customize the Workflow Runtime Container (simplifierag/workflow-runtime) there are following options provided:
Docker Environment Parameter | Default Value | Example Value | Description |
DB_USER |
simplifier | Username to access the Workflow Runtime Database | |
DB_PASS |
simplifier | Password to access the Workflow Runtime Database | |
DB_DATABASE |
simplifier_wf_rt | Name of the Workflow Runtime Database | |
DB_HOST |
mysql | Hostname of the MySQL Database Server | |
DB_PORT |
3306 | 3306 | Portnumber of the MySQL Database Server |
SIMPLIFIER_HOST |
my-simplifier | Internal Container-Name of the Simplifier Server | |
SECOND_SEED |
my-launchpad | Internal Container-Name of the Simplifier Launchpad Container | |
MODULE_HOST |
my-workflow-runtime | Container Name of this workflow runtime container | |
JVM_PARAMETER |
-Xmx1g | JVM Heap-Space for the Workflow Runtime – Default 1 GB | |
TZ |
Europe/Berlin | Actual Time Zone to ensure the correct server time | |
ARCHIVE_ENABLED |
true | Activate the Archive Jobs for Workflow Runtime Logs | |
ARCHIVE_INTERVAL |
1 week | 1 week | Period of time that defines how often should the archive Job run |
ARCHIVE_TIME |
2:00 | 2:00 | Daytime when the Job should be executed |
ARCHIVE_MAX_AGE_COMPLETED |
6 months | 6 months | Duration after a completed or terminated workflow instance will be archived automatically |
SIMPLIFIER_LAUNCHPAD_BASE_URL |
https://my-simplfiier.company.org | Full external access URL to Simplifier Inbox / Launchpad . Per Default this is the same as Simplifier Public URL | |
MAX_ACTIVITY_EXECUTION_COUNT |
1000 | 1000 | Available since Release 8 EHP 1 |
DATABASE_MAX_CONNECTIONS |
100 | 100 | |
DATABASE_THREADS |
20 | 20 |
Maximum Database Threads. Increase this default value if Simplifier Support recommends it.
|
DATABASE_QUEUE_SIZE |
1000 | 1000 | Available since Release 8 EHP 1 Maximum Size of Database Queue |
The following plugins are contained in the simplifier docker image
Plugin Name | Description | Documentation |
keyValueStorePlugin |
No-SQL Database for storing Key Values | KeyValueStore |
pdfPlugin |
PDF Designer and Generator for Forms or Reports | PDFPlugin |
wordGeneratorPlugin |
Word Generator | |
captcha |
Generates Captchas for Login Protection | captcha |
contentRepoPlugin |
Meta Repository for Files | contentRepo |
jsonStore |
NoSQL Database based on MapDB | jsonStore |
When transferring data among networked systems, trust is a central concern. In particular, when communicating over an untrusted medium such as the internet, it is critical to ensure the integrity and the publisher of all the data a system operates on. You use the Docker Engine to push and pull images (data) to a public or private registry. Content trust gives you the ability to verify both the integrity and the publisher of all the data received from a registry over any channel.
Docker Content Trust is a feature in the Docker containerization platform that enables remote registry content to be digitally signed, ensuring that the content is unaltered and is the most current available version when users access it. It works via cryptographic keys. Docker Content Trust was introduced in Docker Engine with version 1.8.
Docker Content Trust adds security controls that verify the integrity of container images — the container files that hold application components and content — stored in a registry, such as Docker Hub. Enterprise developers and other users can push or pull (upload or download) container images to a registry. Docker Content Trust addresses two concerns with registries. Users might upload a container image infiltrated with malware, and the users accessing it from that remote repository cannot determine its integrity. And secondly, users can put outdated containers on a registry, which creates interoperability, compatibility or performance problems for the business. In Docker parlance, a repository is a collection of container images with the same name, distinguished by tags, placed in the registry.
When a publisher pushes a container image to a remote registry, Docker Engine applies a cryptographic signature to the container image, using the publisher’s cryptographic key. The signed image can be pulled from the registry by users, at which point Docker Engine uses the original publisher’s public key to verify it is the same. This key check only verifies that the image is the original file, unaltered. Docker Content Trust does not certify the suitability or performance of a container for any particular task. It is possible to pull a verified container image, only for that container to generate errors or perform poorly because it is not production-ready. A user can still upload a malicious container image, and Docker Content Trust will sign the image. Public registry and repository users still bear the responsibility to test and vet a container image.
DCT Components
Docker Content Trust security advantages
The verification system helps guard against man-in-the-middle attacks, as it prevents an attacker from secretly forging or tampering with content. DCT also prevents replay attacks, wherein valid actions are copied and replayed by attackers to fool a system. For example, DCT timestamps prevent attackers from passing off older (typically compromised) images from being passed off as most recent. The TUF framework and use of multiple keys allow DCT to guard the system against tagging key compromise, and allow publishers to change tagging keys on demand, without disrupting users.
Docker designed the Content Trust feature to be unobtrusive for developers that upload images and the people who use this content. Content publishers do not have to learn new commands, or change workflows, but they do need to create and manage keys. Users are completely insulated from the digital signage system, and can use the same push, pull, build, run and other commands as they would without Docker Content Trust.
Check Signature of Simplifier Image
To verify the Image you can run the below command
docker trust inspect --pretty simplifierag/runtime:6.5
If the Docker Image is one of the original simplifier image, you will get the following output
SIGNER KEYS
simplifier 30aa71c9ab2a
Repository Key: 7a50f4ba027a885a670160d307f02bee85085bffa104c1b200a8d2753d3fd7db
Root Key: 412960d3c77b40d688b37a57acd6a683cf30c5afe0b510f89d10005aafbf20bf