Не удается запустить AEM как службу в Ubuntu 18.04 - PullRequest
0 голосов
/ 24 октября 2019

Я пытаюсь настроить AEM (Adobe Experience Manager) Author как службу в Ubuntu 18.04 на экземпляре AWS EC2.

Файл сценария "aem" на /usr/bin/aem (права доступа к файлу "root"))

#!/bin/bash
#
# description: This service manages the Adobe Experience Manager java process.
# processname: aem6
. /lib/lsb/init-functions
SCRIPT_NAME=`basename $0`
AEM_ROOT=/opt/aem/author
AEM_USER=root

########
BIN=${AEM_ROOT}/crx-quickstart/bin
START=${BIN}/start
STOP=${BIN}/stop
STATUS=${BIN}/status

case "$1" in
  start)
    if [ -f $START ]; then
       echo "Starting AEM Service.."
       /bin/su -l $AEM_USER -c $START
       RETVAL=$?
       [ $RETVAL -eq 0 ] && touch /var/lock/subsys/${SCRIPT_NAME}
    fi
   ;;
   stop)
    if [ -f $STOP ]; then
       echo "Stopping AEM Service.."
       /bin/su -l $AEM_USER -c $STOP
       RETVAL=$?
       [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/${SCRIPT_NAME}
    fi
    ;;
    status)
      if [ -f $STATUS ]; then
         echo -s "Checking status of $SCRIPT_NAME: "
         /bin/su -l $AEM_USER -c $STATUS
         RETVAL=$?
         [ $RETVAL -eq 0 ] && echo "$SCRIPT_NAME is running"
      fi
   ;;
   restart)
      /bin/su -l ${AEM_USER} -c ${STOP}
      /bin/su -l ${AEM_USER} -c ${START}
   ;;
   reload)
   ;;
   *)
     echo "Usage: $0 {start|stop|status|reload}"
     RETVAL=1
     ;;
esac
exit $RETVAL

Сервисный файл на /etc/systemd/system/aem.service (права доступа к «корню»)

[Unit]
Description=Adobe Experience Manager

[Service]
Type=simple
ExecStart=/usr/bin/aem start
ExecStop=/usr/bin/aem stop
ExecReload=/usr/bin/aem restart
RemainAfterExit=yes

[Install]
WantedBy=multi-user.target

при проверке статуса сервиса:

ubuntu@ip-109:~$ sudo systemctl status aem 
aem.service - Adobe Experience Manager
Loaded: loaded (/etc/systemd/system/aem.service; enabled; vendor preset: enabled)
Active: active (exited) since Wed 2019-10-23 20:25:21 UTC; 3min 24s ago
Process: 20106 ExecStart=/usr/bin/aem start (code=exited, status=0/SUCCESS)
Main PID: 20106 (code=exited, status=0/SUCCESS)

Oct 23 20:25:21 ip-172-31-14-109 systemd[1]: Started Adobe Experience Manager.
Oct 23 20:25:21 ip-172-31-14-109 aem[20106]: Starting AEM Service..
Oct 23 20:25:21 ip-172-31-14-109 su[20122]: Successful su for root by root
Oct 23 20:25:21 ip-172-31-14-109 su[20122]: + ??? root:root
Oct 23 20:25:21 ip-172-31-14-109 su[20122]: pam_unix(su:session): session opened for user root by (uid=0)
Oct 23 20:25:21 ip-172-31-14-109 aem[20106]: mesg: ttyname failed: Inappropriate ioctl for device
Oct 23 20:25:21 ip-172-31-14-109 su[20122]: pam_unix(su:session): session closed for user root

Но не можетсм. процесс "Java" (с использованием ps -ef | grep java) или используемый порт "4502" (с использованием sudo lsof -i -P -n | grep LISTEN).

Что мне не хватает?

1 Ответ

0 голосов
/ 24 октября 2019

удалось решить проблему. Проблема была в том, что «java» был недоступен для всех пользователей. Установил Oracle Java с использованием пользователя по умолчанию (ubuntu), в то время как сценарий aem выполнялся как root.

Шаги для установки пользовательской Java .. не по умолчанию Ubuntu:

  • Загрузите файл tar.gz "https://download.oracle.com/otn/java/jdk/8u231-b11/5b13a193868b4bf28bcb45c792fce896/jdk-8u 231-linux-x64.tar.gz"
  • Скопируйте файл на сервер, используя SCP
  • Создайте каталог mkdir /opt/java
  • Установите и скопируйте sudo tar -zxf jdk-8u231-linux-x64.tar.gz -C /opt/java/
  • Обновите свою среду, чтобы разрешить использование Java для всех пользователей. Запустите эту команду
    • sudo update-alternatives --install /usr/bin/java java /opt/java/jdk1.8.0_231/bin/java 1
  • Добавить путь к «.bashrc». Открыть для редактирования sudo nano ~/.bashrc
    • Добавьте следующие строки в конец файла:
      • export JAVA_HOME=/opt/java/jdk1.8.0_231
      • export PATH=${PATH}:${JAVA_HOME}/bin

После этого .. снова запустите службу "aem". Это должно работать!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...