
Я пытаюсь запустить несколько приложений при загрузке CentOS, но сталкиваюсь с некоторыми проблемами, которые не знаю, как решить.
Вот файл my.service:
[Unit]
Description="Boot Jenkins slave and SonarQube server"
After=network.target
[Service]
Type=simple
ExecStart=/var/boot.sh
User=root
Group=root
[Install]
WantedBy=default.target
После systemctl daemon-reload
, systemctl enable my.service
и systemctl start my.service
, похоже, ничего на самом деле не происходит/не работает.
Вывод systemctl status my.service
:
$ systemctl status my.service
● startup.service - "Boot Jenkins slave and SonarQube server"
Loaded: loaded (/etc/systemd/system/my.service; enabled; vendor preset: disabled)
Active: inactive (dead) since Wed 2017-04-26 19:49:31 IDT; 1min 41s ago
Process: 988 ExecStart=/var/boot.sh (code=exited, status=0/SUCCESS)
Main PID: 988 (code=exited, status=0/SUCCESS)
Apr 26 19:49:00 build-1 systemd[1]: Started "Boot Jenkins slave and SonarQube server".
Apr 26 19:49:00 build-1 systemd[1]: Starting "Boot Jenkins slave and SonarQube server"...
Apr 26 19:49:00 build-1 boot.sh[988]: Starting SonarQube...
Apr 26 19:49:01 build-1 boot.sh[988]: Started SonarQube.
По идее, всё должно было работать, но не работает...
Однако если я вручную запущу boot.sh, всё заработает.
su ...
./boot.sh
boot.sh — это:
#!/bin/bash
nohup java -jar /var/jenkins/slave.jar -jnlpUrl https://***.jnlp -secret **** &
/var/sonarqube-6.3/bin/linux-x86-64/sonar.sh start
Обратите внимание, что SonarQube требует root.
Что я делаю не так?
Обновлять:журналы из cat /var/log/messages | grep SonarQube
:
Apr 26 20:58:53 build-1 systemd: Started "Boot Jenkis slave and SonarQube server".
Apr 26 20:58:53 build-1 systemd: Starting "Boot Jenkis slave and SonarQube server"...
Apr 26 20:58:53 build-1 boot.sh: Starting SonarQube...
Apr 26 20:58:53 build-1 boot.sh: Started SonarQube.
решение1
Для SonarQube я в итоге просто следовал этому:https://devopscube.com/setup-and-configure-sonarqube-on-linux/, в котором указано, как добавить SonarQube в качестве службы... это, как ни странно, оказалось гораздо проще, чем подход с использованием systemd.
Что касается первой команды в файле, то это все еще открытый вопрос...