Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cestef/webscraper-exporter
A simple yet powerful prometheus exporter for website performance metrics built using puppeteer
https://github.com/cestef/webscraper-exporter
metrics-exporter prometheus prometheus-exporter puppeteer scraper
Last synced: 3 months ago
JSON representation
A simple yet powerful prometheus exporter for website performance metrics built using puppeteer
- Host: GitHub
- URL: https://github.com/cestef/webscraper-exporter
- Owner: cestef
- License: mit
- Created: 2022-01-07T05:51:36.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2023-05-15T16:24:39.000Z (over 1 year ago)
- Last Synced: 2024-10-04T19:14:17.189Z (4 months ago)
- Topics: metrics-exporter, prometheus, prometheus-exporter, puppeteer, scraper
- Language: TypeScript
- Homepage:
- Size: 5.5 MB
- Stars: 7
- Watchers: 1
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Webscraper Exporter
A simple yet powerful [`prometheus`](https://prometheus.io) exporter for website performance metrics built using [`puppeteer`](https://pptr.dev/).
## Table of contents
- [Webscraper Exporter](#webscraper-exporter)
- [Table of contents](#table-of-contents)
- [CLI](#cli)
- [Getting started](#getting-started)
- [Installation of the CLI](#installation-of-the-cli)
- [Configuration](#configuration)
- [Using the CLI](#using-the-cli)
- [Starting](#starting)
- [Creating a project](#creating-a-project)
- [Adding, Removing and Listing Templates](#adding-removing-and-listing-templates)
- [NodeJS module](#nodejs-module)
- [Installation of the module](#installation-of-the-module)
- [Using the module](#using-the-module)
- [Docker](#docker)
- [Exported Data](#exported-data)
- [Customization](#customization)
- [Contributing](#contributing)## CLI
Currently only tested on `macOS` and `Linux`, should support `Windows`
### Getting started
#### Installation of the CLI
You can install the cli included to get started quickly with barely no configuration:
```bash
npm install --global webscraper-exporter
```or
```bash
yarn global add webscraper-exporter
```You can then check if everything went OK by running:
```bash
wsce --version
```
This should print the package's version#### Configuration
In your current working directory, create a file named `wsce.config.js` with the following example content:
```js
module.exports = {
scraper: {
urls: ["https://google.com"],
puppeteerOptions: {},
addons: [],
interval: 60_000,
},
exporter: {
port: 9924
},
};
```For further information on the configuration, see [CONFIGURING.md](docs/CONFIGURING.md)
#### Using the CLI
To see all available options for a command, see `wsce -h`;
##### Starting
You can start the exporter by simply executing:```
wsce start
```You can then access the metrics at http://localhost:9924
If you want more detailled logs, you can pass the `-v` argument.
To pass a custom config file, use `-c path/to/file`
##### Creating a project
Create a project from one of the included templates by running:
```
wsce init my-project
```You will then be prompted for the project template. You can also directly pass the template to `wsce init`, e.g. :
```
wsce init my-project --template javascript
```By default, `wsce` includes a typings file for the config so it's easier to fill. If you don't want that, you can pass `--typings=false` to the `init` command.
##### Adding, Removing and Listing Templates
`wsce template` has 3 subcommands:
- `add`: Add a template from a local directory / remote repository
- `remove`: Remove a saved template
- `list`: List all saved templatesFor more information on templates, see [TEMPLATES.md](docs/TEMPLATES.md)
## NodeJS module
#### Installation of the module
```
npm install --save webscraper-exporter
```or
```
yarn add webscraper-exporter
```#### Using the module
```js
import { Exporter, Scraper } from "webscraper-exporter";const scraper = new Scraper({
urls: ["https://cstef.dev"],
addons: [
{
name: "Logger",
when: "before",
run: (browser, page, URL) => {
console.log(`I am running on ${URL}`);
},
},
],
interval: 60_000,
});
scraper.start();
const exporter = new Exporter({
scraper,
port: 9924,
});
exporter.start();
```For more examples, see the `examples` folder.
## Docker
There is a [`Dockerfile`](Dockerfile) included in this repository so you can build your own image for `wsce` (based on the `node:alpine-16` image).
See [DOCKER.md](docs/DOCKER.md) for more information.
## Exported Data
You can see the metrics that are exposed in: [EXPORTED_DATA.md](docs/EXPORTED_DATA.md)
## Customization
You can easily write your own plugins in Javascript to expand `webscraper-exporter`'s functionalities.
See [ADDONS.md](docs/ADDONS.md) for more information.
## Contributing
Pull requests are always welcome if you feel like fixing / expanding something in this project !