Introduction: In this tutorial, you will learn how to set up your own mail server using Mailcow on an Ubuntu Server. Mailcow allows you to host your custom mail server with features like domain customization, contact synchronization, and calendar integration.
Prerequisites:
- A domain name
- Basic knowledge of Docker
- Note: Some cloud servers may have port 25 and 465 blocked by default for anti-spam measures.
Step 1 - Create a New Cloud Server
- Sign in to your Cloud Console.
- Create a new project and name it accordingly.
- Choose a server location and type based on your needs (at least 7GB RAM for Mailcow).
- Click "Add Server" and select your server image. While this tutorial is based on Ubuntu 22.04, you can adapt it for Debian 11.
- Under "Cloud config," enter: #include https://get.docker.com(to install Docker).
- Select your SSH key. You can generate an SSH key if you don't have one.
- Enter your server hostname (e.g., mail.example.com).
- Click "Create & Buy Now."
Step 2 - Set Up DNS
- Create DNS records for your domain:
- Create an A record for "mail.example.com" with your server's IPv4 address.
- Create an AAAA record for "mail.example.com" with your server's IPv6 address.
- Set up MX record pointing to "mail.example.com."
- Create "autodiscover.example.com" and "autoconfig.example.com" CNAME records pointing to "mail.example.com."
 
Your DNS configuration should resemble the following:
# Name              Type       Value
mail                IN A       <IPv4_address>
mail                IN AAAA    <IPv6_address>
autodiscover        IN CNAME   mail
autoconfig          IN CNAME   mail
@                   IN MX 10   mail
Refer to Mailcow documentation for advanced DNS configurations.
Step 3 - Install Updates and Docker Compose
- Wait for your server to start and connect to it via SSH using your private key.
- Install available updates and upgrades:
apt update && apt upgrade -y
- Consider rebooting the server if kernel updates were installed.
Step 4 - Clone the Mailcow Repository
- Change your working directory to /opt:
cd /opt
- Clone the Mailcow GitHub repository:
git clone https://github.com/mailcow/mailcow-dockerized
Step 5 - Create Configuration, Pull Docker Containers, and Start Mailcow
- Change your working directory to /opt/mailcow-dockerized:
cd /opt/mailcow-dockerized
- Generate the Mailcow configuration:
./generate_config.sh
- 
When prompted, enter your domain name (e.g., mail.example.com). 
- 
Pull Docker images: 
docker-compose pull
- Start Mailcow:
docker-compose up -d
Step 6 - Set Up Reverse DNS Entries
- Access your cloud server console.
- Set up reverse DNS entries for your server's IPv4 and IPv6 addresses.
Step 7 - First Login to Mailcow
- Access your Mailcow instance at https://mail.example.org.
- Log in with the default credentials:
- Username: admin
- Password: moohoo
 
Important: Change your password immediately for security.
Step 8 - Add Domain(s) to Mailcow
- Go to "Configuration" -> "Mail setup."
- Under the "Domain" tab, add your domain.
Step 9 - Set Up DKIM
- In "Configuration" -> "Configuration & Details," select "DKIM" in the sidebar.
- Scroll down to the mask where you can enter your domain.
- Click "Select domains with missing keys" to fill in your domain name.
- Select a 2048 key and click "Add."
- Copy the public key and create a DNS TXT entry called "dkim._domainkey" with the copied content.
Step 10 - Create a Mailbox
- In "Configuration" -> "Mail setup," create a mailbox.
- Access SOGo at https://mail.example.com/SOGo.
Step 11 - Create Backups
- 
Create manual backups: - Connect to your server using SSH.
- Go to the Mailcow directory with the backup script: /opt/mailcow-dockerized/helper-scripts.
- Run the backup script: ./backup_and_restore.sh backup all --delete-days 7. Adjust the delete days as needed.
 
- 
Create automated backups: - Run crontab -eto enter your cron task list.
- Paste the following and update details as needed:
javascript0 5 * * * MAILCOW_BACKUP_LOCATION=/opt/mailcow-backups /opt/mailcow-dockerized/helper-scripts/backup_and_restore.sh backup all --delete-days 7
 
- Run 
Step 12 - Updating Your Mailcow Instance
- Check for current backups before updates.
- Connect to your server via SSH.
- Go to the Mailcow directory: /opt/mailcow-dockerized.
- Run: ./update.sh.
- Confirm the update and follow on-screen instructions.
- After the update, do not shut down the server or Docker containers to prevent data corruption.
General Recommendations:
- Consider storing backups in a location separate from your server (e.g., cloud storage).
- Keep an eye on Mailcow releases for updates and security patches.
Search
 
                         
                        