Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fbielejec/mer-de-glace
wordpress to AWS Glacier backup tool
https://github.com/fbielejec/mer-de-glace
aws backup devops glacier rust s3 wordpress
Last synced: 16 days ago
JSON representation
wordpress to AWS Glacier backup tool
- Host: GitHub
- URL: https://github.com/fbielejec/mer-de-glace
- Owner: fbielejec
- Created: 2021-01-29T01:28:40.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2021-01-29T15:57:38.000Z (almost 4 years ago)
- Last Synced: 2025-01-04T01:39:38.959Z (21 days ago)
- Topics: aws, backup, devops, glacier, rust, s3, wordpress
- Language: Rust
- Homepage:
- Size: 257 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.org
Awesome Lists containing this project
README
#+TITLE: mer-de-glace
#+SUBTITLE: wordpress backup tool
#+AUTHOR: Filip Bielejec
#+EMAIL: (concat "fbielejec" at-sign "gmail.com")
#+DESCRIPTION: tool written in Rust to create backups of wordpress.org installations
#+KEYWORDS: rust, docker, wordpress, mySQL, mariadb, wordpress.org
#+LANGUAGE: en
#+OPTIONS: H:4 num:nil toc:2 p:t#+HTML_LINK_HOME: https://www.blog.nodrama.io/
#+html:
* Summary
[[https://github.com/fbielejec/mer-de-glace][Mer-de-glace]] is a tool for creating rolling backups of [[https://wordpress.org/][wordpress.org]] installations.It will periodically create a tar archives with the:
- dump of mysql wordpress database
- the wordpress html contentThis tar archive will be than uploaded to the [[https://aws.amazon.com/glacier/][AWS Glacier]].
* Using
Probably the most convenient is to use the tool /via/ a docker container. Below an example docker-compose config:
#+BEGIN_SRC yaml
version: "3.5"
services:mysql:
image: mysql:5.7
container_name: mysql
command:
--default-authentication-plugin=mysql_native_password
volumes:
- /home/$USER/mysql-docker:/var/lib/mysql
expose:
- 3306
ports:
- 0.0.0.0:3306:3306
environment:
- MYSQL_ROOT_USER=root
- MYSQL_ROOT_PASSWORD=Pa55w0rd
- MYSQL_DATABASE=wordpress
- MYSQL_USER=wordpress
- MYSQL_PASSWORD=wordpress
restart: alwayswordpress:
image: wordpress:latest
container_name: wordpress
depends_on:
- mysql
expose:
- 80
ports:
- 0.0.0.0:8080:80
volumes:
- /home/$USER/wordpress-docker:/var/www/html
environment:
- WORDPRESS_DB_HOST=mysql:3306
- WORDPRESS_DB_USER=wordpress
- WORDPRESS_DB_PASSWORD=wordpress
restart: alwaysmer-de-glace:
image: fbielejec/mer-de-glace
container_name: mer-de-glace
depends_on:
- wordpress
- mysql
environment:
# required
- WORDPRESS_DIRECTORY=/wordpress-docker
- MYSQL_HOST=mysql
- MYSQL_DATABASE=wordpress
- MYSQL_USER=root
- MYSQL_PASSWORD=Pa55w0rd
- BACKUPS_DIRECTORY=/wp_backups
- AWS_REGION=us-east-2
- AWS_GLACIER_VAULT=wordpress_backups
- AWS_ACCESS_KEY_ID=$AWS_ACCESS_KEY_ID
- AWS_SECRET_ACCESS_KEY=$AWS_SECRET_ACCESS_KEY
# optional
- BACKUP_INTERVAL=7 # create new glacier archive every 7 days
- ARCHIVE_ROLLING_PERIOD=14 # keep local (on-disk) archives for that long
volumes:
- /home/$USER/wordpress-docker:/wordpress-docker
- /home/$USER/wp_backups:/wp_backups
#+END_SRC* Development
Export following ENV variables:
#+BEGIN_SRC bash
# path to /var/www/html directory of the wordpress installations
export WORDPRESS_DIRECTORY=/home/$USER/wordpress-docker
export MYSQL_HOST="127.0.0.1"
export MYSQL_PORT=3306
export MYSQL_DATABASE=wordpress
export MYSQL_USER=root
export MYSQL_PASSWORD=Pa55w0rd
export BACKUPS_DIRECTORY=/home/$USER/wp_backups
export AWS_REGION=us-east-2
export AWS_GLACIER_VAULT=test
export AWS_ACCESS_KEY_ID=<...>
export AWS_SECRET_ACCESS_KEY=<...>
#+END_SRCStart a watcher on the sources:
#+BEGIN_SRC bash
cargo watch -x run
#+END_SRC