https://github.com/heyvaldemar/mattermost-data-retention-docker-compose
Mattermost Data Retention Using Docker Compose
https://github.com/heyvaldemar/mattermost-data-retention-docker-compose
automation chat data-retention delete-data devops devops-automation docker docker-compose mattermost mattermost-api mattermost-bot mattermost-chat mattermost-client mattermost-plugin mattermost-retention mattermost-server messanger retention retention-policies retention-policy
Last synced: 2 months ago
JSON representation
Mattermost Data Retention Using Docker Compose
- Host: GitHub
- URL: https://github.com/heyvaldemar/mattermost-data-retention-docker-compose
- Owner: heyvaldemar
- Created: 2023-08-11T23:11:05.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2025-01-15T15:17:57.000Z (4 months ago)
- Last Synced: 2025-01-25T22:20:39.375Z (4 months ago)
- Topics: automation, chat, data-retention, delete-data, devops, devops-automation, docker, docker-compose, mattermost, mattermost-api, mattermost-bot, mattermost-chat, mattermost-client, mattermost-plugin, mattermost-retention, mattermost-server, messanger, retention, retention-policies, retention-policy
- Language: Shell
- Homepage: https://www.heyvaldemar.com
- Size: 23.4 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
README
# Mattermost Data Retention Using Docker Compose
The `mattermost-retention.sh` script assists in managing and cleaning up your Mattermost server to retain only a specific number of days' worth of messages and files. The steps performed by the script include:
1. **Environment Setup**: The script sets up the essential environment variables required for database connections, such as database name, user, password, host, and other related configurations like the Mattermost hostname, retention days, and Mattermost data directory.
2. **Container Identification**: Based on the Docker images used by the PostgreSQL and Mattermost services, the script identifies the running containers' IDs. This makes the script flexible, not relying on fixed container names.
3. **Cron Job Management**: For automation, the script first removes any existing cron jobs related to itself and then schedules a new one to run at 8 AM UTC daily.
4. **Retention Time Calculation**: The script computes the timestamp that corresponds to the specified retention days in the past.
5. **Database Interactions**: Depending on whether you're using PostgreSQL or MySQL (based on your configuration), the script communicates with the database running inside a Docker container to:
* Fetch file paths of files created before the retention date and save these paths in a temporary file.
* Delete posts and file information that were created before the retention date.6. **File Deletion**: The script accesses the file paths from the temporary file and erases each one from the Mattermost server running within a Docker container.
7. **Cleanup**: The script gets rid of the temporary file and removes any empty directories in the Mattermost data path.
By executing these steps, the script ensures that the Mattermost server retains only messages and files from the specified retention days, allowing you to manage storage more efficiently.
## Running the Script
Before executing the script, update the environment variables at the beginning of the `mattermost-retention.sh` to match your configuration.
To make the script executable, modify its permissions using:
```
chmod +x mattermost-retention.sh
```After this, you can run the script with:
```
./mattermost-retention.sh
```## Viewing Logs
After adding `mattermost-retention.sh` to the crontab and it has executed, you can check the logs to verify if it operated successfully or if there were any issues.
You can find the logs for `mattermost-retention.sh` in the directory from which you initiated the script.
## Author
hey everyone,
πΎ Iβve been in the IT game for over 20 years, cutting my teeth with some big names like [IBM](https://www.linkedin.com/in/heyvaldemar/), [Thales](https://www.linkedin.com/in/heyvaldemar/), and [Amazon](https://www.linkedin.com/in/heyvaldemar/). These days, I wear the hat of a DevOps Consultant and Team Lead, but what really gets me going is Docker and container technology - Iβm kind of obsessed!
π I have my own IT [blog](https://www.heyvaldemar.com/), where Iβve built a [community](https://discord.gg/AJQGCCBcqf) of DevOps enthusiasts who share my love for all things Docker, containers, and IT technologies in general. And to make sure everyone can jump on this awesome DevOps train, I write super detailed guides (seriously, theyβre foolproof!) that help even newbies deploy and manage complex IT solutions.
π My dream is to empower every single person in the DevOps community to squeeze every last drop of potential out of Docker and container tech.
π³ As a [Docker Captain](https://www.docker.com/captains/vladimir-mikhalev/), Iβm stoked to share my knowledge, experiences, and a good dose of passion for the tech. My aim is to encourage learning, innovation, and growth, and to inspire the next generation of IT whizz-kids to push Docker and container tech to its limits.
Letβs do this together!
## My 2D Portfolio
πΉοΈ Click into [sre.gg](https://www.sre.gg/) β my virtual space is a 2D pixel-art portfolio inviting you to interact with elements that encapsulate the milestones of my DevOps career.
## My Courses
π Dive into my [comprehensive IT courses](https://www.heyvaldemar.com/courses/) designed for enthusiasts and professionals alike. Whether you're looking to master Docker, conquer Kubernetes, or advance your DevOps skills, my courses provide a structured pathway to enhancing your technical prowess.
π [Each course](https://www.udemy.com/user/heyvaldemar/) is built from the ground up with real-world scenarios in mind, ensuring that you gain practical knowledge and hands-on experience. From beginners to seasoned professionals, there's something here for everyone to elevate their IT skills.
## My Services
πΌ Take a look at my [service catalog](https://www.heyvaldemar.com/services/) and find out how we can make your technological life better. Whether it's increasing the efficiency of your IT infrastructure, advancing your career, or expanding your technological horizons β I'm here to help you achieve your goals. From DevOps transformations to building gaming computers β let's make your technology unparalleled!
## Patreon Exclusives
π Join my [Patreon](https://www.patreon.com/heyvaldemar) and dive deep into the world of Docker and DevOps with exclusive content tailored for IT enthusiasts and professionals. As your experienced guide, I offer a range of membership tiers designed to suit everyone from newbies to IT experts.
## My Recommendations
π Check out my collection of [essential DevOps books](https://kit.co/heyvaldemar/essential-devops-books)\
π₯οΈ Check out my [studio streaming and recording kit](https://kit.co/heyvaldemar/my-studio-streaming-and-recording-kit)\
π‘ Check out my [streaming starter kit](https://kit.co/heyvaldemar/streaming-starter-kit)## Follow Me
π¬ [YouTube](https://www.youtube.com/channel/UCf85kQ0u1sYTTTyKVpxrlyQ?sub_confirmation=1)\
π¦ [X / Twitter](https://twitter.com/heyvaldemar)\
π¨ [Instagram](https://www.instagram.com/heyvaldemar/)\
π [Mastodon](https://mastodon.social/@heyvaldemar)\
π§΅ [Threads](https://www.threads.net/@heyvaldemar)\
πΈ [Facebook](https://www.facebook.com/heyvaldemarFB/)\
π§ [Bluesky](https://bsky.app/profile/heyvaldemar.bsky.social)\
π₯ [TikTok](https://www.tiktok.com/@heyvaldemar)\
π» [LinkedIn](https://www.linkedin.com/in/heyvaldemar/)\
π£ [daily.dev Squad](https://app.daily.dev/squads/devopscompass)\
π§© [LeetCode](https://leetcode.com/u/heyvaldemar/)\
π [GitHub](https://github.com/heyvaldemar)## Community of IT Experts
πΎ [Discord](https://discord.gg/AJQGCCBcqf)
## Refill My Coffee Supplies
π [PayPal](https://www.paypal.com/paypalme/heyvaldemarCOM)\
π [Patreon](https://www.patreon.com/heyvaldemar)\
π [GitHub](https://github.com/sponsors/heyvaldemar)\
π₯€ [BuyMeaCoffee](https://www.buymeacoffee.com/heyvaldemar)\
πͺ [Ko-fi](https://ko-fi.com/heyvaldemar)π **Bitcoin (BTC):** bc1q2fq0k2lvdythdrj4ep20metjwnjuf7wccpckxc\
πΉ **Ethereum (ETH):** 0x76C936F9366Fad39769CA5285b0Af1d975adacB8\
πͺ **Binance Coin (BNB):** bnb1xnn6gg63lr2dgufngfr0lkq39kz8qltjt2v2g6\
π **Litecoin (LTC):** LMGrhx8Jsx73h1pWY9FE8GB46nBytjvz8g### Show some π by starring some of the [repositories](https://github.com/heyValdemar?tab=repositories)!

