Spidergram is a toolbox for exploring, auditing, and analyzing complicated web sites — particularly ones that use multiple CMSs, span more than one domain, and are maintained by multiple teams inside an organization. Although it works well for smaller projects, Autogram built it to overcome the roadblocks we hit when using existing crawling and inventory tools on complex, multi-site web properties. Using it to crawl your blog is a bit like swatting a fly with a Buick.
Large-scale inventory and analysis of web content is kind of hellish. Most automated tools are focused on SEO, and assume that a spreadsheet of URLs is the desired endgame. On the other hand, most programmer-friendly web scraping toolkits are built to automate web APIs or extract specific bits of data from others' web sites. (Grabbing a list of every product in an Amazon category, extracting job listings, etc.)
Autogram often works with companies that are trying to get a handle on their own huge web ecosystems. We needed:
- Simple exploratory spidering, and complex conditional rules for normalizing and traversing large multi-site content ecosystems.
- The ability to preserve complex relationships between each page, and layer on additional information from other sources like internal client spreadsheets and CMS inventories, analytics APIs, etc.
- A solid framework for iterative analysis of that multi-layered data, not just a million-row spreadsheet and two weeks with Excel.
There are tons of useful programs, hosted services, and open source projects that do some of that, but finding anything that supported it all was a nightmare. Unforatunately, we're huge nerds, so we had to go build it.
- Node 18; you can check which version you have installed using
node -v
. - ArangoDB for storage and analysis of crawl data. ArangoDB's community edition is available as pre-compiled binaries, can be installed using homebrew on a Mac (
brew install arangodb
), and can be run in a Docker container on most platforms.
npx create-spidergram
will set up a fresh node.js project using one of several example crawler projects. For more details on the example projects, see the Create Spidergram project page.
node install --save spidergram
will add Spidergram to your node.js project's dependencies. Spidergram is a pure ESM project; while there are still plenty of CommonJS projects out there, the ecosystem is quickly moving towards a consistent ESM standard. We bit the bullet now rather than migrating in the future as project dependencies leave CommonJS behind.
npm install -g spidergram
will install Spidergram globally, giving you access to its command line interface, and spidergram --help
will list its available options. Importing existing sitemaps, kicking off a new crawl, generating simple reports, and checking on the status of the database can all be done from the CLI. This CLI doesn't allow as much control as creating a custom project, but it's a quick way to kick the tires.
In a node.js project, import the 'Spider' class, create an instance, and call its 'run' method. Without any other options, Spidergram will hit the URL you give it, save the contents to the database, search for other links within the same domain, and follow them until it's visited and saved everything it can find.
import { Spider } from 'spidergram';
await new Spider().run('https://example.com');
An Options object can be passed into the Spider when it's created to override its default behaviors.
const spider = new Spider({
maxConcurrency: 2, // Run two headless browsers in parallel
maxRequestsPerMinute: 60, // Limit them to 1 request per second
downloadMimeTypes: ['application/pdf'], // Download any PDF files encountered
pageHandler: ({ page, saveResource, enqueueUrls }) => {
// 'page' is the Playwright page object; you can use it to control
// the browser, grab HTML snippets, take screenshots, and more.
const html = await page.content();
// Save metadata about the current page to the database, with the raw
// page markup in the resource's "body" property
await saveResource({ body: html })
// Find URLs on the page, record them all in the database, and visit
// any that match our target domain.
await enqueueUrls();
}
});
await spider.run('https://example.com');
Spidergram is a pure ESM Node.js project written in Typescript; it assembles a laundry list of excellent third-party open source projects including ArangoDB, Crawlee, Playwright, Cheerio, HtmlToText, SheetJS, Vega, and more.
Spidergram is a tool we use when solving problems for our clients; it's been evolving for several years and will continue to evolve as we spot new and interesting weird stuff in the wild. At the moment, our plans include:
- Additional documentation
- Additional example project templates
- Site-specific content extraction and auditing
- Path traversal to identify hard-to-find content
- Pattern analysis to audit design system usage across sites
- Reusable helpers and utilities for common analysis tasks
- Query-builder helpers for common reports
- A larger library of pre-built visualizations
- CMS detection helper functions
- Integration with third-party performance and A11y audit tools
- Technical improvements
- Better test coverage
- Migration to a multi-project monorepo to break up the big dependency footprint
- Pre-configured Docker images for Arango and Playwright
- Cleaner support for crawling authenticated content
- Improved Crawlee integration
- A dedicated SpiderCrawler class
- Arango-backed versions of the RequestQueue, DataSet, and KeyValueStore utilities
- Support for cloud-hosted crawling as an Apify actor
If you're interested in contributing, feel free to jump into the issue queue and/or contact us with your ideas.
If you're wrestling with complicated digital publishing, content operations, or design system challenges you should definitely drop us a line, because we love that shit. We've helped dozens of the world's largest tech companies, educational institutions, publishers, and retailers; we get dangerously bored without complicated problems to solve, and we'd love to hear about yours.