there is a list of customers in the Site table. Each customer has a unique id and a name. Our servers are shared across all customers. Since resources are shared amongst all customers, we need to dynamically handle their asynchronous tasks. We need to create a system to handle the following tasks:
- create a datastructure/store to store type of job based on their execution time. you can assume time in seconds and there are 5 types of jobs.
- create a datastructure/store to store type of customer based on their record volume. large volume customers will tend to comsume more resources. you can assume there are 3 types of customers.
- create relevant apis to support the interactions.
- create workers which will pick up the job based on the customer type and job type and execute them. you can assume that each worker can execute only one job at a time.
refer website/models.py for Site Table
refer website/tasks.py for the tasks to be executed
you can use any database, message queue, etc. to store the data. you can use any library to create the workers or any other part of the system. you can create any number of files, classes, functions, etc. to complete the assignment.
install python3.5, pip3 and venv
$ python3.5 -m venv almabase-venv
$ source almabase-venv/bin/activate
$ pip install --upgrade pip --trusted-host pypi.python.org
$ pip3 install -r requirements.txt
- Fork this repository
- Create a new branch with your name
- Commit your code to this branch
- Create a pull request to this repository
- Add your name and email to the README.md file
- Code quality
- high level design
- api design
create a deployment pipeline to deploy on a ubuntu VM. you can use any CI/CD tool for the same.
or
deploy on your own cloud provider and share the link with us.
Once you have submitted the assignment, we will review your code and if it meets our requirements, we will get back to you within a week and schedule 1st round of interview.
in the 1st round of interview, we will discuss the code and build few additional features.