Micro Web Crawler in PHP & Manticore
Go to file
2024-04-06 03:00:26 +03:00
example fix json encoded regex rule 2024-04-05 06:04:31 +03:00
src/cli fix undefined variable, minor optimization 2024-04-06 02:48:25 +03:00
.gitignore ignore all config files in this folder 2023-12-12 23:30:15 +02:00
composer.json update dependencies 2024-04-06 02:12:07 +03:00
LICENSE Initial commit 2023-11-19 20:07:17 +02:00
README.md update readme 2024-04-06 03:00:26 +03:00

Yo!

Micro Web Crawler in PHP & Manticore

Yo! is the super thin client-server crawler based on Manticore full-text search.
Compatible with different networks, includes flexible settings, history snaps, CLI tools and UI for Gemini Protocol.

To use HTTP version, please checkout main branch!

Features

  • MIME-based crawler with flexible filter settings by regular expressions, selectors, external links etc
  • Page snap history with local and remote mirrors support (including FTP protocol)
  • CLI tools for index administration and crontab tasks
  • Gemini Protocol UI (coming soon)

Components

Install

Environment

Debian
  • wget https://repo.manticoresearch.com/manticore-repo.noarch.deb
  • dpkg -i manticore-repo.noarch.deb
  • apt update
  • apt install git composer manticore manticore-extra php-fpm php-mbstring

Yo search engine uses Manticore as the primary database. If your server sensitive to power down, change default binlog flush strategy to binlog_flush = 1

Deployment

  • git clone https://github.com/YGGverse/Yo.git
  • cd Yo
  • git checkout gemini
  • composer update

Development

  • git clone https://github.com/YGGverse/Yo.git
  • cd Yo
  • git checkout gemini
  • git checkout -b pr-branch
  • git commit -m 'new fix'
  • git push

Update

  • cd Yo
  • git pull
  • composer update

Init

  • cp example/config.json config.json
  • php src/cli/index/init.php

Usage

  • php src/cli/document/add.php URL
  • php src/cli/document/crawl.php
  • php src/cli/document/search.php '*'

Gemini UI

Coming soon..

Documentation

CLI

Index

Init

Create initial index

php src/cli/index/init.php [reset]
  • reset - optional, reset existing index
Alter

Change existing index

php src/cli/index/alter.php {operation} {column} {type}
  • operation - operation name, supported values: add|drop
  • column - target column name
  • type - target column type, supported values: text|integer

Document

Add
php src/cli/document/add.php URL
  • URL - add new URL to the crawl queue
Crawl
php src/cli/document/crawl.php
Clean

Make index optimization, apply new configuration rules

php src/cli/document/clean.php [limit]
  • limit - integer, documents quantity per queue
php src/cli/document/search.php '@title "*"' [limit]
  • query - required
  • limit - optional search results limit

Backup

Logical

SQL text dumps could be useful for public index distribution, but requires more computing resources.

Read more

Physical

Better for infrastructure administration and includes original data binaries.

Read more

Instances

Coming soon..