Requirements
- CentOS 7 / RHEL 7 / Ubuntu 16.04
- 8 GB RAM
- 5 GB Free Space on /opt/Zimbra
- 10 GB free disk space on /opt and /tmp
- Fully Qualified Domain Name (FQDN), in my case it is “mail.itzgeek.local”
- A & MX record for your Server
- The firewall should be disabled
Prerequisites
Become the root user.sudo su -OR
su -Install below packages
### CentOS 7 / RHEL 7 ###
yum install -y bind-utils net-tools wget curl perl
### Ubuntu 16.04 ###
apt-get install -y curl perl wget
Set the hostname of your mail server.hostnamectl set-hostname mail.itzgeek.localAdd the following lines in the
/etc/hosts
file.192.168.1.25 mail.itzgeek.local mail
Firewall
Zimbra recommends the firewall to be disabled.### CentOS 7 / RHEL 7 ### systemctl stop firewalld systemctl disable firewalld ### Ubuntu 16.04 ### ufw disable
Disable Services
CentOS 7 / RHEL 7
In CentOS 7, postfix is installed and running by default. So, we need to disable it for Zimbra installation.systemctl stop postfix
systemctl disable postfix
Ubuntu 16.04
In Ubuntu 16.04, dnsmasq uses port 53 and acts as local resolver which conflicts with Zimbra DNS. So, we need to disable the use of dnsmasq.Edit NetworkManager.conf file.
nano /etc/NetworkManager/NetworkManager.conf
Comment out the dns=dnsmasq
line by putting a hash #
in front of it.#dns=dnsmasq
Then, restart the service.
service network-manager restart
Mail Server Setup
For this demo, I will configure Zimbra to receive emails for domainitzgeek.local
.itzgeek.local is not a live internet domain, and it can’t receive or send emails to internet domains such as gmail.com or yahoo.com. So, I have created one more email server (
blog.local
) in my environment to test the functionality.
Installation for the live domain is similar to local domain setup, and it will work only if the A, MX and SPF records are created properly as shown in the next step.
Create A and Mx Record
You would need to create A and MX record for your domain to receive emails.
Local Test Domain
The local test domain set up is done by creating A and MX record on the local DNS server.READ: How To Configure DNS Server on CentOS 7 / RHEL 7
READ: How To Configure DNS Server On Ubuntu 16.04
Verify A and MX Records
Verify that the A is configured for your domain usingdig
command.dig -t A mail.itzgeek.local
Output:; <<>> DiG 9.9.4-RedHat-9.9.4-72.el7 <<>> mail.itzgeek.local
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 49222
;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 0, ADDITIONAL: 1
;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 4000
;; QUESTION SECTION:
;mail.itzgeek.local. IN A
;; ANSWER SECTION:
mail.itzgeek.local. 3600 IN A 192.168.1.25
;; Query time: 0 msec
;; SERVER: 192.168.1.230#53(192.168.1.230)
;; WHEN: Thu Dec 06 09:53:22 IST 2018
;; MSG SIZE rcvd: 63
Verify MX records.dig -t MX itzgeek.local
Output:; <<>> DiG 9.9.4-RedHat-9.9.4-72.el7 <<>> -t MX itzgeek.local
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 621
;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 0, ADDITIONAL: 2
;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 4000
;; QUESTION SECTION:
;itzgeek.local. IN MX
;; ANSWER SECTION:
itzgeek.local. 3600 IN MX 10 mail.itzgeek.local.
;; ADDITIONAL SECTION:
mail.itzgeek.local. 3600 IN A 192.168.1.25
;; Query time: 0 msec
;; SERVER: 192.168.1.230#53(192.168.1.230)
;; WHEN: Thu Dec 06 09:54:02 IST 2018
;; MSG SIZE rcvd: 79
Live Domain
A record is to point your system’s FQDN (hostname) to your mail server IPv4 address.NAME TTL TYPE DATA
mail.itzgeek.com. 3600 A 35.193.38.113
MX record is to specify which mail server is responsible for accepting email messages on behalf of your domain.NAME TYPE PRIORITY DATA
itzgeek.com. MX 10 mail.itzgeek.com.
SPF record is used to verify which mail servers are permitted to send
email on behalf of your domain. In the example below, emails sent from
all servers defined in MX record of itzgeek.com are permitted.itzgeek.com. 3600 IN TXT "v=spf1 mx mx:itzgeek.com ~all"
PTR (Pointer) is an IP address to domain name mapping, and it’s the
exact opposite of A record which maps domain names to IP addresses.Most of the organizations have spam filters which will perform a reverse DNS lookup on the IP address of your email server that is sending emails to them and would block emails from your server if the PTR record is not set. You would most likely need to reach to your hosting provider / ISP and make a request to create a reverse PTR record for your mail server IP address
If you are struggling to create DNS records, you can always reach your domain registrar for assistance.
Download Zimbra Collaboration 8.8 – Open Source Edition
Create a directory calledzimbra
to place the installer.mkdir /zimbra
cd /zimbra
Download the Zimbra Collaboration Suite 8.8 – Open Source Edition from the official site or download using the wget command### CentOS 7 / RHEL 7 ### wget https://files.zimbra.com/downloads/8.8.10_GA/zcs-8.8.10_GA_3039.RHEL7_64.20180928094617.tgz ### Ubuntu 16.04 ### wget https://files.zimbra.com/downloads/8.8.10_GA/zcs-8.8.10_GA_3039.UBUNTU16_64.20180928094617.tgz
Install Zimbra Collaboration 8.8 – Open Source Edition
Extract the downloaded Zimbra archive file using thetar
command### CentOS 7 / RHEL 7 ### tar -zxvf zcs-8.8.10_GA_3039.RHEL7_64.20180928094617.tgz ### Ubuntu 16.04 ### tar -zxvf zcs-8.8.10_GA_3039.UBUNTU16_64.20180928094617.tgzGo to the extracted folder.
### CentOS 7 / RHEL 7 ###
cd zcs-8.8.10_GA_3039.RHEL7_64.20180928094617 ### Ubuntu 16.04 ### cd zcs-8.8.10_GA_3039.UBUNTU16_64.20180928094617/Execute the install script.
./install.sh
Once you execute the install script, you will get text-based installation wizard. Press Y
to accept the Zimbra license agreement.data:image/s3,"s3://crabby-images/e0fdd/e0fdd48978630dfffa82f6617ed0c200036fddd1" alt="Install Open Source Zimbra Mail Server on CentOS 7 - Accept Zimbra License Agreement"
data:image/s3,"s3://crabby-images/50fde/50fdeca3abab2d6f366e30e34bf142f17b309811" alt="Install Open Source Zimbra Mail Server on CentOS 7 - Configure Zimbra Package Repository"
Y
to all Zimbra Components to install.Also, press Y
to continue to download the Zimbra related packages. This task can take time depending upon on your internet speed.data:image/s3,"s3://crabby-images/17630/1763026977a949b65b7f2ca29be82eb946c5bd7a" alt="Install Open Source Zimbra Mail Server on CentOS 7 - Confirm Zimbra Installation"
In my case, it is
itzgeek.local
.
If your installation is for the live domain, enter like domain.com or domain.org.
data:image/s3,"s3://crabby-images/2e40e/2e40ef57daed4acda5fbcc0015c77136a49d5fc0" alt="Install Open Source Zimbra Mail Server on CentOS 7 - Enter Domain"
7
.data:image/s3,"s3://crabby-images/84e32/84e32b253f66eb51a66840238153e3756cd4d942" alt="Install Open Source Zimbra Mail Server on CentOS 7 - Set Zimbra Admin Password"
4
to set the Zimbra admin password.data:image/s3,"s3://crabby-images/a09f8/a09f8578eed83dade6a2d8e0b0af004b7f28da62" alt="Install Open Source Zimbra Mail Server on CentOS 7 - Enter Zimbra Admin Password"
r
to go to the previous menu and then press a
to apply the changes.data:image/s3,"s3://crabby-images/8de6a/8de6af752e6b63b8105fd912b3687022cba4796f" alt="Install Open Source Zimbra Mail Server on CentOS 7 - Apply Configuration"
data:image/s3,"s3://crabby-images/5d68b/5d68bc198a120ba9eb5f5b617cbac5a37540a9af" alt="Install Open Source Zimbra Mail Server on CentOS 7 - Complete Configuration"
data:image/s3,"s3://crabby-images/b75e3/b75e35bcf6e52450d064cd7f1299ea1bc2759910" alt="Install Open Source Zimbra Mail Server on CentOS 7 - Installation Completed"
Verify Zimbra Services
To check the Zimbra services status from the command line, you would need to switch to zimbra user.[root@mail ~]# su - zimbra
[zimbra@mail ~]$ zmcontrol status
Output:data:image/s3,"s3://crabby-images/7c3fc/7c3fc96fe970880b13e8bc78fafe5b24fa7c8a1e" alt="Zimbra Mail Services Status"
[zimbra@mail ~]$ zmcontrol restart
Output:data:image/s3,"s3://crabby-images/1dfd8/1dfd819d2a6268c785c238bf87db588b4013547e" alt="Restarting Zimbra Server"
Access Zimbra Admin Portal
To access the Zimbra Admin Portal, type below URL in the Web Browser.
https://mail.itzgeek.local:7071/
You will get the Zimbra admin login page. Login with admin
and the password you entered during the installation.data:image/s3,"s3://crabby-images/6672b/6672be512b2742cab90ca08497571e8c18d40a0c" alt="Zimbra Admin Portal Login"
data:image/s3,"s3://crabby-images/17884/178842b26bd56d6d3a4857a30027e937e2c9cb75" alt="Zimbra Admin Portal"
Create Email Account (Optional)
To test the functionality of Zimbra, I would be creating an email account for receiving an email from second test domainblog.local
. To create an email account, go to Manage >> Accounts >> New.data:image/s3,"s3://crabby-images/b2a0e/b2a0e77c66faba05b977fb4510287aa91c212fba" alt="Zimbra Admin Portal - Create New Email Account"
data:image/s3,"s3://crabby-images/8e3c6/8e3c6e39904727c152c68aab90f421d828216533" alt="Zimbra Admin Portal - New Account Name"
data:image/s3,"s3://crabby-images/5c15e/5c15ea4892bc4625317cadfe3ed7e6d7ab2f7ebd" alt="Zimbra Admin Portal - New Account Password"
Access Zimbra Web Mail Client
To access Zimbra Mail Web Client, type the following URL in the browser
https://mail.itzgeek.local
Log in as the newly created user or as admin to see admin emails.Here, I will log in as
raj@itzgeek.local
.data:image/s3,"s3://crabby-images/07b0e/07b0ea1d5215e8602c427303c8b20dc739e1f059" alt="Zimbra Web Mail Client Login Page"
data:image/s3,"s3://crabby-images/f71ca/f71cac6b31b48f42cee6b5b9d8b93c8c1cd5b764" alt="Zimbra Web Mail"
data:image/s3,"s3://crabby-images/008d4/008d4ec50f9a4e3b61c39dd81377eb8941f0655e" alt="Zimbra Web Mail Client - Email From Other Domain"
UnInstall Zimbra Collaboration 8.8 – Open Source Edition
In any time, you want to uninstall Zimbra mail server from the system. Go to the installer directory.cd /zimbra/zcs-8.8.10_GA_3039.RHEL7_64.20180928094617
Then, run the install.sh
script followed by -u
../install.sh -u
Source : https://www.itzgeek.com/how-tos/linux/centos-how-tos/how-to-install-open-source-zimbra-mail-server-8-8-on-centos-7-rhel-7-ubuntu-16-04.html