Page tree
Skip to end of metadata
Go to start of metadata

Установка Wildfly

При установке далее мы рекомендуем указывать JAVA_HOME вручную в standalone.conf, чтобы, если у вас есть установленная JRE/JDK из репозитария, неожиданно для вас не поменялась используемая версия Java. Однако это не касается запуска некоторых команд, требуемых при установке личного кабинета. Для таких команд может использоваться JRE/JDK по умолчанию, установленную из репозитария; или же Вы можете прописать JAVA_HOME глобально, в /etc/environment или в ~/.bashrc.

  1. Скачайте сервер приложений Java EE (Java Platform, Enterprise Edition) Wildfly с официального сайта http://wildfly.org/downloads/. Рекомендуемая версия Wildfly для биллинга 21.0.2.Final. Распакуйте содержимое архива, например, в папку /opt и переименуйте папку wildfly-номервесии в wildfly. Или же создайте символическую ссылку /opt/wildfly, которая будет указывать на /opt/wildfly-номерверсии.

  2. Отредактируйте файл /opt/wildfly/bin/standalone.conf, укажите правильный путь к JDK в переменной JAVA_HOME:

    #
    # Specify the location of the Java home directory. If set then $JAVA will
    # be defined to $JAVA_HOME/bin/java, else $JAVA will be "java".
    #
    #JAVA_HOME="/opt/java/jdk"

    Отредактируйте ниже параметры запуска JVM:

    #
    # Specify options to pass to the Java VM.
    #
    if [ "x$JAVA_OPTS" = "x" ]; then
       #JAVA_OPTS="-Xms64m -Xmx512m -XX:MetaspaceSize=96M -XX:MaxMetaspaceSize=256m -Djava.net.preferIPv4Stack=true"
       JAVA_OPTS="-Xms64m -Xmx300m -XX:MetaspaceSize=96M -XX:MaxMetaspaceSize=256m -Djava.net.preferIPv4Stack=true -XX:MaxDirectMemorySize=80m -XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=20"
       JAVA_OPTS="$JAVA_OPTS -Djboss.modules.system.pkgs=$JBOSS_MODULES_SYSTEM_PKGS -Djava.awt.headless=true"
    else
       echo "JAVA_OPTS already set in environment; overriding default settings with values: $JAVA_OPTS"
    fi
  3. Если у вас нет значения JAVA_HOME по умолчанию, то отредактируйте common.sh и укажите там путь к JAVA_HOME (иначе следующая команда не будет выполнена):

    #!/bin/sh -x
    
    JAVA_HOME=/opt/java/jdk15
    
  4. Выполните команду, чтобы добавить пользователя Wildfly для аутентификации в web-консоли:

    ./add-user.sh логин пароль
  5. Отредактируйте файл конфигурации Wildfly /opt/wildfly/standalone/configuration/standalone.xml указав используемые HTTP-порты (если необходимо):

    <!--<socket-binding name="http" port="${jboss.http.port:8080}"/>-->
    <socket-binding name="http" port="${jboss.http.port:8081}"/>

    Возможно вы захотите поменять интерфейс, на котором открыт HTTP-порт. Обратите внимание, что для сокета (порта) интерфейс прописан в атрибуте socket-binding/@interface, а также в socket-binding-group/@default-interface. Сами интерфейсы прописаны выше:

        <interfaces>
            <interface name="management">
                <inet-address value="${jboss.bind.address.management:127.0.0.1}"/>
            </interface>
            <interface name="public">
                <inet-address value="${jboss.bind.address:127.0.0.1}"/>
            </interface>
            <interface name="unsecure">
                <inet-address value="${jboss.bind.address.unsecure:127.0.0.1}"/>
            </interface>
        </interfaces>

    Не рекомендуем оставлять web-консоль (management) открытым наружу (если вы решили поменять интерфейсы).

    Или же порты можно поменять с помощью сдвига (offset), используя параметр port-offset, например, на 1 (т.е. 8080 станет 8081, 8443 станет 8444), изменив значение параметра port-offset:

    <!--<socket-binding-group name="standard-sockets" default-interface="public" port-offset="${jboss.socket.binding.port-offset:0}">-->
    <socket-binding-group name="standard-sockets" default-interface="public" port-offset="${jboss.socket.binding.port-offset:1}">

    При изменении port-offset также изменится порт web-консоли Wildfly, значение по умолчанию которого 9990. В этом случае нужно редактировать файл jboss-cli.xml, поменяв значение <port>9990</port> на новое.

    Данные параметры можно менять в web-консоли Wildfly.

  6. Добавьте системного пользователя wildfly и поменяйте владельца у /opt/wildfly:

    useradd -r wildfly
    chown -R wildfly:wildfly /opt/wildfly-XX.Y.Z.Final
    chown -R wildfly:wildfly /opt/wildfly
  7. Создайте файл службы для systemd, (примеры скриптов досты в каталоге /wildfly-XX.Y.Z.Final/docs/contrib/scripts) или используйте в качестве примера код нуже

    cd /lib/systemd/system
    touch wildfly.service

    и укажите содержимое:

    [Unit]
    Description=WildFly Application Server Daemon
    After=network.target
    Requires=
    
    [Service]
    Type=simple
    User=wildfly
    Group=wildfly
    ExecStart=/opt/wildfly/bin/standalone.sh
    
    [Install]
    WantedBy=multi-user.target
  8. Установите в автозапуск:

    systemctl enable wildfly
  9. Запустите 

    systemctl start wildfly

    и попробуйте открыть web-консоль на порту 9991, если указали сдвиг портов на 1, или 9990, если не указывали сдвиг портов. Web-консоль по умолчанию запускается на интерфейсе 127.0.0.1, поэтому может понадобиться проброс портов.

  10.  Отключить логирование в консоль (в файл /var/log/message)

    ./jboss-cli.sh --connect --commands="/subsystem=logging/root-logger=ROOT:remove-handler(name="CONSOLE")"
  11. Настройте firewall, а также рекомендуем использовать nginx.

Установка ЛК

  1. Создайте нового пользователя в BGBillingServer, в поле "Полное имя" укажите Пользователь (как ранее помечались действия абонента), в поле "Описание" укажите "Личный кабинет". Придумайте сложные логин и пароль, разрешите все действия.
  2. Скачайте https://bgbilling.ru/download/8.2101/mybgbilling/MyBGBilling.last соответствующий версии биллинга, например, в папку /opt. Распакуйте архив, оставив имя директории, содержащее файлы архива MyBGBilling.war и поместите эту папку в /opt/wildfly/standalone/deployments:

    cd /opt
    wget https://bgbilling.ru/download/8.2101/mybgbilling/MyBGBilling.last
    unzip ./MyBGBilling.last -d /opt/wildfly/standalone/deployments && rm -f MyBGBilling.last
    touch /opt/wildfly/standalone/deployments/MyBGBilling.war.dodeploy
  3. Поменяйте владельца у директории MyBGBilling.war

    chown -R wildfly:wildfly /opt/wildfly/standalone/deployments/MyBGBilling.war
  4. Укажите в файле /opt/wildfly/bin/common.sh переменную JAVA_HOME

    !/bin/sh -x
    
    JAVA_HOME=/opt/java/jdk14
    
    setModularJdk() {
      "$JAVA" --add-modules=java.se -version > /dev/null 2>&1 && MODULAR_JDK=true || MODULAR_JDK=false
    }

    5. Запустите скрипт синхронизации библиотек сервера биллинга и ЛК (для работы скрипта должен быть запущен сервер биллинга, и если у вас ЛК и биллинг работают на разных сервереах или биллинг запущен на порту отличном от 8080, отредактируйте соответствующие напарметры в файле /opt/wildfly/standalone/deployments/MyBGBilling.war/WEB-INF/script/application.xml):

    chmod 0755 /opt/wildfly/standalone/deployments/MyBGBilling.war/WEB-INF/script/update_libs.sh
    /opt/wildfly/standalone/deployments/MyBGBilling.war/WEB-INF/script/update_libs.sh

    6. Скопируйте файлы конфигурации из MyBGBilling.war/WEB-INF/defaults в MyBGBilling.war/WEB-INF:

    cp /opt/wildfly/standalone/deployments/MyBGBilling.war/WEB-INF/defaults/*.groovy /opt/wildfly/standalone/deployments/MyBGBilling.war/WEB-INF

    7. Отредактируйте MyBGBilling.war/WEB-INF/mybgbilling-conf.groovy, укажите параметры подключения к BGBillingServer

    // Параметры подключения к BGBillingServer.
    // ЛК является пользователем биллинга, общается с ним также, как BGBillingClient
    bgbilling {
        // URL доступа к BGBilling
        url = 'http://127.0.0.1:8080/bgbilling/executer'
        // Логин
        user = 'customer'
        // Пароль
        password = 'customer'
    }

    8. Попробуйте войти в ЛК через браузер http://[host[:port]]/my

Рекомендация для reverse-proxy (Nginx)

Если вы используется reverse-proxy (например, Nginx) и на нём настроен HTTPS, а reverse-proxy работает с Wildfly по HTTP, то в некоторых случаях нужно, чтобы Wildfly знал, что абонент на самом деле использует HTTPS (например, это может быть нужно при отправке редиректа от Wildfly). Для этого рекомендуется внести такие настройки:

  1. Указать в reverse-proxy добавление заголовка X-Forwarded-Proto:

    proxy_set_header X-Forwarded-Proto $scheme;
  2. Указать Wildfly, чтобы он обрабатывал такой заголовок. Для этого в standalone.xml в элементе http-listener нужно добавить proxy-address-forwarding="true":

    <http-listener name="default" socket-binding="http" redirect-socket="https" enable-http2="true" proxy-address-forwarding="true"/>

Также необходимо, чтобы путь к контексту ЛК совпадал с путем, который установлен через NGINX. Например, и там и там должно быть /my.

  • No labels