parallel_requests
parallel_requests
Parallel requests is an example of a small application for making parallel requests for URLs and collecting the information for their statuses.
The application can use the Crystal language (still beta at the time of writing) multithreading features.
Installation
Install the required dependency shards:
shards install
Run the included migrations:
./migration.sh up
Run the application:
crystal run src/parallel_requests.cr
or you can try the new, multithreading support (still beta in Crystal):
crystal run -Dpreview_mt src/parallel_requests.cr
Production build
shards build --production
Architecture
The application creates 2 fibers - one for fetching the records from the database in batches and one for receiving these records and processing them.
After the second fiber receives the jobs, it will spawn a new fiber for each job, which will process it.
After certain record is processed, it's result is received from the results_channel and saved to the database.
Since the used database (at the moment) is SQlite, there are some database locks situations that needs to be handled.
How it works ?
When you run the application, one of the fibers will be running a loop, that will be looking for records with status = "NEW" and will process them in batches of MAX_BATCH_REQUESTS (10 by default) every second.
Contributing
- Fork it (https://github.com/evvo/parallel_requests/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
Contributors
- Evtimiy Mihaylov - creator and maintainer
parallel_requests
- 1
- 0
- 0
- 0
- 2
- over 4 years ago
- June 25, 2020
MIT License
Thu, 02 Jan 2025 03:57:00 GMT