Поиск по сайту:

Как установить программное обеспечение Mailtrain Newsletter на Ubuntu 18.04


На этой странице

  1. Требования
  2. Начало работы
  3. Установите Docker и Docker Compose
  4. Установка Mailtrain с помощью Docker
  5. Доступ к веб-интерфейсу Mailtrain
  6. Настройка Nginx в качестве обратного прокси-сервера для Mailtrain
  7. Защитите почтовый поезд с помощью Lets Encrypt
  8. Заключение

Mailtrain — это бесплатное приложение для рассылки новостей с открытым исходным кодом, созданное на основе Node.js и поддерживающее серверные части баз данных MySQL/MariaDB. Mailtrain позволяет добавлять подписчиков вручную, через API или импортировать из CSV-файла. Mailtrain поставляется с богатым набором функций, включая редакторы шаблонов, автоматизацию, настраиваемые поля, RSS-кампанию, редактор HTML-кода и многое другое. Если у вас длинный список подписчиков и вы хотите легко им управлять, то Mailtrain — лучший выбор для вас.

В этом руководстве мы покажем вам, как установить приложение для рассылки новостей Mailtrain с помощью Docker на сервере Ubuntu 18.04.

Требования

  • Сервер под управлением Ubuntu 18.04.
  • Действительное доменное имя, указанное с IP-адресом вашего сервера.
  • На вашем сервере настроен пароль root.

Начиная

Перед запуском вам нужно будет обновить вашу систему до последней версии. Вы можете сделать это, выполнив следующую команду:

apt-get update -y
apt-get upgrade -y

Затем перезагрузите систему, чтобы применить изменения.

Установите Docker и Docker Compose

По умолчанию последняя версия Docker недоступна в стандартном репозитории Ubuntu 18.04. Итак, вам нужно будет добавить репозиторий Docker в вашу систему.

Сначала установите необходимые пакеты с помощью следующей команды:

apt-get install curl git apt-transport-https ca-certificates -y

Затем загрузите и добавьте ключ PGP Docker с помощью следующей команды:

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | apt-key add -

Затем добавьте репозиторий Docker CE, отредактировав файл /etc/apt/sources.list:

nano /etc/apt/sources.list

Добавьте следующую строку в конец файла:

deb [arch=amd64] https://download.docker.com/linux/ubuntu bionic stable

Сохраните и закройте файл, когда закончите. Затем обновите репозиторий и установите Docker CE с помощью следующих команд:

apt-get update -y
apt-get install docker-ce -y

После успешного завершения установки вы можете проверить статус службы Docker с помощью следующей команды:

systemctl status docker

Вы должны увидеть следующий вывод:

Docker Application Container Engine
   Loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled)
   Active: active (running) since Thu 2019-10-24 16:15:25 UTC; 21min ago
     Docs: https://docs.docker.com
 Main PID: 1402 (dockerd)
    Tasks: 45
   CGroup: /system.slice/docker.service
           ?? 1402 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock
           ??10312 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-port 3000 -container-ip 172.18.0.4 -container-port 3000

Oct 24 16:23:04 ubuntu1804 dockerd[1402]: time="2019-10-24T16:23:04.817021656Z" level=info msg="Layer sha256:b875b006eb8ffb0434ce3a26cb04c9017c
Oct 24 16:24:09 ubuntu1804 dockerd[1402]: time="2019-10-24T16:24:09.879265134Z" level=info msg="ignoring event" module=libcontainerd namespace=
Oct 24 16:24:10 ubuntu1804 dockerd[1402]: time="2019-10-24T16:24:10.065610315Z" level=warning msg="20676b10252b4a484e32a7d7534b3b386cc2a1e5efd1
Oct 24 16:25:52 ubuntu1804 dockerd[1402]: time="2019-10-24T16:25:52.649551513Z" level=info msg="Layer sha256:903ab9000f0a93e49537d5d00c5c8a8cab
Oct 24 16:26:47 ubuntu1804 dockerd[1402]: time="2019-10-24T16:26:47.428865652Z" level=info msg="Layer sha256:903ab9000f0a93e49537d5d00c5c8a8cab
Oct 24 16:27:41 ubuntu1804 dockerd[1402]: time="2019-10-24T16:27:41.603287585Z" level=info msg="Layer sha256:903ab9000f0a93e49537d5d00c5c8a8cab

Затем установите последнюю версию docker compose с помощью команды pip, как показано ниже:

apt-get install python-pip
apt-get install docker-compose

После завершения установки можно переходить к следующему шагу.

Установите Mailtrain с помощью Docker

Сначала загрузите последнюю версию Mailtrain из репозитория Git с помощью следующей команды:

git clone git://github.com/Mailtrain-org/mailtrain.git

Затем измените каталог на mailtrain и переименуйте файл docker-compose по умолчанию:

cd mailtrain
mv docker-compose.override.yml.tmpl docker-compose.override.yml

Затем запустите док-контейнеры Mailtrain с помощью следующей команды:

docker-compose up -d

Эта команда загрузит и запустит контейнеры mailtrain, mysql и redis, как показано ниже:

Creating network "mailtrain_default" with the default driver
Creating volume "mailtrain_mailtrain-node-config" with default driver
Creating volume "mailtrain_mailtrain-node-data" with default driver
Creating volume "mailtrain_mailtrain-redis-data" with default driver
Creating volume "mailtrain_mailtrain-node-reports" with default driver
Creating volume "mailtrain_mailtrain-mysq-data" with default driver
Pulling redis (redis:3.0)...
3.0: Pulling from library/redis
f5cc0ee7a6f6: Pull complete
5fc25ed18e87: Pull complete
e025bc8872f6: Pull complete
77c68b51b836: Pull complete
7c403ece3755: Pull complete
0a653bd338f4: Pull complete
31531fd948c6: Pull complete
Digest: sha256:730b765df9fe96af414da64a2b67f3a5f70b8fd13a31e5096fee4807ed802e20
Status: Downloaded newer image for redis:3.0
Pulling mysql (mysql:5.7)...
5.7: Pulling from library/mysql
80369df48736: Pull complete
e8f52315cb10: Pull complete
cf2189b391fc: Pull complete
cc98f645c682: Pull complete
27a27ac83f74: Pull complete
fa1f04453414: Pull complete
d45bf7d22d33: Pull complete
c7d49ffebc56: Pull complete
511a8052b204: Pull complete
5d5df4c12444: Pull complete
d482603a2922: Pull complete
Digest: sha256:44b33224e3c406bf50b5a2ee4286ed0d7f2c5aec1f7fdb70291f7f7c570284dd
Status: Downloaded newer image for mysql:5.7
Building mailtrain
:
:
Removing intermediate container 20676b10252b
 ---> 0abdb4121f54
Step 6/9 : COPY . /app
 ---> c8af7560e844
Step 7/9 : EXPOSE 3000
 ---> Running in 3ff55179a229
Removing intermediate container 3ff55179a229
 ---> d83b49d4b24b
Step 8/9 : ENTRYPOINT ["bash", "/app/docker-entrypoint.sh"]
 ---> Running in e5baf6a1ea2e
Removing intermediate container e5baf6a1ea2e
 ---> c4f899a0f8f9
Step 9/9 : CMD ["node", "index.js"]
 ---> Running in fe94519d2bd3
Removing intermediate container fe94519d2bd3
 ---> 2808c2972f20
Successfully built 2808c2972f20
Successfully tagged mailtrain:latest
WARNING: Image for service mailtrain was built because it did not already exist. To rebuild this image you must use `docker-compose build` or `docker-compose up --build`.
Creating mailtrain_redis_1 ... done
Creating mailtrain_mysql_1 ... done
Creating mailtrain_mailtrain_1 ... done

Теперь вы можете проверить все запущенные контейнеры с помощью следующей команды:

docker ps

Вы должны увидеть следующий вывод:

CONTAINER ID        IMAGE               COMMAND                  CREATED              STATUS              PORTS                    NAMES
0e837c586c39        mailtrain:latest    "bash /app/docker-en…"   About a minute ago   Up 55 seconds       0.0.0.0:3000->3000/tcp   mailtrain_mailtrain_1
49a4e69a09c6        mysql:5.7           "docker-entrypoint.s…"   About a minute ago   Up About a minute   3306/tcp, 33060/tcp      mailtrain_mysql_1
a1449b64a196        redis:3.0           "docker-entrypoint.s…"   About a minute ago   Up About a minute   6379/tcp                 mailtrain_redis_1

Доступ к веб-интерфейсу Mailtrain

Контейнер Mailtrain теперь запущен и прослушивает порт 3000. Затем откройте веб-браузер и введите URL-адрес http://your-server-ip:3000. Вы должны увидеть панель инструментов Mailtrain по умолчанию на следующей странице:

Теперь нажмите кнопку Войти. Вы должны увидеть следующую страницу:

Укажите имя пользователя и пароль по умолчанию как admin/admin и нажмите кнопку «Войти». Вы должны увидеть панель инструментов Mailtrain по умолчанию на следующей странице:

Настройте Nginx в качестве обратного прокси для Mailtrain

Затем вам нужно будет создать Nginx в качестве обратного прокси-сервера для Mailtrain на порту 3000. Для этого сначала установите веб-сервер Nginx, выполнив следующую команду:

apt-get install nginx -y

Затем создайте файл конфигурации виртуального хоста Nginx с помощью следующей команды:

nano /etc/nginx/sites-available/mailtrain.conf

Добавьте следующие строки:

upstream mailtrain {
  server 127.0.0.1:3000 weight=100 max_fails=5 fail_timeout=5;
}

server {
  listen          80;
  server_name     example.com;

  location / {
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header X-Forwarded-Server $host;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass http://mailtrain/;
  }
}

Сохраните и закройте файл, когда закончите. Затем проверьте Nginx на наличие синтаксической ошибки с помощью следующей команды:

nginx -t

Вы должны увидеть следующий вывод:

nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

Затем включите файл виртуального хоста Nginx с помощью следующей команды:

ln -s /etc/nginx/sites-available/mailtrain.conf /etc/nginx/sites-enabled/

Наконец, перезапустите веб-сервер Nginx, чтобы применить конфигурацию:

systemctl restart nginx

Безопасный почтовый поезд с помощью Lets Encrypt

Затем вам нужно будет установить клиент Certbot для защиты Mailtrain с помощью бесплатного SSL от Lets Encrypt. По умолчанию последняя версия Certbot недоступна в стандартном репозитории Ubuntu 18.04. Итак, добавьте репозиторий Certbot, выполнив следующую команду:

add-apt-repository ppa:certbot/certbot

Затем обновите репозиторий и установите Certbot с помощью следующей команды:

apt-get update -y
apt-get install certbot python-certbot-nginx -y

После установки выполните следующую команду, чтобы загрузить бесплатный SSL Lets Encrypt для вашего домена example.com и настроить Nginx для использования этого сертификата.

certbot --nginx -d example.com

Укажите свой адрес электронной почты и согласитесь с Условиями обслуживания. После успешной установки сертификата вы должны увидеть следующий вывод:

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Congratulations! You have successfully enabled https://example.com

You should test your configuration at:
https://www.ssllabs.com/ssltest/analyze.html?d=example.com
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

IMPORTANT NOTES:
 - Congratulations! Your certificate and chain have been saved at:
   /etc/letsencrypt/live/example.com/fullchain.pem
   Your key file has been saved at:
   /etc/letsencrypt/live/example.com/privkey.pem
   Your cert will expire on 2020-01-22. To obtain a new or tweaked
   version of this certificate in the future, simply run certbot again
   with the "certonly" option. To non-interactively renew *all* of
   your certificates, run "certbot renew"
 - Your account credentials have been saved in your Certbot
   configuration directory at /etc/letsencrypt. You should make a
   secure backup of this folder now. This configuration directory will
   also contain certificates and private keys obtained by Certbot so
   making regular backups of this folder is ideal.
 - If you like Certbot, please consider supporting our work by:

   Donating to ISRG / Let's Encrypt:   https://letsencrypt.org/donate
   Donating to EFF:                    https://eff.org/donate-le

Теперь вы можете безопасно получить доступ к своему приложению Mailtrain, используя URL-адрес https://example.com.

Заключение

В приведенном выше руководстве мы узнали, как установить Mailtrain с докером на сервер Ubuntu 18.04. Мы также узнали, как настроить Nginx в качестве обратного прокси-сервера для Mailtrain и защитить Mailtrain с помощью бесплатного SSL от Lets Encrypt. Не стесняйтесь спрашивать меня, если у вас есть какие-либо вопросы.