Quick Start for Docker & Images

The following guide will walk you through the necessary steps to install, configure, and run the Data Collectors and the Time Series Historian for Docker.

Install Docker and Download Images

Docker Compose

Docker Run

Verify the Containers are Running

Access the UI Pages

Create Logging Session

Verify Your Data

Additional Information

 


Install Docker and Download Images

  • If you don't have Docker installed, download and install it from the Docker website: Docker Installation Guide
  • Visit Docker Hub and pull the Timebase images for Time Series Historian and Collector

Timebase images Docker Hub

 


Docker Compose

The quickest way to get started is to edit and run the following Docker Compose file. It will create and run two containers, one for the Time Series Historian and one for a Collector.

  • Create a "docker-compose.yml" file with the following contents:

For Linux

name: timebase

services:  
  historian:
  image: timebase/historian:latest
    deploy:
      resources:
        limits:
        cpus: "2"
          memory: 4096m
    hostname: historian
    container_name: historian
    ports:
      - "4511:4511"
    restart: unless-stopped
    volumes:
      - ./timebase.historian.data:/data
      - ./timebase.historian.logs:/logs

  explorer:
  image: timebase/explorer:latest
    deploy:
      resources:
        limits:
        cpus: "2"
          memory: 2048m
    hostname: explorer
    container_name: explorer
    ports:
      - "4531:4531"
    restart: unless-stopped
    volumes:
      - ./timebase.explorer.config:/config
      - ./timebase.explorer.logs:/logs

  simulator:
  image: timebase/collector:latest
    deploy:
      resources:
        limits:
        cpus: "2"
          memory: 2048m
    hostname: simulator
    container_name: simulator
    ports:
      - "4521:4521"
    restart: unless-stopped
    depends_on:
      historian:
        condition: service_started
    volumes:
      - ./timebase.collectors.simulator.config:/config
      - ./timebase.collectors.simulator.data:/data
      - ./timebase.collectors.simulator.logs:/logs
    environment:
      - Active=false

  mqtt:
  image: timebase/collector:latest
    deploy:
      resources:
        limits:
        cpus: "2"
          memory: 2048m
    hostname: mqtt
    container_name: mqtt
    ports:
      - "4522:4521"
    restart: unless-stopped
    depends_on:
      historian:
        condition: service_started
    volumes:
      - ./timebase.collectors.mqtt.config:/config
      - ./timebase.collectors.mqtt.data:/data
      - ./timebase.collectors.mqtt.logs:/logs
    environment:
      - Active=false

  sparkplugB:
  image: timebase/collector:latest
    deploy:
      resources:
        limits:
        cpus: "2"
          memory: 2048m
    hostname: sparkplugB
    container_name: sparkplugB
    ports:
      - "4523:4521"
    restart: unless-stopped
    depends_on:
      historian:
        condition: service_started
    volumes:
      - ./timebase.collectors.sparkplugb.config:/config
      - ./timebase.collectors.sparkplugb.data:/data
      - ./timebase.collectors.sparkplugb.logs:/logs
    environment:
      - Active=false

 

For Windows

name: timebase

services:  
  historian:
    image: timebase/historian:latest
    deploy:
      resources:
        limits:
          cpus: "2"
          memory: 4096m
    hostname: historian
    container_name: historian
    ports:
      - "4511:4511"
    restart: unless-stopped
    volumes:
      - C:\Timebase Docker\Historian\Data:/data
      - C:\Timebase Docker\Historian\Logs:/logs

  explorer:
    image: timebase/explorer:latest
    deploy:
      resources:
        limits:
          cpus: "2"
          memory: 2048m
    hostname: explorer
    container_name: explorer
    ports:
      - "4531:4531"
    restart: unless-stopped
    volumes:
      - C:\Timebase Docker\Explorer\Config:/config
      - C:\Timebase Docker\Explorer\Logs:/logs

  simulator:
    image: timebase/collector:latest
    deploy:
      resources:
        limits:
          cpus: "2"
          memory: 2048m
    hostname: simulator
    container_name: simulator
    ports:
    - "4521:4521"
    restart: unless-stopped
    depends_on:
      historian:
        condition: service_started
    volumes:
      - C:\Timebase Docker\Collectors\The Juice Factory\Config:/config
      - C:\Timebase Docker\Collectors\The Juice Factory\Data:/data
      - C:\Timebase Docker\Collectors\The Juice Factory\Logs:/logs
    environment:
      - Active=false
  
   MQTT:
    image: timebase/collector:latest
    deploy:
      resources:
        limits:
          cpus: "2"
          memory: 2048m
    hostname: MQTT
    container_name: MQTT
    ports:
    - "4522:4521"
    restart: unless-stopped
    depends_on:
      historian:
        condition: service_started
    volumes:
      - C:\Timebase Docker\Collectors\MQTT\Config:/config
      - C:\Timebase Docker\Collectors\MQTT\Data:/data
      - C:\Timebase Docker\Collectors\MQTT\Logs:/logs
    environment:
      - Active=false
  
   OPCUA:
    image: timebase/collector:latest
    deploy:
      resources:
        limits:
          cpus: "2"
          memory: 2048m
    hostname: OPCUA
    container_name: OPCUA
    ports:
    - "4523:4521"
    restart: unless-stopped
    depends_on:
      historian:
        condition: service_started
    volumes:
      - C:\Timebase Docker\Collectors\OPCUA\Config:/config
      - C:\Timebase Docker\Collectors\OPCUA\Data:/data
      - C:\Timebase Docker\Collectors\OPCUA\Logs:/logs
    environment:
    - Active=false

This file assumes you are running on a Windows environment and will link to volumes on your Windows host. Note there is one volume for the Historian's data, three volumes for the Collector's configuration and store and forward files, and one volume for Explorer's trend configuration storage. If you are running on a Linux environment, be sure to modify these volume paths.

  • Through a Command Prompt, or Terminal, browse to the location of your "docker-compose.yml" file and run the following command:

docker compose -f docker-compose.yml up --detach

 

Docker Run

  • Alternatively, using Docker Run, you can start your containers individually as follows:

docker run -d --name=historian -p 4511:4511 timebase/historian

docker run -d --name=collector -p 4521:4521 timebase/collector

docker run -d --name=explorer -p 4531:4531 timebase/explorer

 

⚠️ Make sure to mount and persist your data and config files.

These Docker Run commands will not setup volumes external to the containers. If you delete the containers, your data will be lost. Please consult the Docker Documentation to create and mount external volumes as is done by the above Docker Compose method.

 

Verify the Containers are Running

  • To confirm both the Time Series Historian and Collector containers are running, execute the following command:
docker ps
  • You should see the containers named historian, collector, and explorer listed as follows:

Note that a Collector will only connect to one data source (e.g. MQTT Broker). To connect your Time Series Historian to multiple data sources, you can create additional Collector containers and configure them accordingly.

 


Access the UI Pages

Once running, the Time Series Historian and each Collector instance have their own Administration pages:

 

Create Logging Session

By Default, the Collector will "spin up" the Simulator Plugin and Simulate the "Juice Factory" Filling process as a start. You can change your Data Source Type to OPC UA, MQTT, or Sparkplug.

 


Verify Your Data

Use Explorer Trending or the Time Series Historian API to access your datasets, tags and data being stored in the Historian

 


Additional Information

 


 

Support Assistance

Struggling? We are here to help and will support you. Please log your ticket and we will respond via email.

Submit your ticket.