e5278442c9 | ||
---|---|---|
.. | ||
app | ||
bootstrap | ||
config | ||
database | ||
public | ||
resources | ||
routes | ||
storage | ||
tests | ||
.editorconfig | ||
.env.example | ||
.gitattributes | ||
.gitignore | ||
README.md | ||
artisan | ||
composer.json | ||
composer.lock | ||
package.json | ||
phpunit.xml | ||
vite.config.js |
README.md
Web Scraper e-domizil.ch
Das Repository enthält eine auf Laravel (Version 10.x) basierender Web Scraper für die Plattform e-domizil.ch.
Installation
Vorbedingungen für die erfolgreiche Installation sind Server Requirements
- Das Repository klonen
git clone https://gitea.fhgr.ch/dianigionath/ConsultancyProject1_Auslastungsmodellierung.git`
- Die Applikation mittels Composer installieren
php composer install
- Eine Kopie der Datei .env.example nach .env erstellen und den Dateiinhalt bez. Datenbankverbindung anpassen.
cp .env.example .env`
Bsp. für Verbinung zu einer SQLite Datenbank.
DB_CONNECTION=sqlite
DB_DATABASE=/absolute/path/to/database.sqlite
- Mittels Artisan Console die Datenbank initialisieren
php artisan migrate
Erwartete Ausgabe:
WARN The SQLite database does not exist: /home/gio/database_test.sqlite.
┌ Would you like to create it? ────────────────────────────────┐
│ Yes │
└──────────────────────────────────────────────────────────────┘
INFO Preparing database.
Creating migration table .......................................................................... 31ms DONE
INFO Running migrations.
0001_01_01_000000_create_users_table .......................................................................... 57ms DONE
0001_01_01_000001_create_cache_table .......................................................................... 18ms DONE
2019_12_14_000001_create_personal_access_tokens_table .......................................................................... 36ms DONE
2024_03_15_142227_create_regions_table .......................................................................... 10ms DONE
2024_03_15_142228_create_seeds_table .......................................................................... 18ms DONE
2024_03_15_142257_create_properties_table .......................................................................... 17ms DONE
2024_03_15_142550_create_extractions_table .......................................................................... 10ms DONE
2024_03_15_142625_create_exceptions_table .......................................................................... 10ms DONE
2024_03_15_162023_create_jobs_table .......................................................................... 18ms DONE
2024_04_08_115153_create_failed_jobs_table .......................................................................... 32ms DONE
- Gewünschte Region(en) mittels Artisan Konsole hinzufügen:
php artisan scraper:add-region
Mögliche erwartete Ausgabe:
Type in desired region:
> Davos
Choose desired region:
[5460aea91d044] Davos
[5390628eeaa24] Davos Davos Platz
[5460adf3d7913] Davos Clavadel
[565847a969c59] Prättigau/Davos
[5460adf87857d] Davos Wolfgang
[5460adf8f3e46] Davos Monstein
> Davos
New Region created {"name":"Davos","updated_at":"2024-07-06T17:24:09.000000Z","created_at":"2024-07-06T17:24:09.000000Z","id":1}
New Seed added {"uri":"https:\/\/www.e-domizil.ch\/search\/5460aea91d044?_format=json","region_id":1,"updated_at":"2024-07-06T17:24:09.000000Z","created_at":"2024-07-06T17:24:09.000000Z","id":1}
- Zum Schluss sind Cronjobs einzurichten, welche den Webscraper regelmässig ausführt Alle drei Tage um 02:00 die Scraping Jobs erstellen:
0 2 */3 * * /usr/local/bin/php ConsultancyProject1_Auslastungsmodellierung/artisan scrape:jobs
Jeden Tag alle drei Stunden zwischen 04:00 bis 23:00 mit einer zufälligen Verzögerung bis zu einer Stunde den Queue Worker für das Abarbeiten von 250 Jobs ausführen.
0 4,7,9,11,13,15,17,19,21,23 * * * sleep $((RANDOM \% 60))m ; /absolute/path/to/bin/php /absolute/path/to/artisan queue:work --max-jobs=250 --stop-when-empty --max-time=7200