We hope you found our previous two articles on “How to Install Carbonio CE On Ubuntu 20.04LTS” and “How to Install Carbonio CE On RHEL8” useful. Therefore, assuming that we are bringing another article in this series to you on How To Install Carbonio CE and this time we are installing it on another growing Operating System that is Rocky Linux 8.
Important Note:
CentOS, Rocky Linux, Alma Linux, and Debian are not officially supported operating systems (OS) for Carbonio CE. Therefore, we discourage users to install CE on any unofficial OS due to potential compatibility issues. Referring to the current official documentation and using the supported OS is recommended to avoid complications during installation and post installation experiences.
*** This article is written completely for experimental purposes.
Disclaimer
Carbonio CE is currently only available for 64-bit CPUs and can be installed on top of the below-mentioned distributions:
- Ubuntu 20.04 LTS
- RHEL 8
Warning:
Right now, there are no other officially supported distributions for Carbonio CE. So please consider all the aspects before installing Carbonio CE on Rocky Linux in any active/live/production environment.
Warning:
Linux distributions compatible with Ubuntu 20.04LTS (e.g., Debian) and RHEL 8 (e.g., AlmaLinux, Rocky Linux, CentOS etc) may be used as base OS for Carbonio CE installation in that case to satisfy all required dependencies, you may need to include adding third-party repositories or annually installing software packages which are not included in the official documentation.
Additional Requirements
Before entering the main installation phase, these are the additional requirements that you should keep it mind.
- valid DNS resolution for the domain (
MX
andA
records) and the FQDN (A
record) - Python 3, the latest version available on the Operating System chosen
- Perl, the latest version available on the Operating System chosen
Install Rocky Linux 8 On Your Server
You can visit this site and download it.
If you use a Base Environment (Server/Minimal install) with minimal/boot ISOS of Rocky Linux 8.7 (Green Obsidian), you will get errors during the installation process, therefore we recommend you to use Minimal Install (Basic Functionality) from the x86_64 DVD ISOS during the installation.
Rocky Linux is not yet the officially supported OS for Carbonio CE. So the steps mentioned here are not included in the Official Documentation Page.
Set Static IP Address
Set a static IP Address on your server. It can be a private or a public one.
[root@localhost ~]# cat /etc/sysconfig/network-scripts/ifcfg-ens160 | tail -9
NAME=ens160
UUID=68aba678-63b0-4f3f-915f-87d16d43b1d8
DEVICE=ens160
ONBOOT=yes
IPADDR=192.168.1.121
PREFIX=24
GATEWAY=192.168.1.1
DNS1=8.8.8.8
IPV6_PRIVACY=no
[root@localhost ~]#
Configure hostname and hosts file
Configure the hostname of the server in FQDN format.
[root@localhost ~]# cat /etc/hostname
mail.example.com
Modify the /etc/hosts
file as follows:
[root@localhost ~]# cat /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.1.121 mail.example.com mail
[root@localhost ~]#
Modify Selinux status
To proceed Carbonio CE Installation on Rocky Linux 8, selinux
status should be either disabled or permissive.
[root@localhost ~]# cat /etc/selinux/config
# This file controls the state of SELinux on the system.
# SELINUX= can take one of these three values:
# enforcing - SELinux security policy is enforced.
# permissive - SELinux prints warnings instead of enforcing.
# disabled - No SELinux policy is loaded.
SELINUX=disabled
# SELINUXTYPE= can take one of these three values:
# targeted - Targeted processes are protected,
# minimum - Modification of targeted policy. Only selected processes are protected.
# mls - Multi Level Security protection.
SELINUXTYPE=targeted
Modify The Firewall Service Status
Disable firewalld
daemon.
[root@localhost ~]# systemctl stop firewalld.service
[root@localhost ~]# systemctl disable firewalld.service
Removed /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
[root@localhost ~]#
Reboot the Server
As we have modified server hostname
& selinux
configuration it is recommended to reboot the server.
[root@localhost ~]# reboot now
Add Postgresql repositories
Add required repositories.
[root@mail ~]# yum -y install https://download.postgresql.org/pub/repos/yum/reporpms/EL-8-x86_64/pgdg-redhat-repo-latest.noarch.rpm
Install and configure dnsmasq [Optional]
If you have active resolvable public DNS records, then you can skip this step. But if you do not have any active/resolvable DNS records against the domain you are using, then follow below mentioned instructions:
[root@mail ~]# dnf install dnsmasq
[root@mail ~]# vi /etc/dnsmasq.conf
server=1.1.1.1
mx-host=example.com,mail.example.com,50
host-record=example.com,192.168.1.121
host-record=mail.example.com,192.168.1.121
Modify the /etc/resolv.conf
as follows:
[root@mail ~]# cat /etc/resolv.conf
# Generated by NetworkManager
search example.com
nameserver 127.0.0.1
Now restart dnsmasq
service.
[root@localhost ~]# systemctl restart dnsmasq
Managing Postgresql Database
The version of Postgresql
shipped by Rocky Linux 8 is older than required by Carbonio CE. We need to make sure that Postgresql 12
is installed in your system.
[root@mail ~]# dnf -qy module disable postgresql
[root@mail ~]# dnf -y install postgresql12 postgresql12-server
[root@mail ~]# /usr/pgsql-12/bin/postgresql-12-setup initdb
Initializing database ... OK
[root@mail ~]# systemctl enable --now postgresql-12
Created symlink /etc/systemd/system/multi-user.target.wants/postgresql-12.service β /usr/lib/systemd/system/postgresql-12.service.
[root@mail ~]#
Now, we need to modify one more file before reloading postgresql-12
[root@mail ~]# vi /var/lib/pgsql/12/data/pg_hba.conf
[find the line]
host all all 127.0.0.1/32 ident
[change it to]
host all all 127.0.0.1/32 md5
Now reload the postgresql-12
[root@mail ~]# systemctl reload postgresql-12
Install wget
Now we need to add zextras repository to the system. For that we need to download the script. For that we need to install wget
.
[root@mail ~]# dnf install wget
Add Carbonio repository to the system
You need to download and add zextras repository in your system in order to install necessary carbonio CE packages.
Head to the Carbonio Community Edition webpage and fill out the form. You will soon receive an e-mail including very easy instructions to add the repository to your operating system.
After you successfully added the repository, upgrade the system.
[root@mail ~]# dnf upgrade
Install service-discover-server
[root@mail ~]# dnf install service-discover-server
Install Carbonio Packages
Before installing the carbonio packages we need to enable powertools repo and install perl-common-sense
to avoid following errors:
Error:
Problem: package carbonio-mta-4.0.16-1.el8.x86_64 requires carbonio-amavisd, but none of the providers can be installed
– package carbonio-amavisd-2.12.2-2.el8.x86_64 requires carbonio-perl-convert-uulib, but none of the providers can be installed
– cannot install the best candidate for the job
– nothing provides perl(common::sense) needed by carbonio-perl-convert-uulib-1.8-3.el8.x86_64
– nothing provides perl-common-sense needed by carbonio-perl-convert-uulib-1.8-3.el8.x86_64
(try to add ‘–skip-broken’ to skip uninstallable packages or ‘–nobest’ to use not only best candidate packages)
Solution Reference: Visit this page
[root@mail ~]# dnf --enablerepo=powertools install perl-common-sense -y
[root@mail ~]# dnf install carbonio-directory-server \
carbonio-proxy \
carbonio-webui carbonio-files-ui \
carbonio-mta \
carbonio-appserver carbonio-logger \
carbonio-user-management \
carbonio-files-ce carbonio-files-db \
carbonio-storages-ce \
carbonio-preview-ce \
carbonio-docs-connector-ce carbonio-docs-editor \
carbonio-admin-ui carbonio-admin-console-ui \
carbonio-admin-login-ui
Use the following command to launch Carbonio bootstrap
[root@mail ~]# carbonio-bootstrap
Setup Carbonio Mesh & pending setups
[root@mail ~]# service-discover setup-wizard
[root@mail ~]# pending-setups -a
Configure Carbonio CE databases
[root@mail ~]# su - postgres -c "psql --command=\"CREATE ROLE carbonio_adm WITH LOGIN SUPERUSER encrypted password '123456';\""
[root@mail ~]# su - postgres -c "psql --command=\"CREATE DATABASE carbonio_adm owner carbonio_adm;\""
[root@mail ~]# PGPASSWORD=123456 carbonio-files-db-bootstrap carbonio_adm 127.0.0.1
Restart all services and check the status
[root@mail ~]# su - zextras
[zextras@mail ~]$ zmcontrol restart
[zextras@mail ~]$ zmcontrol -v
Carbonio Release 22.12.0
[zextras@mail ~]$
[zextras@mail ~]$
[zextras@mail ~]$ zmcontrol status
Host mail.example.com
amavis Running
antispam Running
antivirus Running
directory-server Running
logger Running
mailbox Running
memcached Running
mta Running
opendkim Running
proxy Running
service webapp Running
service-discover Running
stats Running
zimbra webapp Running
zimbraAdmin webapp Running
zimlet webapp Running
zmconfigd Running
[zextras@mail ~]$
And with this step the installation process is completed.
πππ
Now you/user can access the Webmail Interface panel using one of the following methods/links:
https://Server_IP_Address
https://mail.example.com
https://192.168.1.121
zextras is the default admin account in Carbonio CE server. In this case the account is, zextras@example.com
To access the admin account for the first time, you have to set/change itβs password:
[root@mail ~]# su - zextras
[zextras@mail ~]$ carbonio prov sp zextras@example.com 123456
Now you can access the Admin Panel Interface with that credential using one of the following methods/links:
https://Server_IP_Address:6071/login
https://mail.example.com:6071/login
https://192.168.1.121:6071/login
Thatβs it.
π
Comments
I need help, # dnf install service-discover-server root@mail.domain.com:~# dnf -y install service-discover-server Error: Problema: cannot install the best candidate for the job - package service-discover-server-0.1.9-1.el8.x86_64 from zextras requires service-discover-daemon, but none of the providers can be installed - package service-discover-agent-0.1.9-1.el8.x86_64 from zextras requires service-discover-daemon, but none of the providers can be installed - package service-discover-daemon-0.1.9-1.el8.x86_64 from zextras requires carbonio-core, but none of the providers can be installed - package service-discover-daemon-0.1.8-1.el8.x86_64 from zextras requires carbonio-core, but none of the providers can be installed - package carbonio-core-4.0.36-1.el8.x86_64 from zextras requires carbonio-perl-xml-simple, but none of the providers can be installed - package carbonio-core-4.0.33-1.el8.x86_64 from zextras requires carbonio-perl-xml-simple, but none of the providers can be installed - package carbonio-perl-xml-simple-2.25-2.el8.x86_64 from zextras requires carbonio-perl-xml-sax-expat, but none of the providers can be installed - nothing provides carbonio-perl-xml-sax needed by carbonio-perl-xml-sax-expat-0.51-2.el8.x86_64 from zextras
Hi Cristhiantl, Rocky Linux is not officially supported OS for Carbonio CE. We strongly discourage our users from installing Carbonio CE on it. You may face several issues during the installation. Also, this article was written during the earlier time of Carbonio CE so please use officially supported OS (Ubuntu 20.04LTS or RHEL8) and official documentation for all technical help. https://docs.zextras.com/carbonio-ce/html/index.html Regards,