Production Service Architecture_old - internetarchive/openlibrary GitHub Wiki
- 2019: ol-mem[0-2]trusty VMs have been reprovisioned asol-mem[3-5]following the Provisioning Guide
Today, our production service architecture consists of ~11 VMs:
Our current production setup process (as of 2019) for provisioning these 11 VMs is ostensibly manual and relies on a lot of manually scping directories around, as well as a separate repository called olsystem which contains the production configs, cron jobs, and infrastructure required to run the official openlibrary.org service.
Each of our 11 VMs are more-or-less provisioned identically:
- Every VM has an /optdirectory containing all the "business"
- Within /optthere is anopenlibrary/and apetabox/directory. It's very likely/opt/petaboxis not required by all VMs, though it's not currently well understood which services may rely on it (e.g. theol-homeVM makes heavy use ofolsystemwhich may reference petabox)
- 
/opt/openlibrarycontains all the business logic for the Open Library project:
/opt/
/opt/petabox
/opt/openlibrary
/opt/openlibrary/venv  -- python virtualenv
/opt/openlibrary/maxmind-geoip/  -- .dat file for anonymizing IPs
/opt/openlibrary/deploys  -- history of all deploys, hash-binned by service
/opt/openlibrary/deploys/openlibrary  -- history of openlibrary deploys
/opt/openlibrary/deploys/olsystem  -- history of openlibrary deploys
/opt/openlibrary/deploys/base  -- deprecated??
/opt/openlibrary/deploys/openlibrary/openlibrary  -- active openlibrary deploy
/opt/openlibrary/deploys/openlibrary/openlibrary  -- active olsystem deploy
/opt/openlibrary/olsystem/  -- symlink to active olsystem: /opt/deploys/openlibrary/olsystem
/opt/openlibrary/openlibrary -- symlink to active openlibrary: /opt/deploys/openlibrary/olsystemAt minimum, re-provisioning a VM requires:
- setting up firewall rules and installing core packages (e.g. git, docker) by running an ansible playbook
- 
scp'ing over the legacy VM's/optdirectory (preferably as an external mountable/1volume which can be moved in the future)
- Setting up olsystemso that its files within/opt/openlibrary/olsystem/etcsymlink to the right locations within/etc
