{"id":29429412,"url":"https://github.com/matveynator/redis-backup","last_synced_at":"2026-04-15T18:02:04.384Z","repository":{"id":295964951,"uuid":"991835536","full_name":"matveynator/redis-backup","owner":"matveynator","description":"🚀 Redis Backup Tool - Built by CHICHA — good dog, great backups. 🐕💾","archived":false,"fork":false,"pushed_at":"2025-12-14T12:52:37.000Z","size":81,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2025-12-16T15:04:32.771Z","etag":null,"topics":["backup","backup-tool","backup-utility","backups","redis","redis-cache","redis-client","redis-cluster","redis-database","redis-server"],"latest_commit_sha":null,"homepage":"","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/matveynator.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2025-05-28T08:11:11.000Z","updated_at":"2025-12-14T10:42:06.000Z","dependencies_parsed_at":"2025-06-10T11:19:25.437Z","dependency_job_id":"28c7b81e-afb0-4530-b186-8ccd646942fd","html_url":"https://github.com/matveynator/redis-backup","commit_stats":null,"previous_names":["matveynator/backup-redis","matveynator/redis-backup"],"tags_count":1,"template":false,"template_full_name":null,"purl":"pkg:github/matveynator/redis-backup","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/matveynator%2Fredis-backup","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/matveynator%2Fredis-backup/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/matveynator%2Fredis-backup/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/matveynator%2Fredis-backup/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/matveynator","download_url":"https://codeload.github.com/matveynator/redis-backup/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/matveynator%2Fredis-backup/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31853279,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-15T15:24:51.572Z","status":"ssl_error","status_checked_at":"2026-04-15T15:24:39.138Z","response_time":63,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["backup","backup-tool","backup-utility","backups","redis","redis-cache","redis-client","redis-cluster","redis-database","redis-server"],"created_at":"2025-07-12T16:08:23.127Z","updated_at":"2026-04-15T18:02:04.378Z","avatar_url":"https://github.com/matveynator.png","language":"Go","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003cimg src=\"https://repository-images.githubusercontent.com/991835536/72ff229d-e789-4fc8-883d-53439aab3c0d\" align=\"right\" width=\"50%\"\u003e\n\n# 🇬🇧 redis-backup\n\n[🇷🇺 Читать по-русски](#-русская-инструкция)\n\n---\n\n## 📦 Overview\n\n**redis-backup** is a simple yet powerful Go utility:\n- It automatically discovers all running Redis instances.\n- Backs up their `RDB` files as compressed `.tar.gz` archives.\n- Can replicate backups to **multiple FTP servers** for redundancy.\n- Controls how many copies to keep locally and remotely.\n- Includes an interactive restore wizard.\n- Supports a robust check mode for monitoring freshness, size, disk usage, and FTP health.\n- Locks itself to avoid parallel runs.\n- Provides clear, colorized logs.\n\n---\n\n## ✅ Key Features\n\n- 🔍 **Auto-discover Redis ports**\n- 📂 **Multiple FTP upload** — replicate to as many FTPs as you want.\n- 🔁 **Smart retention** — limit local copies (`--copies`) and multiply retention for FTP (`--ftp-keep-factor`).\n- 🕵️ **Nagios-friendly check mode** — verify freshness, size, disk status and FTP consistency.\n- 🔄 **Safe interactive restore**\n- 🔐 **File lock to prevent overlaps**\n\n---\n\n## ⚙️ New Flags\n\n| Flag                  | Description                                                       | Default |\n| --------------------- | ----------------------------------------------------------------- | ------- |\n| `--copies`, `-c`      | Max daily archives to keep locally (0 = unlimited)                | `0`     |\n| `--ftp-keep-factor`   | Remote retention multiplier (`copies × factor` per FTP server)    | `4`     |\n\n---\n\n## 🗂️ FTP Configuration\n\nYou can define multiple FTP accounts in `/etc/ftp-backup.conf`:\n\n```ini\n# Example /etc/ftp-backup.conf\n\nFTP_HOST=ftp1.example.com\nFTP_USER=user1\nFTP_PASS=pass1\n\nFTP_HOST=ftp2.backup.net\nFTP_USER=user2\nFTP_PASS=pass2\n````\n\nBackups will be uploaded to **each** FTP defined.\n\n---\n\n## 🚀 Installation\n\n**✅ Linux (amd64)**\n\n```bash\ncurl -L https://github.com/matveynator/redis-backup/releases/latest/download/redis-backup_linux_amd64 -o /usr/local/bin/redis-backup; chmod +x /usr/local/bin/redis-backup;\n```\n\n**✅ macOS (amd64)**\n\n```bash\ncurl -L https://github.com/matveynator/redis-backup/releases/latest/download/redis-backup_darwin_amd64 -o /usr/local/bin/redis-backup; chmod +x /usr/local/bin/redis-backup;\n```\n\n**✅ OpenBSD (amd64)**\n\n```bash\ncurl -L https://github.com/matveynator/redis-backup/releases/latest/download/redis-backup_openbsd_amd64 -o /usr/local/bin/redis-backup; chmod +x /usr/local/bin/redis-backup;\n```\n\n**✅ FreeBSD (amd64)**\n\n```bash\ncurl -L https://github.com/matveynator/redis-backup/releases/latest/download/redis-backup_freebsd_amd64 -o /usr/local/bin/redis-backup; chmod +x /usr/local/bin/redis-backup;\n```\n\n---\n\n## ✅ Usage Examples\n\n**Basic backup:**\n\n```bash\nsudo redis-backup\n```\n\n**Limit local to 1 copy, keep 4× more on FTP:**\n\n```bash\nsudo redis-backup --copies 1 --ftp-keep-factor 4\n```\n\n**Check freshness (24h) + disk usage + FTP:**\n\n```bash\nredis-backup --check 24 --copies 2 --ftp-keep-factor 4\n```\n\n---\n\n## 📁 Backup Locations\n\n| Where | How Many                       |\n| ----- | ------------------------------ |\n| Local | `--copies`                     |\n| FTP   | `--copies × --ftp-keep-factor` |\n\n---\n\n## 🔄 Restore\n\n```bash\nsudo redis-backup --restore\n```\n\n* Pick Redis port.\n* Pick archive.\n* The current `RDB` is renamed to `.backup` and replaced safely.\n\n---\n\n## 🔍 Nagios Command Example\n\n```bash\n/usr/local/bin/check_ssh r2d2@$HOSTADDRESS$ sudo /usr/local/bin/redis-backup --check 24\n```\n\n---\n\n# 🇷🇺 Русская инструкция\n\n---\n\n## 📦 Обзор\n\n**redis-backup** — это удобный инструмент на Go, который:\n\n* Автоматически находит все работающие Redis.\n* Сохраняет их `RDB` в виде `.tar.gz` архивов.\n* Отправляет архивы сразу на несколько FTP серверов.\n* Гибко управляет количеством копий локально и на FTP.\n* Позволяет интерактивно восстановить данные.\n* Проверяет свежесть, размер, FTP и диск.\n* Ставит лок-файл для защиты от параллельного запуска.\n* Выводит цветные логи.\n\n---\n\n## ✅ Новые возможности\n\n* 🔗 **Мульти-FTP** — сколько угодно серверов для надёжности.\n* ⏳ **Ограничение локальных копий** (`--copies`) и длинная история на FTP (`--ftp-keep-factor`).\n* 🕵️ **Режим проверки (`--check`)** — следит за всем.\n* 🔄 **Безопасное восстановление**.\n\n---\n\n## ⚙️ Новые флаги\n\n| Флаг                | Описание                                                    | По умолчанию |\n| ------------------- | ----------------------------------------------------------- | ------------ |\n| `--copies`, `-c`    | Сколько daily-файлов хранить локально (0 = без ограничения) | `0`          |\n| `--ftp-keep-factor` | Во сколько раз дольше хранить на FTP                        | `4`          |\n\n---\n\n## 🗂️ Пример /etc/ftp-backup.conf\n\n```ini\nFTP_HOST=ftp1.example.com\nFTP_USER=user1\nFTP_PASS=pass1\n\nFTP_HOST=ftp2.backup.net\nFTP_USER=user2\nFTP_PASS=pass2\n```\n\n---\n\n## 🚀 Установка\n\n**✅ Linux (amd64)**\n\n```bash\ncurl -L https://github.com/matveynator/redis-backup/releases/latest/download/redis-backup_linux_amd64 -o /usr/local/bin/redis-backup; chmod +x /usr/local/bin/redis-backup;\n```\n\n**✅ macOS (amd64)**\n\n```bash\ncurl -L https://github.com/matveynator/redis-backup/releases/latest/download/redis-backup_darwin_amd64 -o /usr/local/bin/redis-backup; chmod +x /usr/local/bin/redis-backup;\n```\n\n**✅ OpenBSD (amd64)**\n\n```bash\ncurl -L https://github.com/matveynator/redis-backup/releases/latest/download/redis-backup_openbsd_amd64 -o /usr/local/bin/redis-backup; chmod +x /usr/local/bin/redis-backup;\n```\n\n**✅ FreeBSD (amd64)**\n\n```bash\ncurl -L https://github.com/matveynator/redis-backup/releases/latest/download/redis-backup_freebsd_amd64 -o /usr/local/bin/redis-backup; chmod +x /usr/local/bin/redis-backup;\n```\n\n---\n\n## 📋 Примеры использования\n\n**Обычный бэкап:**\n\n```bash\nsudo redis-backup\n```\n\n**Локально — 1 копия, на FTP — 4 раза больше:**\n\n```bash\nsudo redis-backup --copies 1 --ftp-keep-factor 4\n```\n\n**Проверка свежести (24ч), места и FTP:**\n\n```bash\nredis-backup --check 24 --copies 2 --ftp-keep-factor 4\n```\n\n---\n\n## 📁 Где хранятся бэкапы\n\n| Где      | Сколько копий                  |\n| -------- | ------------------------------ |\n| Локально | `--copies`                     |\n| На FTP   | `--copies × --ftp-keep-factor` |\n\n---\n\n## 🔄 Восстановление\n\n```bash\nsudo redis-backup --restore\n```\n\n* Выбрать порт Redis.\n* Выбрать архив.\n* Текущий RDB переименуется в `.backup` и заменится.\n\n---\n\n## 🔍 Пример команды для Nagios\n\n```bash\n/usr/local/bin/check_ssh r2d2@$HOSTADDRESS$ sudo /usr/local/bin/redis-backup --check 24\n```\n\n---\n\n## 🧹 Автоудаление\n\n* Локально — удаляются лишние daily-архивы по `--copies`.\n* На FTP — аналогично, но копий хранится `× --ftp-keep-factor`.\n\n---\n\n## 📑 License\n\nGNU GPL.\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmatveynator%2Fredis-backup","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmatveynator%2Fredis-backup","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmatveynator%2Fredis-backup/lists"}