Skip to content

g--/ecobee-exporter

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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

About

Prometheus exporter utilizing Ecobee API (https://www.ecobee.com/home/developer/api/introduction/index.shtml) to gather thermostat metrics.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 70.4%
  • Shell 27.0%
  • Dockerfile 2.6%