К основному контенту

Пересылка запросов от Apache на Payara Server 5 в Ubuntu

Использования Payara Server в «продакшане» совместно с  Apache Web Server (httpd) и Ubuntu. Многие из концепций, не опираются на инструменты, которые мы здесь используем, и могут быть применены к другим сценариям.


Наша цель — настроить следующее:

image
Здесь у нас есть веб-сервер Apache, который будет доступен нашим пользователям. Их запросы будут направлены одному из двух экземпляров сервера Payara. Здесь мы рассмотрим использование «склеивание» сессий на основе файла cookie JSESSIONID, чтобы гарантировать взаимодействие каждого пользователя с одним и тем же сервером Payara, а также репликацию сессий, чтобы гарантировать, что, если один сервер Payara выйдет из строя, другой сможет обрабатывать существующие сессии без проблем.


Будем считать что веб сервер Apache уже установлен и настроен. Нашим следующим шагом будет настройка переадресации запросов для отправки трафика на Payara Server.


Что такое пересылка запросов?


Переадресация запросов (или прокси) — это когда сервер, получающий веб-трафик, отправляет его в другое место назначения. Их можно использовать, чтобы скрыть реальное местоположение пользователя, чтобы не видеть внутренние системы или управлять производительностью. Как и большинство веб-серверов, веб-сервер Apache может быть дополнен модулями, которые дают ему возможность пересылать запросы на сервер и передавать ответы через прокси. Это означает, что вы можете использовать Apache в качестве посредника, который избавляет от необходимости указывать номера портов или точные IP-адреса и позволяет пользователю получать ответы от того же сервера (вместо того, чтобы нажимать на localhost и иметь адресную строку с надписью localhost:8080).


Настройка пересылки запросов между веб-сервером Apache и сервером Payara


В этом посте мы рассмотрим пакет, доступный в репозитории Ubuntu. Пакет Ubuntu содержит двоичные файлы Apache, но также имеет дополнительные «вспомогательные инструменты» для управления файлами конфигурации. В Ubuntu 18 два модуля, которые нам нужно добавить в Apache, являются частью пакета apache2, который мы установили ранее. Его можно установить из репозитория с помощью:


sudo apt install apache2

Обратите внимание, что до Ubuntu 16.04 вам нужно будет использовать «apt-get» вместо «apt».

Мы установим два модуля для включения базовой пересылки http-запросов — mod_proxy и mod_proxy_http. В Ubuntu вспомогательные инструменты управляют установкой этих модулей — чтобы еще проще было, инструменты будут искать свои зависимости и включать их. Полезно, что mod_proxy_http требует работы mod_proxy, что означает, что наша команда выглядит следующим образом:

sudo a2enmod proxy_http

Обратите внимание, что в этих командах мы можем опустить префикс «mod_»


image

Если вы хотите отключить модуль, для a2enmod существует вспомогательный инструмент под названием a2dismod, который используется таким же образом. Инструмент обнаружил зависимость и также включил mod_proxy. Если у вас было несколько модулей, которые вы хотели активировать, вы можете добавить их после proxy_http, разделив их пробелами…


Мы перезапустим сервер позже, так как нам также нужно изменить конфигурацию.


Пакет apache2 в Ubuntu имеет пример конфигурации сайта под названием «000-default». Файл конфигурации для этого сайта находится в папке /etc/apache2/sites-available и содержит символическую ссылку на папку sites-enabled.


Структура файла конфигурации Apache


Как правило, вы увидите, что интернет-руководства ссылаются на httpd.conf как файл конфигурации для редактирования. Это просто «родительский» файл конфигурации по умолчанию. В системах Debian / Ubuntu (и их производных, таких как Linux Mint), файл для поиска — apache2.conf.


Этот файл читается, и его директивы применяются сверху вниз, поэтому, если для одного и того же свойства задано два разных значения, будет применяться второе. (Точнее, первый будет применяться только до прочтения второго параметра).


Этот файл также может специально «включать» файлы и папки (обратите внимание, что подстановочные знаки тоже работают). Они будут считаны и объединены с основной конфигурацией в том месте, где написано «include». Таким образом, самая последняя строка в главном файле конфигурации (если он не указывает другой файл) будет последней строкой конфигурации, которая будет установлена, несмотря ни на что.


Страница по умолчанию в новой установке для Apache в Ubuntu находится в /var/www/index.html и дает хороший обзор того, как это работает в деталях.


Создание новой конфигурации сайта


Мы не будем использовать конфигурацию по умолчанию, потому что нам нужно добавить определенное поведение. Скопируйте старую конфигурацию с доступных сайтов и переименуйте ее в нечто запоминающееся.


sudo cp /etc/apache2/sites-available/000-default.conf 
/etc/apache2/sites-available/payara-site.conf

Откройте новый файл в предпочитаемом вами текстовом редакторе от имени пользователя root. Вы должны увидеть что-то вроде этого:


image

Элемент содержит серию директив, которые сообщают серверу, как реагировать на перечисленные входящие запросы. В этом примере <VirtualHost *: 80> обрабатывает все ответы, поступающие на сервер через порт 80. Более подробное описание тегов VirtualHost см. В документации Apache.

Нам нужно добавить две строки в тегах , чтобы сообщить Apache, как обращаться с входящим и исходящим трафиком — одну, чтобы сообщить Apache, куда отправлять запросы, и другую, чтобы сообщить Apache, откуда должны быть получены ответы. Таким образом, пользователь, посещающий localhost, может быть перенаправлен на наш сервер приложений по адресу localhost:8080/, а ответы, направленные на localhost:8080/, вместо этого перенаправляются, так что пользователь видит их поступающими из localhost.


Для управления входящим трафиком добавьте строку:


ProxyPass / http://localhost:8080/

Эта директива указывает Apache отправлять все после доменного имени сервера на localhost:8080/, как если бы пользователь перешел непосредственно по этому URL.

 ProxyPassReverse / http://localhost:8080/
Эта директива сообщает Apache об обратном URL-адресе прокси, чтобы, несмотря на то, что ответ возвращается от экземпляра Payara Server на порт 8080, URL выглядит так, как будто он получен от Apache. Эти две директивы, когда используются вместе, означают, что мы можем избежать сложных регулярных выражений с помощью mod_rewrite.


Предполагая, что доменное имя, которое мы хотим использовать, например, www.example.com, наша конфигурация означает, что запрос к www.example.com/myapp будет фактически отправлен на сервер Payara, как если бы пользователь непосредственно подключился к localhost:8080//MyApp.


Ваш файл должен теперь выглядеть следующим образом (я удалил большинство комментариев, чтобы прояснить, что именно нужно):


image
Сохраните свой файл.

Чтобы отключить сайт по умолчанию и активировать нашу новую конфигурацию, выполните команды:


  sudo a2dissite 000-default.conf
     sudo a2ensite payaraSite.conf

Перезапустите службу Apache HTTP Server (перезапуск, который мы пропустили ранее):

sudo service apache2 restart

Чтобы остановить и запустить Apache HTTP Server, это:

остановка службы

        sudo service apache2 stop
    sudo service apache2 start

Не забудьте запустить Payara Server:

/opt/payara5/bin/asadmin start-domain domain1

Прежде чем вносить изменения в конфигурацию, зайдя на localhost, вы попадете на экран приветствия Apache:


image

Но теперь мы добавили в наш прокси-сервер и включили новые директивы для нашей пользовательской конфигурации Apache, когда мы вводим localhost/index.html, который мы теперь отправляем на экран приветствия Payara Server:

image

Теперь вы можете добавлять приложения на сервер Payara


Таким образом, теперь у нас есть активный HTTP-сервер Apache, действующий в качестве нашего прокси (с возможностью добавления дополнительных модулей), и работающий сервер Payara, готовый к добавлению к нему приложений.

Мы прошли установку обоих серверов, настройку Apache, исследование файловой системы и очень кратко рассмотрели команды asadmin сервера Payara Server.

Комментарии

Популярные сообщения из этого блога

Команды Yum (Oracle linux,Cent os, RHEL)

Шпаргалка по работе с пакетным менеджером Yum (Yellowdog Updater, Modified), который используется в популярных Linux дистрибутивах: RedHat, CentOS, Scientific Linux (и других). В целях экономии места вывод команд не представлен. отображение команд и опций #yum help список названий пакетов из репозиторий #yum list список всех доступных пакетов #yum list available список всех установленных пакетов #yum list installed установлен ли указанный пакет #yum list installed httpd список установленных и доступных пакетов #yum list all список пакетов, относящихся к ядру #yum list kernel отображение информации о пакете #yum info httpd список зависимостей и необходимых пакетов #yum deplist httpd найти пакет, который содержит файл #yum provides "*bin/top" поиск пакета по имени и описанию #yum search httpd #yum search yum получить информацию о доступных обновлениях безопасности #yum updateinfo list security вывести список групп #yum gr...

Установка и конфигурирование Oracle Enterprise Manager 13c.

Этот пост поможет правильно установить и сконфигурировать Oracle Enterprise Manager 13c. Oracle Enterprise Manager - Это централизованный центр управления и мониторинга для всех продуктов Oracle. OEM способен управлять и мониторить и сторонние приложения и сообщать о всех критических проблемах основанные на установленных правилах установленные администратором. Первоначальные настройки системы Oracle Linux 6.7 64 Bit Virtual Machine VirtualBox 5.1.6 for Windows hosts Oracle Database 12.1.0.2 Oracle Enterprise Manager 13c Выделена оперативной памяти 12 Гб . На операционной системе Oracle Linux 6.7 64 Bit предустановлена база данных Oracle Database 12c установка которой тут не рассматривается. Предустановленные пакеты для корректной установки и настройки Oracle Management Service (OMS) make-3.81 binutils-2.20 gcc-4.4.4 libaio-0.3.107 glibc-common-2.12-1 libstdc++-4.4.4 libXtst-1.0.99 (x86_64) sysstat-9.0.4 glibc-2.12 glibc-devel-2.1...

Настройка портов доступа к Oracle Enterprise Manager Express 12c

Для чего данное руководство Данное руководство позволит Вам настроить Oracle Enterprise Manager Express 12c, с Веб интерфейсом, который поможет управлять и администрировать Ваш экземпляр базы данных Oracle. Введение Oracle Enterprise Manager Express позволяет выполнять административные задачи, такие как управление безопасностью пользователей и управление памятью и хранение базы данных. Вы можете также просмотреть производительность и статус информации о вашей базе данных. В Oracle Database 12c , было введено понятие Мультиарендность.( Мультиарендность (англ. multitenancy — «множественная аренда») — элемент архитектуры программного обеспечения, где единый экземпляр приложения, запущенного на сервере, обслуживает множество организаций-клиентов («арендаторов»). Мультиарендность сопоставляется с архитектурой из множественных экземпляров (англ. multiinstance), где для каждой организации-клиента создаются отдельные программные экземпляры. В мультиарендной архитектуре программные при...