Özel bir daemon'u init.d'ye nasıl doğru bir şekilde ekleyebilirim?


26

Birkaç tane komut satırı tarafından başlatılabilen ve durdurulabilen bir üçüncü taraf tescilli uygulama sunucusu arka plan programı var. Sistem kapatıldığında sistemin başlatılması ve doğru şekilde durdurulması için başlatılacak olan bu cumaya ihtiyacım var. Bunu doğru olarak nasıl uygularım? /Etc/init.d içindeki bir betiği kopyalamak ve buna göre değiştirmek yeterli mi?

Yanıtlar:


16

init.d, servet başlatmak için kullanılan eski ve kullanımdan kaldırılmış bir sistemdir; nin yerini almıştır edilir sonradan görme . Upstart, yapılandırılmasının çok daha kolay olma avantajına sahiptir ve görev başlatmanın doğru sıralanmasına izin verir.

Upstart için yapılandırma dosyaları / etc / init dizininde bulunur ve daemon'unuzun önkoşulları yoksa, tty1.conf kadar basit olabilir:

# tty1 - getty
#
# This service maintains a getty on tty1 from the point the system is
# started until it is shut down again.

start on stopped rc RUNLEVEL=[2345]
stop on runlevel [!2345]

respawn
exec /sbin/getty -8 38400 tty1

bu durumda bu dosyayı kopyalayabilir ve zevkinize göre değiştirebilirsiniz. Daha karmaşık yapılandırmalar en iyi başlangıç ​​yerinde ve / etc / init içindeki diğer girişlerde belgelenmiştir.

Yoruma cevap olarak eklendi

Upstart veya init.d kullanıyor olsanız da, Firebird'ün uygun şekilde ne zaman başlatıldığını belirlemeniz için bir yol bulmanız gerekir. Ne yazık ki, Firebird , yüklü olduğunu ve çalıştığını doğrulamak için iyi bir yol gibi görünmüyor . Bu nedenle, programınızın /etc/rc.local 'a başlamasının tavsiye edilmesi kesinlikle en kolay olanıdır ve Ubuntu'da - en azından - önyükleme işleminde mümkün olduğu kadar geç kalması garanti edilir.


1
Aslında arka planım init.d'yi kullanan Firebird veritabanı sunucusuna bağlı.
Ivan

12

UPSTART'a geçmek istemiyorsanız ancak klasik yaklaşımı istiyorsanız, şunları yapmalısınız:

NOT: Hizmeti ve programı aynı adda farklı dizinlerde saklıyorum (ancak hizmet dosyanızda yansıtıldığı sürece bunu değiştirebilirsiniz). "myscriptname" ve "myprogramname" i gerçek isimlerle değiştir!

  1. Hizmet olarak çalışacak olan programınızı / usr / sbin içine kaydedin.

    sudo cp myprogramname /usr/sbin/myscriptname

  2. temel bir başlangıç ​​betiği oluşturun (referans olarak /etc/init.d/skeleton kullanın)

  3. bu betiği /etc/init.d dizinine taşıyın

    sudo mv /etc/init.d/myscriptname

  4. bu betiğin çalıştırılabilir iznini ver (775 kullandım, ancak daha düşük ayarlayabilirsiniz)

    sudo chmod 755 /etc/init.d/myscriptname

  5. goto /etc/init.d

    cd /etc/init.d

  6. Düşük başlangıç ​​önceliği olan başlangıç ​​listesine dahil et

    sudo update-rc.d myscriptname defaults 97 03

makinenizi yeniden başlatın ve servisin doğru şekilde başlatılıp başlatılmadığını kontrol edin.

sudo ps -A --sort cmd

Eğer servisiniz uygun şekilde başlamıyorsa, önce elle aradığınızda çalışıp çalışmadığını kontrol etmelisiniz:

cd /etc/init.d
sudo service myscriptname start

Aşağıda gerçekten çalışan örnek bir servis dosyası yer almaktadır. neyi yapılandırmanız gerektiğini anlamak için iskelet servisiyle karşılaştırın. NOT: Bu Ubuntu 12.04 amazon bulutu AWS EC2 klasik LAMP uygulamasında çalışır (ayrıca Kubuntu 15.10'da).

#! /bin/sh
### BEGIN INIT INFO
# Provides:          
# Required-Start:    $remote_fs
# Required-Stop:     $remote_fs
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: Sample_GT02 daemon startup script
# Description:       Sample Server for GT02 class 
### END INIT INFO

# Author: Tony Gil 
#

# Do NOT "set -e"

# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="Sample Daemon"
NAME=sampleserver_gt02
DAEMON=/usr/sbin/$NAME
PIDFILE=/var/run/$NAME.pid
SCRIPTNAME=/etc/init.d/$NAME
CHUID=root

# Exit if the package is not installed
[ -x "$DAEMON" ] || exit 0

# Read configuration variable file if it is present
[ -r /etc/default/$NAME ] && . /etc/default/$NAME

# Load the VERBOSE setting and other rcS variables
. /lib/init/vars.sh

# Define LSB log_* functions.
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
. /lib/lsb/init-functions

#
# Function that starts the daemon/service
#
do_start()
{
   # Return
   #   0 if daemon has been started
   #   1 if daemon was already running
   #   2 if daemon could not be started
   start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \
      || return 1
   start-stop-daemon --start --quiet --chuid $CHUID --pidfile $PIDFILE --exec $DAEMON -- \
      $DAEMON_ARGS \
      || return 2
}

#
# Function that stops the daemon/service
#
do_stop()
{
   # Return
   #   0 if daemon has been stopped
   #   1 if daemon was already stopped
   #   2 if daemon could not be stopped
   #   other if a failure occurred
   start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
   RETVAL="$?"
   [ "$RETVAL" = 2 ] && return 2
   # Wait for children to finish too if this is a daemon that forks
   # and if the daemon is only ever run from this initscript.
   # If the above conditions are not satisfied then add some other code
   # that waits for the process to drop all resources that could be
   # needed by services started subsequently.  A last resort is to
   # sleep for some time.
   start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
   [ "$?" = 2 ] && return 2
   # Many daemons don't delete their pidfiles when they exit.
   rm -f $PIDFILE
   return "$RETVAL"
}

#
# Function that sends a SIGHUP to the daemon/service
#
do_reload() {
   #
   # If the daemon can reload its configuration without
   # restarting (for example, when it is sent a SIGHUP),
   # then implement that here.
   #
   start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --name $NAME
   return 0
}

case "$1" in
  start)
   [ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
   do_start
   case "$?" in
      0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
      2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
   esac
   ;;
  stop)
   [ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
   do_stop
   case "$?" in
      0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
      2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
   esac
   ;;
  #reload|force-reload)
   #
   # If do_reload() is not implemented then leave this commented out
   # and leave 'force-reload' as an alias for 'restart'.
   #
   #log_daemon_msg "Reloading $DESC" "$NAME"
   #do_reload
   #log_end_msg $?
   #;;
  restart|force-reload)
   #
   # If the "reload" option is implemented then remove the
   # 'force-reload' alias
   #
   log_daemon_msg "Restarting $DESC" "$NAME"
   do_stop
   case "$?" in
     0|1)
      do_start
      case "$?" in
         0) log_end_msg 0 ;;
         1) log_end_msg 1 ;; # Old process is still running
         *) log_end_msg 1 ;; # Failed to start
      esac
      ;;
     *)
        # Failed to stop
      log_end_msg 1
      ;;
   esac
   ;;
  *)
   #echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
   echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
   exit 3
   ;;
esac

:

1
@jakeGould "benim" kodumu yeniden biçimlendirmek için gerçekten zaman ayırdınız mı? Bu test ettiğin ve senin için çalıştığı anlamına mı geliyor?
Tony Gil

1
benim için çalıştı
Mario S

Artık start up sistemd lehine ölü değil mi?
Gillespie,

Gerçekten de, start-up, son Ubuntu'ma bile yüklenmedi. SysV init scriptleri asla ölmeyecek.
Chris Nadovich

8

/Etc/init.d/skeleton dosyasının bir kopyasını alın ve hizmetinizi başlatmak / durdurmak / yeniden başlatmak için uygun yerlerde düzenleyin. Çok iyi yorumlandı, bu yüzden hiçbir zaman çalışan bir init.d betiği oluşturabilmelisiniz.


Bu, rcX.d'de sembolik linkler oluşturmanız gerektiği anlamına gelir. Ancak bir Ubuntu güncellemesi tüm özel sembolik linklerinizi siler.
Robin Hsu

2
  • Komutlarını ekle /etc/rc.local
  • Böylece arka planınız sistem başlangıcında otomatik olarak başlayacaktır.

1

pleaserunTek bir komutla otomatik olarak bir init betiği oluşturma sorununu çözmeye çalışan bir yakut betiğidir. sayfasından alıntı yapmak:

"Pleaserun ile, aşağıdaki rampaları / komut dosyalarını / her şeyi oluşturabilirsiniz:

Launchd
sonradan görme
systemd
runit
sysv init"

Ayrıca hangi init sisteminin kullanıldığını tespit eder, böylece senaryoyu buna göre oluşturur.


pleaserun'un da günlük kaydı yaptığından emin değilim, ancak bu diğerinin de günlük kaydı var: gist.github.com/naholyr/4275302
Costin Gușă
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.