Weather Downloader ingests weather data to cloud buckets, such as Google Cloud Storage (beta).
- Flexible Pipelines:
weather-dl
offers a high degree of control over what is downloaded via configuration files. Separate scripts need not be written to get new data or add parameters. For more, see the configuration docs. - Efficient Parallelization: The tool gives you full control over how downloads are sharded and parallelized (with good defaults). This lets you focus on the data and not the plumbing.
- Hassle-Free Dev-Ops.
weather-dl
and Dataflow make it easy to spin up VMs on your behalf with one command. No need to keep your local machine online all night to acquire data. - Robust Downloads. If an error occurs when fetching a shard, Dataflow will automatically retry the download for you. Previously downloaded shards will be skipped by default, so you can re-run the tool without having to worry about duplication of work.
Note: Currently, only ECMWF's MARS and CDS clients are supported. If you'd like to use
weather-dl
to work with other data sources, please file an issue (or consider making a contribution).
usage: weather-dl [-h] [-f] [-d] [-l] [-m MANIFEST_LOCATION] [-n NUM_REQUESTS_PER_KEY] [-p PARTITION_CHUNKS]
[-s {in-order,fair}]
config [config ...]
Weather Downloader ingests weather data to cloud storage.
positional arguments:
config path/to/configs.cfg, containing client and data information. Can take multiple configs.Accepts
*.cfg and *.json files.
Common options:
-f, --force-download
: Force redownload of partitions that were previously downloaded.-d, --dry-run
: Run pipeline steps without actually downloading or writing to cloud storage.-l, --local-run
: Run locally and download to local hard drive. The data and manifest directory is set by default to '<$CWD>/local_run'. The runner will be set toDirectRunner
. The only other relevant option is the config and--direct_num_workers
-m, --manifest-location MANIFEST_LOCATION
: Location of the manifest. By default, it will use Cloud Logging (stdout for direct runner). You can set the name of the manifest as the hostname of a URL with the 'cli' protocol. For example,cli://manifest
will prefix all the manifest logs as '[manifest]'. In addition, users can specify either a Firestore collection URI (fs://<my-collection>?projectId=<my-project-id>
), or BigQuery table (bq://<project-id>.<dataset-name>.<table-name>
), ornoop://<name>
for an in-memory location.-n, --num-requests-per-key
: Number of concurrent requests to make per API key. Default: make an educated guess per client & config. Please see the client documentation for more details.-p, --partition-chunks
: Group shards into chunks of this size when computing the partitions. Specifically, this controls how we chunk elements in a cartesian product, which affects parallelization of that step. Default: chunks of 1000 elements for 'in-order' scheduling. Chunks of 1 element for 'fair' scheduling.-s, --schedule {in-order,fair}
: When using multiple configs, decide how partitions are scheduled: 'in-order' implies that partitions will be processed in sequential order of each config; 'fair' means that partitions from each config will be interspersed evenly. Note: When using 'fair' scheduling, we recommend you set the '--partition-chunks' to a much smaller number. Default: 'in-order'.--log-level
: An integer to configure log level. Default: 2(INFO).--use-local-code
: Supply local code to the Runner. Default: False.
Note:
- In case of BigQuery manifest tool will create the BQ table itself, if not already present. Or it will use the existing table but can report errors in case of schema mismatch.
- To run complex queries on the Firestore manifest, users may find it helpful to replicate Firestore to BigQuery using the automated process described in this article. By following the step-by-step instructions, users can easily set up the automated replication and then use BigQuery to perform advanced analysis on the data.
Invoke with -h
or --help
to see the full range of options.
For further information on how to write config files, please consult this documentation.
Usage Examples:
weather-dl configs/era5_example_config_local_run.cfg --local-run
Preview download with a dry run:
weather-dl configs/mars_example_config.cfg --dry-run
Using DataflowRunner
weather-dl configs/mars_example_config.cfg \
--runner DataflowRunner \
--project $PROJECT \
--temp_location gs://$BUCKET/tmp \
--job_name $JOB_NAME
Using DataflowRunner and using local code for pipeline
weather-dl configs/mars_example_config.cfg \
--runner DataflowRunner \
--project $PROJECT \
--temp_location gs://$BUCKET/tmp \
--job_name $JOB_NAME \
--use-local-code
Using the DataflowRunner and specifying 3 requests per license
weather-dl configs/mars_example_config.cfg \
-n 3 \
--runner DataflowRunner \
--project $PROJECT \
--temp_location gs://$BUCKET/tmp \
--job_name $JOB_NAME
For a full list of how to configure the Dataflow pipeline, please review this table.
You can view how your ECMWF API jobs are by visitng the client-specific job queue:
If you use Google Cloud Storage, we recommend using gsutil
(link) to
inspect the progress of your downloads. For example:
# Check that the file-sizes of your downloads look alright
gsutil du -h gs://your-cloud-bucket/mars-data/*T00z.nc
# See how many downloads have finished
gsutil du -h gs://your-cloud-bucket/mars-data/*T00z.nc | wc -l