Skip to content

GSA-TTS/searchgov-spider

Repository files navigation

search-spider

The home for the spider that supports search.gov.

Table of contents:

About

The spider uses the open source scrapy framework.

The spiders can be found at search_gov_crawler/search_gov_spiders/spiders/.

Core Scrapy File Structure

*Note: Other files and directories are within the repository but the folders and files below relate to those needed for the scrapy framework.

├── search_gov_crawler ( scrapy root )
│   ├── search_gov_spider ( scrapy project *Note multiple projects can exist within a project root )
│   │   ├── extensions ( includes custom scrapy extensions )
│   │   ├── helpers ( includes common functions )
│   │   ├── spiders
│   │   │   ├── domain_spider.py ( spider for html pages )
│   │   │   ├── domain_spider_js.py  ( spider for js pages )
│   │   ├── utility_files ( includes json files with default domains to scrape )
│   │   ├── items.py
│   │   ├── middlewares.py
│   │   ├── pipelines.py
│   │   ├── settings.py
│   ├── scrapy.cfg

Scrapy Web Crawler

The spider can either scrape for URLs from the list of required domains or take in a domain and starting URL to scrape a site/domain.

Running the spider produces a list of urls found in search_gov_crawler/search_gov_spiders/spiders/scrapy_urls/{spider_name}/{spider_name}_{date}-{UTC_time}.txt as specified by FEEDS in settings.py.

Quick Start

Make sure to run pip install -r requirements.txt and playwright install before running any spiders.

Running Against All Listed Search.gov Domains

Navigate down to search_gov_crawler/search_gov_spiders, then enter the command below:

scrapy crawl domain_spider

to run for all urls / domains that do not require javacript handling. To run for all sites that require javascript run:

scrapy crawl domain_spider_js

^^^ These will take a long time

Running Against A Specific Domain

In the same directory specified above, enter the command below, adding the domain and starting URL for the crawler:

scrapy crawl domain_spider -a allowed_domains=example.com -a start_urls=www.example.com

or

scrapy crawl domain_spider -a allowed_domains=example.com -a start_urls=www.example.com

Setup and Use

Make sure to run pip install -r requirements.txt and playwright install before running any spiders.

Option 1: straight from command-line

  1. Navigate to the spiders directory

  2. Enter one of two following commands:

    • This command will output the yielded URLs in the destination (relative to the spiders directory) and file format specified in the search_gov_crawler/search_gov_spiders/pipelines.py:

      $ scrapy runspider <spider_file.py>
      
    • This command will output the yielded URLs in the destination (relative to the spiders directory) and file format specified by the user:

      $ scrapy runspider <spider_file.py>  -o <filepath_to_output_folder/spider_output_filename.csv>
      

Option 2: benchmark command line

The benchmark script is primarily intended for use in timing and testing scrapy runs. There are two ways to run. In either case its likes you want to redirect your ouput to a log file using something like <benchmark command> >scrapy.log 2>&1

  1. To run a single domain (specifying starting URL -u and allowed domain -d):

       $ python search_gov_spiders/benchmark.py -u https://www.example.com -d example.com
    
  2. To run multiple spiders simultaneously, provide a json file in the format of the crawl-sites.json file as an argument:

       $ python search_gov_spiders/benchmark.py -f </path/to/crawl-sites-like-file.json>
    

There are other options available. Run python search_gov_spiders/benchmark.py -h for more info.

Option 3: custom scheduler

  1. See the Running Scrapy Scheduler section below.

Option 4: deploying on server (Scrapyd)

  1. Navigate to the Scrapy project root directory and start the server.

     $ scrapyd
    
    • Note: the directory where you start the server is arbitrary. It's simply where the logs and Scrapy project FEED destination (relative to the server directory) will be.
  2. Run this command to eggify the Scrapy project and deploy it to the Scrapyd server:

     $ scrapyd-deploy default
    
    • Note: This will simply deploy it to a local Scrapyd server. To add custom deployment endpoints, you navigate to the scrapy.cfg file and add or customize endpoints.

      For instance, if you wanted local and production endpoints:

        [settings]
        default = search_gov_spiders.settings
      
        [deploy: local]
        url = http://localhost:6800/
        project = search_gov_spiders
      
        [deploy: production]
        url = <IP_ADDRESS>
        project = search_gov_spiders
      

      To deploy:

        # deploy locally
        scrapyd-deploy local
      
        # deploy production
        scrapyd-deploy production
      
  3. For an interface to view jobs (pending, running, finished) and logs, access http://localhost:6800/. However, to actually manipulate the spiders deployed to the Scrapyd server, you'll need to use the Scrapyd JSON API.

    Some most-used commands:

    • Schedule a job:

        $ curl http://localhost:6800/schedule.json -d project=search_gov_spiders -d spider=<spider_name>
      
    • Check load status of a service:

        $ curl http://localhost:6800/daemonstatus.json
      

Adding new spiders

  1. Navigate to anywhere within the Scrapy project root directory and run this command:

    $ scrapy genspider -t crawl <spider_name> "<spider_starting_domain>"
    
  2. Open the /search_gov_spiders/search_gov_spiders/spiders/boilerplate.py file and replace the lines of the generated spider with the lines of the boilerplate spider as dictated in the boilerplate file.

  3. Modify the rules in the new spider as needed. Here's the Scrapy rules documentation for the specifics.

  4. To update the Scrapyd server with the new spider, run:

     $ scrapyd-deploy <default or endpoint_name>
    
     ## Running Against All Listed Search.gov Domains
    

Running scrapy scheduler

This process allows for scrapy to be run directly using an in-memory scheduler. The schedule is based on the initial schedule setup in the crawl-sites.json file. The process will run until killed.

The json input file must be in a format similar what is below. There are validations in place when the file is read and in tests that should help prevent this file from getting into an invalid state.

[
    {
        "name": "Example",
        "allowed_domains": "example.com",
        "allow_query_string": false,
        "handle_javascript": false,
        "schedule": "30 08 * * MON",
        "starting_urls": "https://www.example.com"
    }
]
  1. Source virtual environment and update dependencies.

  2. Start scheduler

     $ python search_gov_crawler/scrapy_scheduler.py
    

Running Scrapydweb UI

Local Environment Setup

  1. Source virtual environment, update dependencies, and change working directory to search_gov_crawler

  2. Start scrapyd

     $ scrapyd
    
  3. Build latest version of scrapy project (if any changes have been made since last run)

     $ scrapyd-deploy local -p search_gov_spiders
    
  4. Start logparser

     $ python -m search_gov_logparser
    
  5. Start scrapydweb

     $ python -m search_gov_scrapydweb
    

About

The home for the spider that supports search.gov

Resources

License

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published