Skip to content

Latest commit

 

History

History
140 lines (111 loc) · 4.83 KB

README.md

File metadata and controls

140 lines (111 loc) · 4.83 KB

ecobee_exporter

Docker Pulls Docker Automated Docker Build

Lots of references from: https://github.com/dichro/ecobee

Check him out as well, initial idea from his repository.

Summary

Ecobee exporter for metrics in Prometheus format

Setting up an ecobee exporter is complicated due to the need to authenticate with the Ecobee API service via tokens. The first time you run this program it requires some manual steps, however the exporter will subsequently manage its own authentication afterwards if you give the program a volume somewhere to store passwords and manage it's authorization cache.

First time running ecobee exporters, read this

  1. Create a volume on your host so we can persist authentication cache

  2. Run docker run -v <volume from step 1>:/db -p 9098:9098 -it billykwooten/ecobee-exporter --appkey p3NbLx6iSYTjXDFHIMtM77SWWPLRuEZ0

  3. Open a browser and go to http://localhost:9098/metrics or curl -X GET http://localhost:9098/metrics from another terminal

  4. Docker will now print a pin like Pin is "ig7j"

  5. Go to https://www.ecobee.com/consumerportal/index.html#/my-apps

  6. Register your app pin from step 4

  7. You can now run the container in any way you want, as long as you mount in the volume from step 1.

    Example: Binary/Docker Run Examples

Configuration

Ecobee exporter can be controlled by both ENV or CLI flags as described below.

Environment CLI (--flag) Default Description
ECOBEE_LISTEN_ADDRESS listen-address :9098 The port for /metrics to listen on
ECOBEE_APPKEY appkey p3NbLx6iSYTjXDFHIMtM77SWWPLRuEZ0 Your Application API Key or you can use my app key seen here
ECOBEE_CACHEFILE cachefile /db/auth.cache Cache file to store auth credentials

Usage

Binary Usage

# Export ecobee metrics from thermostat
./ecobee-exporter

Docker Usage (recommended method of running)

# Export ecobee metrics from thermostat using docker with volume for cache
docker run -d --restart always --name=ecobee-exporter -v /example/persistancedirectory:/db -p 9098:9098 billykwooten/ecobee-exporter --appkey p3NbLx6iSYTjXDFHIMtM77SWWPLRuEZ0

Docker-compose Usage

  ecobee-exporter:
    image: billykwooten/ecobee-exporter
    container_name: ecobee-exporter
    restart: always
    ports:
      - "9098:9098"
    volumes:
      - /volume1/docker/ecobee-exporter/data:/db

Prometheus Scrape Usage

scrape_configs:
  - job_name: 'ecobee-exporter'
    scrape_interval: 60s
    static_configs:
      - targets: ['ecobee-exporter:9098']

Metrics

Current

  • ecobee_actual_temperature (F)
  • ecobee_aux_heat1
  • ecobee_aux_heat2
  • ecobee_aux_heat3
  • ecobee_comp_cool1
  • ecobee_comp_cool2
  • ecobee_currenthvacmode
    • current_hvac_mode="cool"
  • ecobee_equipment_running
  • ecobee_fan
  • ecobee_fetch_time
  • ecobee_heat_pump1
  • ecobee_heat_pump2
  • ecobee_humidity
  • ecobee_in_use
  • ecobee_occupancy
  • ecobee_target_temperature_max (F)
  • ecobee_target_temperature_min (F)
  • ecobee_temperature (F)

Proposed

All temperatures would have both _celsius and _fahrenheit suffixes.

  • ecobee_device_info
    • name
    • model
    • s/n
  • ecobee_exporter_info
    • version
  • ecobee_outside_temperature_celsius
  • ecobee_sensor_in_use (0 or 1) -- sensor is part of the active comfort setting, ie eligable to be part of the combined temperature
    • name
  • ecobee_combined_temperature_celsius -- synthetic temperature ecobee makes by combining sensors of occupied rooms
  • ecobee_sensor_temperature_celsius
    • name
  • ecobee_occupancy_detected (0 or 1)
    • name
  • ecobee_equipment_running (0 or 1)
    • name
  • ecobee_setpoint_cooling_celsius
  • ecobee_setpoint_heating_celsius
  • ecobee_currenthvacmode
    • current_hvac_mode="cool"
  • ecobee_fetch_time 0.150490171
  • ecobee_humidity
    • name

Missing:

  • something indicating the system is on hold because windows are open
  • window sensors

Development

If you'd like to build this yourself you can clone this repo and run:

./script/cibuild