Skip to main content

Carbon-minimizing task scheduler for Unix systems

Project description

CAS

A Carbon-aware scheduler for Unix jobs
Report Bug · Request Feature · Contribute

About Carbon Aware Scheduler

Carbon Aware Scheduler (CAS) is a command line tool that takes CO2 into account when scheduling jobs. Given a job, this tool will find the best time to run this job based on a model of carbon intensity of the power grid. The amount of CO2 emitted per kWh (the aforementioned carbon intensity) often varies greatly during the day, so smart scheduling can reduce CO2 emissions. The model is based on heuristics and it's currently only available for the Netherlands. The tool is a wrapper around the cron and at tools for scheduling Unix commands.

This tool can help you:

  • Schedule non-urgent jobs at a later time during the day
  • Save CO2 and visualize total CO2 saved
  • Easily manage your cron and at jobs

(back to top)

Built With

This project was built in Python. Its main dependencies are:

The project also imports requests, but we do not actually use it in live code in the project. This is due to us not getting access to the ElectricityMap API in time for this project.

(back to top)

Getting Started

Here are the instructions on getting started with our tool. Whether you want to use this tool to become more environmentally-friendly or simply contribute to a tool that changes the world, you can find the instructions here.

Installation

If you simply want to use the app and benefit from the carbon aware-scheduling, simply run:

pip install carbon-aware-scheduler

Contributing

In order to contribute to this project,

  1. Fork the repo using the web interface or using the gh CLI:

    gh repo fork https://github.com/abel-vs/carbon-scheduler --clone
    
  2. Install the requirements

    pip install -r requirements.txt
    
  3. Make some commits!

  4. Open a Pull Request

(back to top)

Usage

Some useful commands:

  1. Scheduling a one-off job

    $ cas myjob.py --repeat @daily

  2. Scheduling a repeating job

    $ cas myjob.py --at 202204052230

  3. Listing all the scheduled jobs, repeating and one-off jobs

    $ cas --list

  4. Cancelling a repeating job given the index

    $ cas --cancel-repeating 42

  5. Cancelling a one-off job given the index

    $ cas --cancel-one 42

(back to top)

Roadmap

  • Schedule jobs

    • Given estimate of duration and deadline
    • Taking into account carbon intensity of the grid
  • List jobs

    • Combined view of all jobs: one-off and repeating
  • Remove jobs given id of task

  • Implement offline model based on energymap's historical data on energy mix

    • Location set to NL only
    • Use time of the day
    • Use day of the week
    • Use week/month/season of the year
  • Output saved CO2

    • For current session
    • For all sessions
  • Run parallel jobs

  • "Full of batteries basement" flag -> don't use energy data for scheduling

  • Implement online/live model

    • Based on forecasting marginal carbon intensity
  • GUI for non-technical users

  • Windows platform support

  • Extensive testing

  • Consider machine workload

See the open issues for a full list of proposed features (and known issues).

(back to top)

Contact

Wander Siemers - wandersiemers@me.com

Abel Van Steenweghen - Abel.van.steenweghen@gmail.com

Florentin-Ionut Arsene - arsene.florentin.ionut@gmail.com

(back to top)

Acknowledgments

  • Luís Cruz - Assistant Professor at Delft University of Technology

(back to top)

License

Distributed under the MIT License. See LICENSE.txt for more information.

(back to top)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

carbon-aware-scheduler-1.0.1.tar.gz (11.5 kB view hashes)

Uploaded Source

Built Distribution

carbon_aware_scheduler-1.0.1-py3-none-any.whl (13.6 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page