Skip to content

Latest commit

 

History

History
151 lines (110 loc) · 9.4 KB

README.md

File metadata and controls

151 lines (110 loc) · 9.4 KB

cv-ingest-to-lake

Quality Gate Status Coverage

This repository contains lambda function and ECS task code for the Connected Vehicle (CV) Pilot data ingestion pipeline (from the private ingestion buckets to the public ITS Sandbox). For more information on ITS Sandbox data, please refer to the ITS Sandbox README page.

The utilities for working with the ITS Sandbox data and Socrata have been moved to the Sandbox Exporter package. Utilities that have migrated include: Sandbox Exporter, Data Flattener, and Socrata Connector. The pipeline for ingestion from the ITS Sandbox into Socrata has been moved to the cv-lake-to-socrata repository.

Prerequisites

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes. See deployment for notes on how to deploy the project on a live system.

Prerequisites for AWS Lambda Deployment

If you plan to deploy the script on AWS Lambda, you need access to an AWS account and be able to assign role(s) to a lambda function. There needs to be a role that is able to invoke lambda functions and perform list/read/write actions to relevant buckets in S3.

Prerequisites for Local Deployment

If you plan to deploy the script on your local machine, you need the following:

  1. Have access to Python 3.6+. You can check your python version by entering python --version and python3 --version in command line.
  2. Have access to the command line of a machine. If you're using a Mac, the command line can be accessed via the Terminal, which comes with Mac OS. If you're using a Windows PC, the command line can be accessed via the Command Prompt, which comes with Windows, or via Cygwin64, a suite of open source tools that allow you to run something similar to Linux on Windows.
  3. Have your own Free Amazon Web Services account.
  4. Obtain Access Keys:
    • On your Amazon account, go to your profile (at the top right)
    • My Security Credentials > Access Keys > Create New Access Key
    • Record the Access Key ID and Secret Access Key ID (you will need them in step 4)
  5. Save your AWS credentials in your local machine, using one of the following method:

Usage

Installing locally

  1. Download the script by cloning the git repository at https://github.com/usdot-its-jpo-data-portal/cv-ingest-to-lake. You can do so by running the following in command line. git clone https://github.com/usdot-its-jpo-data-portal/cv-ingest-to-lake.git. If unfamiliar with how to clone a repository, follow the guide at https://help.github.com/en/articles/cloning-a-repository.
  2. Navigate into the repository folder by entering cd cv-ingest-to-lake in command line.
  3. Create a virtualenv folder by running virtualenv --python=python3 temp_env/. If you do not have virtualenv installed, you may install it by following the virtualenv installation instruction.
  4. Activate the virtualenv by running source temp_env/bin/activate.
  5. Install the required packages in your virtualenv by running pip install -r src/requirements.txt.

Building

To build the Docker image, run:

docker build -t cv-ingest-to-lake .

To build the image without cache, run:

docker build -t cv-ingest-to-lake . --no-cache

Testing

If this is your first time running tests, run the following line in your command line to install the required packages: pip install coverage "pytest<5"

Run the test by entering the following in command line: coverage run -m pytest

Run coverage report by entering the following in command line: coverage report -m

Deployment

Deployment to AWS Lambda

  1. To prepare the code package for deployment to AWS Lambda, run sh package.sh to build the packages. This will create two zipped files in the repo's root folder: ingest_to_lake.zip.
  2. For each of the lambdas, create a lambda function in your AWS account "from scratch" with the following settings:
    • Runtime: Python 3.8
    • Permissions: Use an existing role (choose existing role with full lambda access (e.g. policy AWSLambdaFullAccess), list/read/write permission to your destination s3 bucket, and full ECS access)
  3. In the configuration view of your lambda function, set the following:
    • For the cv-ingest-to-lake function:
      • In "Function code" section, select "Upload a .zip file" and upload the cv-ingest-to-lake.zip file as your "Function Package."
      • In "Environment variables" section, set the following:
        • TARGET_BUCKET: the destination s3 bucket (sandbox bucket).
          • default set as: usdot-its-cvpilot-public-data
        • ECS_TASK_JSON: Stringified json containing the following information, replacing <values> with your own. {"cluster": , "launchType": "FARGATE", "taskDefinition": , "count": 1, "platformVersion": "LATEST", "networkConfiguration": {"awsvpcConfiguration": {"subnets": , "securityGroups": , "assignPublicIp": "DISABLED"}}, "overrides": {"containerOverrides": []}}
      • In "Basics settings" section, set adequate Memory and Timeout values. Memory of 1664 MB and Timeout value of 10 minutes should be plenty.
      • In "Triggers" section, set the S3 bucket(s) where data provider(s) is depositing data files to trigger on Object Creation.
  4. Make sure to save all of your changes.

Deployment to AWS ECS

Deploy built Docker image to AWS Elastic Container Registry (ECR). Steps 2-5 are also available via AWS Console when you select your ECR repository and click on "View push commands". Replace all reference of $AWS_ACCOUNT_NUMBER with your own AWS account number.

  1. If repository does not exist yet, create repository in AWS Console or using AWS Command Line Tool

  2. Retrieve an authentication token and authenticate your Docker client to your registry.

    aws ecr get-login-password --region us-east-1 | docker login --username AWS --password-stdin $AWS_ACCOUNT_NUMBER.dkr.ecr.us-east-1.amazonaws.com
    
  3. If you've already built your container, tag your image so you can push the image to this repository:

    docker tag cv-ingest-to-lake:latest $AWS_ACCOUNT_NUMBER.dkr.ecr.us-east-1.amazonaws.com/cv-ingest-to-lake:latest
    
  4. Run the following command to push this image to your newly created AWS repository:

    docker push $AWS_ACCOUNT_NUMBER.dkr.ecr.us-east-1.amazonaws.com/cv-ingest-to-lake:latest
    

Note that in the task definition, this container should have the default environment variable TARGET_BUCKET, which is set to the same value as in the lambda function.

Invocation

The lambda function is expected to be invoked code. The ECS task is expected to be invoked by the cv-ingest-to-lake lambda function. In our deployment, the cv-ingest-to-lake is invoked by deposit of data into private S3 ingestion buckets.

Version History and Retention

Status: This project is in the release phase.

Release Frequency: This project is updated irregularly.

Retention: This project will remain publicly accessible for a minimum of five years (until at least 08/19/2026).

Release History

  • 2.0.0
    • Moved sandbox UI html page to sandbox repository.
    • Moved code for ingesting sandbox data to Socrata to cv-lake-to-socrata.
    • Allows the same ingestion code to be deployed and run as an ECS Task and have the lambda function trigger an ECS Task with the triggering event information when data comes from NYCDOT.
    • Rename repostory to cv-ingest-to-lake.
  • 1.0.0
  • 0.1.0
    • Initial version.

License

This project is licensed under the Apache 2.0 License. See LICENSE for more information.

Contributions

  1. Fork it (https://github.com/usdot-its-jpo-data-portal/cv-ingest-to-lake/fork)
  2. Create your feature branch (git checkout -b feature/fooBar)
  3. Commit your changes (git commit -am 'Add some fooBar')
  4. Push to the branch (git push origin feature/fooBar)
  5. Create a new Pull Request

Contact Information

Contact Name: ITS JPO

Contact Information: [email protected]

Acknowledgements

When you copy or adapt from this code, please include the original URL you copied the source code from and date of retrieval as a comment in your code.

Thank you to the Department of Transportation for funding to develop this project.