Налаштуйте Zarafa і Yaffas на CentOS 6

Налаштуйте Zarafa і Yaffas на CentOS 6

Існує багато рішень, які замінюють Microsoft Exchange рішенням для Linux, але в усіх була одна проблема, яка мені дуже не сподобалася. Коли я отримував запрошення на зустріч, вони надходили як вкладені файли на мої пристрої iOS і не відкривалися безпосередньо в програмі календаря. Zarafa була єдиним випробуваним мною рішенням, яке відкривало події календаря в програмі календаря. Цей посібник навчить вас, як налаштувати Zarafa і Yaffas на CentOS 6.

Перш ніж почати

Ми робимо наступні припущення, щоб полегшити розуміння конфігурації. Однак ви повинні використовувати власні, реальні значення для цих елементів:

  • Доменом, на який я хочу отримувати пошту, є "example.com". Користувачі схожі на "[email protected]", "[email protected]".
  • Ім’я хоста для поштового сервера – «pegasus», тому повне ім’я домену для цього сервера – «pegasus.example.com».
  • Коли я використовую термін «панель керування сервером», я маю на увазі панель vultr.com .

Підготовка сервера (VPS)

Почніть з розгортання екземпляра сервера vultr.com. Я вибрав 1 ГБ VPS під керуванням CentOS 6, 32-розрядна версія. Після завершення встановлення ми готуємо сервер до того, щоб він став поштовим сервером.

На екрані «Мої сервери» панелі керування сервером натисніть посилання «Керувати» поруч із вашим щойно створеним сервером. На сторінці, що відкриється, ви можете побачити деталі вашого сервера. Натисніть на вкладку IPv4, а потім натисніть синю кнопку «Оновити». З’явиться поле введення тексту, у якому попередньо встановлено щось на кшталт «.vultr.com». Замініть цей запис на повне доменне ім’я вашого сервера (наприклад: pegasus.example.com) і натисніть синю кнопку «Оновити».

Тепер настав час увійти на новий сервер. Відкрийте термінал ssh і підключіться до свого сервера. Крім того, ви можете натиснути синю кнопку «Переглянути консоль», щоб отримати вікно браузера з екраном входу на ваш сервер.

ssh root@your_ip_address

Частина " your_ip_address" є основною IP-адресою, зазначеною на панелі керування сервером. Якщо ви використовуєте браузер для підключення до свого сервера, то просто увійдіть як root, використовуючи свій пароль root.

Спочатку ми встановлюємо правильне доменне ім’я. Відкрийте файл конфігурації мережі.

nano /etc/sysconfig/network

Замініть "vultr.guest" на повне доменне ім'я вашого сервера (Приклад: pegasus.example.com). Збережіть файл з допомогою Ctrl + X , потім Y .

Друге місце, яке ми змінюємо, - це /etc/hostsфайл.

nano /etc/hosts

Додайте наступний рядок. Він може бути у верхній частині файлу або в другому рядку.

127.0.1.1 pegasus.example.com pegasus

Збережіть файл з допомогою Ctrl + X , потім Y . Мені подобається переконатися, що все працює після перезавантаження, тому я перезавантажую VPS після цих змін.

reboot

Дайте машині хвилину для перезавантаження, а потім підключіть знову.

ssh root@your_ip_address

Yaffas і Zarafa потрібен репозиторій EPEL, який уже встановлений у джерелах на серверах vultr.com. Їм також потрібен репозиторій RPMforge. Виконайте таку команду, щоб встановити цей репозиторій.

32-розрядні системи:

rpm -Uvh http://packages.sw.be/rpmforge-release/rpmforge-release-0.5.2-2.el6.rf.i686.rpm

64-розрядні системи:

rpm -Uvh http://packages.sw.be/rpmforge-release/rpmforge-release-0.5.2-2.el6.rf.x86_64.rpm

Далі ми додаємо репозиторій Yaffas.

nano /etc/yum.repos.d/yaffas.repo

Вставте наступний текст у щойно створений файл:

[yaffas]
name = yaffas $releasever
baseurl = http://repo.yaffas.org/releases/latest/rhel/$releasever
enabled = 1
protect = 0
gpgcheck = 1
priority = 1

Збережіть файл з допомогою Ctrl + X , потім Y .

Щоб уникнути проблем із сумісністю, нам потрібно виключити деякі елементи зі сховища EPEL. Відкрийте файл репозиторію.

nano /etc/yum.repos.d/epel.repo

Потім у [epel]розділі, прямо під рядком «gpgkey», введіть наступне.

exclude=clamav* clamd* amavisd* libvmime libical libvmime-devel libical-devel php-mapi zarafa*

Повний розділ буде виглядати так:

[epel]
name=Extra Packages for Enterprise Linux 6 - $basearch
#baseurl=http://download.fedoraproject.org/pub/epel/6/$basearch
mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-6&arch=$basearch
failovermethod=priority
enabled=1 
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6
exclude=clamav* clamd* amavisd* libvmime libical libvmime-devel libical-devel php-mapi zarafa*

Збережіть файл з допомогою Ctrl + X , потім Y .

Імпортуйте ключ GPG для репозиторію Yaffas:

rpm --import http://repo.yaffas.org/repo.rpm.key

Тепер давайте приберемо ням.

yum clean all

На цьому етапі ми повинні бути готові до встановлення Yaffas. Встановіть його, просто ввівши цю команду.

yum install yaffas

Yum перевірить залежності та надасть вам підсумок.

Install 359 Package(s)

Total download size: 260 M
Installed size: 639 M
Is this ok [y/N]:

Натисніть Y , потім Enter/Return, щоб почати встановлення.

Установка займе деякий час, тому побалуйте себе кавою та печивом, дочекавшись завершення встановлення.

MySQL

Перш ніж почати остаточне налаштування, ми повинні налаштувати MySQL. Запустіть MySQL і почніть безпечне налаштування.

service mysqld restart
mysql_secure_installation

Щоб увійти в MySQL і захистити його, нам знадобиться поточний пароль користувача root. Якщо ви щойно встановили MySQL і ще не встановили пароль root, пароль буде порожнім, тому вам слід просто натиснути Enter/Return тут.

Enter current password for root (enter for none): **{press Enter/Return}**

[...]

Setting the root password ensures that nobody can log into the MySQL
root user without the proper authorisation.

Set root password? [Y/n] **Y**

New password: **{enter super secret password}**
Re-enter new password: **{enter super secret password again}**

Remove anonymous user? [Y/n] **Y**

Disallow root login remotely? [Y/n] **Y**

Remove test database and access to it? [Y/n] **Y**

Reload privilege tables now? [Y/n] **Y**

Конфігурація

Відкрийте веб-браузер і перейдіть за такою URL-адресою.

http://your_ip_address:10000

#If you have a DNS entry already, use this instead.
http://server.example.com:10000

Початкове ім'я користувача adminз паролем yaffas.

Після входу ви побачите майстра налаштування. Має 5 кроків. Натисніть «Далі», щоб почати.

Першим кроком є ​​введення нового пароля адміністратора. Введіть новий пароль двічі. Переконайтеся, що він досить складний, щоб бути безпечним, але не забувайте про це. Потім натисніть «Далі».

На наступному екрані можна налаштувати серверну частину MySQL. Єдине, що вам потрібно ввести, це пароль, який ви створили для користувача root MySQL.

На 4-му екрані налаштуйте свій поштовий домен. Введіть "example.com" у поле основного поштового домену. Це має бути ваш власний домен. Натисніть «Далі».

Я вважаю, що 5-й екран необов’язковий, але щоб бути в безпеці, створіть обліковий запис користувача, який буде адміністратором LDAP, а потім натисніть «Готово».

It will take a while until the setup finishes. Once it completes, a popup appears that tells you everything was successful. Click the "OK" button. After a moment, you will see the login screen again. You can login as admin with the new password that you created during the setup.

Extras

During the installation, some general self-signed certificates for the app are generated and installed. Personally, I prefer to have my own self-signed certificates to show the values that I entered and I also want to make sure that all requests are sent over HTTPS.

Zarafa comes with a few scripts to generate your own certificates. These are of course self-signed certificates.

Let's make a home for the certificate authority.

mkdir -p /etc/zarafa/ssl
chmod 700 /etc/zarafa/ssl
cd /etc/zarafa/ssl

... then run the script:

sh /usr/share/doc/zarafa/ssl-certificates.sh server

The parameter "server" means the certificate we create will be called server.pem.

You will be greeted with the following message.

No Certificate Authority Root found in current directory.
Press enter to create, or ctrl-c to exit.

Press Enter or Return.

The next message that appears is:

CA certificate filename (or enter to create)

Press Enter or Return to continue and create the CA Certificate.

After a little activity on the screen, you will get a prompt to enter the PEM passphrase. Enter any passphrase for the CA certificate, but make sure that you don't forget it, as you will need it later. For simplicity's sake, let's assume we chose the passphrase "ca-root-pem".

Answer the questions to generate the certificate. The answers here are my examples, so replace them with the correct values for yourself.

Country Name (2 letter code) [XX]: **MY**
State or Province Name (full name) []:**Selangor**
Locality Name (eg, city) [Default City]: **Shah Alam**
Organization Name (eg, company) [Default Company Ltd]: **ELMIMA-Systems**
Organizational Unit Name (eg, section) []: **Certificate Authority**
Common Name (eg, your name or your server's hostname) []:**server.example.com** **Must be the full domain name of your server**
Email Address []: **[email protected]**

Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password []: **Enter/Return**
An optional company name []: **Enter/Return**

Next, it will ask you for the passphrase of the cakey.pem file. This is the passphrase that you created earlier.

Enter pass phrase for /etc/pki/CA/private/./cakey.pem:ca-root-pem

Ви побачите невелику активність на екрані, потім він запропонує вам ввести парольну фразу PEM. Це парольна фраза для server.pemфайлу, який ми створили. Введіть все, що вам заманеться, але переконайтеся, що ви це не забудете. Для простоти ми будемо використовувати "server-pem-phrase".

Enter PEM pass phrase:**server-pem-phrase**
Verifying - Enter PEM pass phrase:**server-pem-phrase**

Час ввести значення для server.pemфайлу.

Country Name (2 letter code) [XX]: **MY**
State or Province Name (full name) []:**Selangor **
Locality Name (eg, city) [Default City]: **Shah Alam**
Organization Name (eg, company) [Default Company Ltd]: **ELMIMA-Systems**
Organizational Unit Name (eg, section) []: **Server SSL Certificate**
Common Name (eg, your name or your server's hostname) []: **server.example.com** **Must be the full domain name of your server**
Email Address []: [email protected]


Please enter the following 'extra' attributes
to be sent with your certificate request
A challenge password []: **Enter/Return**
An optional company name []: **Enter/Return**

Enter pass phrase for /etc/pki/CA/private/cakey.pem:ca-root-pem **Replace with your own passphrase**

Деякі дії на екрані показують, що сертифікат створено.

Sign the certificate? [y/n]:

Введіть Y і натисніть Enter/Return .

1 out of 1 certificate requests certified, commit? [y/n]

Введіть Y і натисніть Enter/Return .

Create public key from this certificate? [y]

Нам це насправді не потрібно, але я думаю, що створити його не завадить. Просто натисніть Enter/Return .

Enter pass phrase for server.pem: **server-pem-phrase**

Тепер настав час налаштувати server.cfgфайл для Zarafa.

nano /etc/zarafa/server/cfg

Знайдіть запис server_ssl_enabledі змініть його значення на "так" (без лапок).

Знайдіть запис server_ssl_portі підтвердьте, що це 237.

Знайдіть запис server_ssl_key_fileі встановіть для нього значення " /etc/zarafa/ssl/server.pem" (без лапок).

Створіть запис, server_ssl_key_passвикористовуйте парольну фразу, яку ви створили для server.pemфайлу (наприклад: server-pem-phrase), як його значення.

Знайдіть запис server_ssl_ca_file. Оригінальна документація для Zarafa передбачає, що шлях є /etc/zarafa/ssl/demoCA/cacert.pem, однак у CentOS цей шлях є /etc/pki/CA/cacert.pem. Відповідним чином оновіть це значення.

server_ssl_ca_file = /etc/pki/CA/cacert.pem

Перезапустіть сервер Zarafa.

service zarafa restart

Давайте згенеруємо сертифікат для Apache.

cd /etc/zarafa/ssl
openssl req -nodes -newkey rsa:2048 -keyout zarafa-ssl.key -out zarafa-ssl.csr

Отримуємо ще одну форму для створення сертифіката.

Country Name (2 letter code) [XX]: **MY **
State or Province Name (full name) []: **Selangor**
Locality Name (eg, city) [Default City]: **Shah Alam**
Organization Name (eg, company) [Default Company Ltd]: **ELMIMA-Systems**
Organizational Unit Name (eg, section) []: **Zarafa Web Services**
Common Name (eg, your name or your server's hostname) []: **server.example.com** **Must be the full domain name of your server**
Email Address []: **[email protected]**

Потім підпишіть сертифікат.

openssl x509 -req -in ./zarafa-ssl.csr -signkey zarafa-ssl.key -out zarafa-ssl.crt -days 9999

... і додайте його в Apache.

cd /etc/httpd/conf.d
nano ssl.conf

Знайдіть рядок «SSLCertificateFile /opt/yaffas/etc/ssl/certs/zarafa-webaccess.crt» і змініть його на «SSLCertificateFile /etc/zarafa/ssl/zarafa-ssl.crt».

Знайдіть рядок «SSLCertificateKeyFile /opt/yaffas/etc/ssl/certs/zarafa-webaccess.key» і змініть його на «SSLCertificateKeyFile /etc/zarafa/ssl/zarafa-ssl.key»

Збережіть файл і вийдіть.

Тепер відкрийте zarafa-webapp.confфайл.

nano /etc/httpd/zarafa-webapp.conf

Знайдіть наступні 2 рядки та розкоментуйте їх.

#php_flag session.cookie_secure on
#php_flag session.cookie_httponly on

Додайте наступні рядки.

RewriteEngine On
RewriteCond % !=on
RewriteRule (.*) https://pegasus.example.com/webapp/ [R] (Of course use your own real domain here)

Збережіть файл і вийдіть. Потім перезапустіть Apache.

service httpd restart

Тепер веб-додаток завжди використовуватиме HTTPS. Ви можете зробити те ж саме для zarafa-webapp.conf.

Зауваження

Під час тестування встановлення на CentOS я помітив деякі повідомлення про помилки через відсутність папок. Ви можете виправити це за допомогою наступних команд.

mkdir -p /var/run/policyd-weight/cores/master
mkdir -p /var/run/policyd-weight/cores/cache
chown -R polw /var/run/policyd-weight

Щоб використовувати ваш новий сервер Zarafa як поштовий сервер для вашого домену, вам потрібно буде налаштувати запис A та MX для вашого домену. За бажанням ви можете використовувати свою улюблену пошукову систему, щоб знайти SPF Wizard, який спрощує створення запису SPF для вашого домену.


Створення мережі серверів Minecraft за допомогою BungeeCord на Debian 8, Debian 9 або CentOS 7

Створення мережі серверів Minecraft за допомогою BungeeCord на Debian 8, Debian 9 або CentOS 7

Що вам знадобиться Vultr VPS з принаймні 1 Гб оперативної пам’яті. Доступ по SSH (з правами root/адміністратора). Крок 1: Встановлення BungeeCord Перш за все

Підвищте продуктивність за допомогою Z і Zsh на CentOS

Підвищте продуктивність за допомогою Z і Zsh на CentOS

Вступ Робота в системах Linux означає, що ви використовуєте командний рядок частіше, ніж ні. Доводиться вводити довгі імена каталогів знову і знову

Налаштуйте кластер RethinkDB на CentOS 7

Налаштуйте кластер RethinkDB на CentOS 7

Вступ RethinkDB — це база даних NoSQL, яка зберігає дані як документи JSON. Він має надзвичайно інтуїтивно зрозумілу мову запитів і має загальнодоступні функції i

Встановіть DirectAdmin на CentOS 6 або 7

Встановіть DirectAdmin на CentOS 6 або 7

DirectAdmin — це запатентована веб-панель керування, яку можна встановити на своєму сервері, яка пропонує різноманітні функції системного адміністрування. У цьому

Огляд процесу завантаження та усунення несправностей CentOS 7 і RHEL 7

Огляд процесу завантаження та усунення несправностей CentOS 7 і RHEL 7

У цій статті описується процес завантаження систем CentOS/RHEL 7.x. Хоча він може залишатися схожим на попередні випуски, з RHEL 7, systemd є

Встановіть PostgreSQL на CentOS 7

Встановіть PostgreSQL на CentOS 7

Вступ PostgreSQL — це найдосконаліша у світі система управління реляційними базами даних (RDBMS) з відкритим кодом. Він відповідає стандартам ANSI SQL:2008

Основи керування користувачами в системах CentOS

Основи керування користувачами в системах CentOS

Керування користувачами може бути складним завданням: від щоденного обслуговування, ризиків безпеки та відсутності ретельної онлайн-документації. Ця стаття допоможе вам почати

Налаштуйте медіасервер Red5 на CentOS 7

Налаштуйте медіасервер Red5 на CentOS 7

Використання іншої системи? Red5 — це медіасервер із відкритим вихідним кодом, реалізований на Java, який дозволяє запускати багатокористувацькі програми Flash, такі як прямі трансляції

Початкове налаштування сервера CentOS 7

Початкове налаштування сервера CentOS 7

Вступ Нещодавно активований сервер CentOS 7 має бути налаштований, перш ніж його можна буде використовувати як робочу систему. У цій статті найголовніше

Перевірте швидкість Інтернету за допомогою Speedtest-cli на CentOS

Перевірте швидкість Інтернету за допомогою Speedtest-cli на CentOS

Вступ У цьому підручнику встановіть Speedtest-cli, щоб перевірити швидкість мережі вашого сервера. Speedtest-cli — це інтерфейс командного рядка для th

Установіть середовище GUI на CentOS 6

Установіть середовище GUI на CentOS 6

Управління сервером лише за допомогою SSH може бути страшним. Добре для нас те, що у Vultr є параметр View Console. Щоб повністю використовувати консоль Vultrs VNC

Налаштувати часовий пояс і NTP на CentOS 6

Налаштувати часовий пояс і NTP на CentOS 6

Вступ Для адміністраторів серверів важливо правильно встановити та підтримувати час на серверах. Неправильно налаштований час спричинить хаос усередині

Як встановити Foreman на CentOS 7

Як встановити Foreman на CentOS 7

Використання іншої системи? Foreman — це безкоштовний інструмент з відкритим вихідним кодом, який допоможе вам налаштувати та керувати фізичними та віртуальними серверами. Предварня

Захист і зміцнення ядра CentOS 7 за допомогою Sysctl

Захист і зміцнення ядра CentOS 7 за допомогою Sysctl

Вступ Sysctl дозволяє користувачеві точно налаштувати ядро ​​без необхідності перебудовувати ядро. Він також негайно застосує зміни, таким чином сервер виграв

Використовуйте Nethogs для моніторингу використання пропускної здатності мережі

Використовуйте Nethogs для моніторингу використання пропускної здатності мережі

У цьому підручнику ми розглянемо процес встановлення та використання nethogs на CentOS 6x x64. nethogs — це інструмент моніторингу мережі, який дозволяє Networ

Встановіть CentOS Web Panel (CWP) на CentOS 6

Встановіть CentOS Web Panel (CWP) на CentOS 6

CentOS Web Panel або CWP — це панель керування хостингом з відкритим кодом, яка призначена для швидкого та легкого керування сервером. Він включає в себе всі функції o

Налаштуйте Zarafa і Yaffas на CentOS 6

Налаштуйте Zarafa і Yaffas на CentOS 6

Існує багато рішень, які замінюють Microsoft Exchange рішенням для Linux, але в усіх була одна проблема, яка мені дуже не сподобалася. Коли отримаю

Як встановити Apache Maven 3.5 на CentOS 7

Як встановити Apache Maven 3.5 на CentOS 7

Apache Maven — це безкоштовний інструмент управління проектами програмного забезпечення з відкритим вихідним кодом, який широко використовується для розгортання програм на основі Java. Передумови A newl

Як встановити та налаштувати Concourse CI на CentOS 7

Як встановити та налаштувати Concourse CI на CentOS 7

Використання іншої системи? Вступ Постійна інтеграція – це практика розробки програмного забезпечення DevOps, яка дозволяє розробникам часто об’єднувати

Розгортання серверного сервера Glowing Bear на CentOS 7

Розгортання серверного сервера Glowing Bear на CentOS 7

Glowing Bear — це веб-інтерфейс для клієнта WeeChat IRC і прагне бути сучасним інтерфейсом. Завдяки таким функціям, як клік, щоб згадати, замінити смайли

Повстання машин: застосування ШІ в реальному світі

Повстання машин: застосування ШІ в реальному світі

Штучний інтелект не в майбутньому, він тут прямо в сьогоденні У цьому блозі Прочитайте, як програми штучного інтелекту вплинули на різні сектори.

DDOS-атаки: короткий огляд

DDOS-атаки: короткий огляд

Ви також стали жертвою DDOS-атак і спантеличені методами запобігання? Прочитайте цю статтю, щоб вирішити свої запитання.

Ви коли-небудь замислювалися, як хакери заробляють гроші?

Ви коли-небудь замислювалися, як хакери заробляють гроші?

Можливо, ви чули, що хакери заробляють багато грошей, але чи замислювалися ви коли-небудь, як вони заробляють такі гроші? давайте обговоримо.

Революційні винаходи від Google, які полегшать ваше життя.

Революційні винаходи від Google, які полегшать ваше життя.

Ви хочете побачити революційні винаходи Google і як ці винаходи змінили життя кожної людини сьогодні? Тоді читайте в блозі, щоб побачити винаходи Google.

Friday Essential: Що сталося з автомобілями, керованими штучним інтелектом?

Friday Essential: Що сталося з автомобілями, керованими штучним інтелектом?

Концепція самокерованих автомобілів, щоб вирушати в дороги за допомогою штучного інтелекту, є мрією, яку ми давно мріємо. Але, незважаючи на кілька обіцянок, їх ніде не видно. Прочитайте цей блог, щоб дізнатися більше…

Технологічна сингулярність: віддалене майбутнє людської цивілізації?

Технологічна сингулярність: віддалене майбутнє людської цивілізації?

Оскільки наука розвивається швидкими темпами, бере на себе багато наших зусиль, ризики піддати себе незрозумілій Сингулярності також зростає. Читайте, що може означати для нас сингулярність.

Еволюція зберігання даних – інфографіка

Еволюція зберігання даних – інфографіка

Методи зберігання даних можуть розвиватися з моменту народження Даних. Цей блог висвітлює еволюцію зберігання даних на основі інфографіки.

Функціональні можливості шарів еталонної архітектури великих даних

Функціональні можливості шарів еталонної архітектури великих даних

Прочитайте блог, щоб дізнатися про різні шари архітектури великих даних та їх функціональні можливості найпростішим способом.

6 дивовижних переваг використання пристроїв розумного дому в нашому житті

6 дивовижних переваг використання пристроїв розумного дому в нашому житті

У цьому цифровому світі пристрої розумного дому стали важливою частиною життя. Ось кілька дивовижних переваг пристроїв розумного дому щодо того, як вони роблять наше життя гідним життя та спрощують його.

Оновлення доповнення macOS Catalina 10.15.4 спричиняє більше проблем, ніж вирішує

Оновлення доповнення macOS Catalina 10.15.4 спричиняє більше проблем, ніж вирішує

Нещодавно Apple випустила додаткове оновлення macOS Catalina 10.15.4, щоб виправити проблеми, але схоже, що оновлення викликає більше проблем, що призводять до блокування комп’ютерів Mac. Прочитайте цю статтю, щоб дізнатися більше