{"id":13813643,"url":"https://github.com/scrapinghub/frontera","last_synced_at":"2025-05-13T23:09:34.567Z","repository":{"id":23633570,"uuid":"27003377","full_name":"scrapinghub/frontera","owner":"scrapinghub","description":"A scalable frontier for web crawlers","archived":false,"fork":false,"pushed_at":"2025-02-05T16:26:31.000Z","size":4342,"stargazers_count":1310,"open_issues_count":98,"forks_count":217,"subscribers_count":156,"default_branch":"master","last_synced_at":"2025-05-12T11:09:24.021Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"bsd-3-clause","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/scrapinghub.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":"AUTHORS","dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2014-11-22T15:42:50.000Z","updated_at":"2025-05-06T05:47:11.000Z","dependencies_parsed_at":"2022-07-10T09:46:18.349Z","dependency_job_id":"56b6c8e3-432a-4c22-a79b-7842163e30ab","html_url":"https://github.com/scrapinghub/frontera","commit_stats":{"total_commits":742,"total_committers":42,"mean_commits":"17.666666666666668","dds":0.5026954177897573,"last_synced_commit":"84f9e1034d2868447db88e865596c0fbb32e70f6"},"previous_names":["scrapinghub/crawl-frontier"],"tags_count":25,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/scrapinghub%2Ffrontera","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/scrapinghub%2Ffrontera/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/scrapinghub%2Ffrontera/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/scrapinghub%2Ffrontera/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/scrapinghub","download_url":"https://codeload.github.com/scrapinghub/frontera/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":253726895,"owners_count":21954095,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-08-04T04:01:24.137Z","updated_at":"2025-05-13T23:09:29.543Z","avatar_url":"https://github.com/scrapinghub.png","language":"Python","readme":"# Frontera\n\n[![pypi](https://img.shields.io/pypi/v/frontera)](https://pypi.org/project/frontera/)\n[![python versions](https://img.shields.io/pypi/pyversions/frontera.svg)](https://pypi.org/project/frontera/)\n[![Build Status](https://travis-ci.org/scrapinghub/frontera.svg?branch=master)](https://travis-ci.org/scrapinghub/frontera)\n[![codecov](https://codecov.io/gh/scrapinghub/frontera/branch/master/graph/badge.svg)](https://codecov.io/gh/scrapinghub/frontera)\n\n## Overview\n\nFrontera is a web crawling framework consisting of [crawl frontier](http://nlp.stanford.edu/IR-book/html/htmledition/the-url-frontier-1.html), and distribution/scaling primitives, allowing to build a large scale online web crawler. \n\nFrontera takes care of the logic and policies to follow during the crawl. It stores and prioritises links extracted by \nthe crawler to decide which pages to visit next, and capable of doing it in distributed manner.\n\n## Main features\n\n- Online operation: small requests batches, with parsing done right after fetch.\n- Pluggable backend architecture: low-level backend access logic is separated from crawling strategy.\n- Two run modes: single process and distributed.\n- Built-in SqlAlchemy, Redis and HBase backends.\n- Built-in Apache Kafka and ZeroMQ message buses.\n- Built-in crawling strategies: breadth-first, depth-first, Discovery (with support of robots.txt and sitemaps).\n- Battle tested: our biggest deployment is 60 spiders/strategy workers delivering 50-60M of documents daily for 45 days, without downtime,\n- Transparent data flow, allowing to integrate custom components easily using Kafka.\n- Message bus abstraction, providing a way to implement your own transport (ZeroMQ and Kafka are available out of the box).\n- Optional use of Scrapy for fetching and parsing.\n- 3-clause BSD license, allowing to use in any commercial product.\n- Python 3 support.\n\n## Installation\n\n```bash\n$ pip install frontera\n```\n\n## Documentation\n\n- [Main documentation at RTD](http://frontera.readthedocs.org/)\n- [EuroPython 2015 slides](http://www.slideshare.net/sixtyone/fronteraopen-source-large-scale-web-crawling-framework)\n- [BigDataSpain 2015 slides](https://speakerdeck.com/scrapinghub/frontera-open-source-large-scale-web-crawling-framework)\n\n## Community\n\nJoin our Google group at https://groups.google.com/a/scrapinghub.com/forum/#!forum/frontera or check GitHub issues and \npull requests.\n","funding_links":[],"categories":["Python","Web Scraping \u0026 Crawling","Crawler"],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fscrapinghub%2Ffrontera","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fscrapinghub%2Ffrontera","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fscrapinghub%2Ffrontera/lists"}