문서의 이전 판입니다!
Systemd Unit 옵션
[Unit] Section
Description=- 해당 유닛에 대한 상세한 설명을 포함한다.Requires=- 상위 의존성을 구성한다. 목록의 유닛이 정상적일 경우 유닛이 시작된다. (필요 조건)RequiresOverridable=-Requires=옵션과 유사하다. 하지만 이 경우 사용자에 의해서 서비스가 시작하는데 상위 의존성이 있는 유닛 구동에 실패 하더라도 이를 무시하고 유닛을 시작한다. (즉 상위 의존성을 무시한다.) 자동 시작의 경우 적용 되지 않는다.Requisite=,RequisiteOverridable=-Requires=와RequiresOverridable=와 유사하다. 상위 의존성 유닛이 시작되지 않은 경우 즉시 실패를 반환한다.Wants=-Requires=보다 다소 완화된 옵션이다. 상위 의존성의 유닛이 시작되지 않더라도 전체 수행과정에 영향을 끼치지 않는다. 이 옵션은 하나의 유닛을 다른 유닛과 연계할 경우 사용하게 된다. (충분 조건)BindsTo=-Requires=와 매우 유사하다. systemd 개입 없이 갑작기 서비스가 사라진 경우 (가령 NIC 가 물리적 장애가 난 경우) 해당 유닛도 같이 중지 하도록 설정하도록 한다.PartOf=-Requires=와 매우 유사하다. 상위 의존성의 유닛을 중지하거나 재시작하는 경우 해당 유닛 또한 중지나 재시작을 수행한다. 만일 오라클과 오라클 리스너의 경우에서 처럼 하나의 서비스 다른 하나의 종속성을 가지게 되는 경우 필요한 설정이다.Conflicts=- 역의 관계를 설정한다. 만일 유닛1 의Conflicts=설정이 유닛2 로 되어 있다면 유닛1이 시작된 경우 유닛2가 중지되고, 유닛1이 중지된 경우 유닛2가 시작한다. 이 옵션은After=와Before=옵션과는 독립적으로 작동한다. 각 서비스가 반대의 역활을 하거나 혹은 보조적인 서비스 역활을 수행한다면 서비스 실행 관리에 편리할 것 같다.Before=,After=- 유닛 시작의 전후 관계를 설정한다. 해당 설정은Requires=설정과는 독립적이다.Before=에 나열된 유닛이 시작되기 전에 실행하고After=은 해당 유닛이 시작된 이후 나열된 유닛이 실행한다. 이 설정은 시스템이 종료(shutdown) 될때는 역으로 작동하게 된다.OnFailure=- 해당 유닛이 실패 상태가 되면 수행할 유닛 목록 (예/파일 시스템 마운트 실패시 복구 모드 수행)PropagatesReloadTo=,ReloadPropagatedFrom=- 리로드(reload) 명령을 다른 유닛에게 전달하거나 혹은 전달받아 해당 유닛도 리로드(reload)하게 된다.RequiresMountsFor=- 절대 경로로 지정하여 유닛을 구동하는데 필요한 마운트 목록을 자동으로 구성하여Requires=,After=을 수행한다. 즉 필요한 마운트 경로가 준비되어 있는지 점검하고 마운트를 미리 진행한다.OnFailureIsolate=[yes|no]- yes인 경우OnFailure=에 선언된 리스트와는 격리모드(isolation mode)로 작동한다. 즉 해당 유닛에 종속성이 없는 모든 유닛은 중지 되게 된다.OnFailureIsolate=yes인 경우OnFailure=옵션에 오직 하나의 유닛만 설정 할 수 있다.
[Service] Section
Type=[simple|forking|oneshot|notify|dbus]- 유닛 타입을 선언한다.simple- (기본값) 유닛이 시작된 경우 즉시 systemd 는 유닛의 시작이 완료되었다고 판단한다. 다른 유닛과 통신하기 위해 소켓을 사용하는 경우 이러한 설정을 사용하면 안된다.forking- 자식 프로세스를 생성이 완료되는 단계까지를 systemd 가 시작이 완료되었다고 판단하게 된다. 부모 프로세스를 추적할 수 있도록PIDFile=필드에 PID 파일을 선언해 주어야 한다.oneshot-simple과 다소 유사하지만 단일 작업을 수행하는데 적합한 타입니다. 또한 실행 이후 해당 실행이 종료되더라도RemainAfterExit=yes옵션을 통해 유닛이 활성화 상태로 간주할 수 있다.notify-simple과 동일하다. 다만 유닛이 구동되면 systemd 에 시그널을 보낸다. 이때 시그널에 대한 내용은libsystemd-daemon.so에 선언 되어 있다.dbus- DBUS 에 지정된 BusName 이 준비될때까지 대기한다. 즉 DBUS 준비가 완료된 이후 유닛이 시작되었다고 간주한다.
RemainAfterExit=[yes|no]- 유닛이 종료 이후에도 유닛이 활성화 상태로 판단한다.GuessMainPID=[yes|no]- 이 옵션는Type=forking가 설정되어 있고PIDFile=설정이 되어 있지 않은 경우에 작동한다. systemd 가 유닛이 정상적으로 시작되었는지 판단이 명확하지 않는 경우 사용된다. 만일 여러개의 데몬으로 구성된 유닛의 경우 잘못된 PID 추측이 발생할 수 있다. 그로인해 오류 검출이나 자동 재시작 등의 작업이 불가능 할 수 있다. 이 옵션은 이러한 문제를 방지하는 기능을 한다.PIDFile=- PID 파일을 지정한다. 만일 유닛 타입이 forking 이라면 해당 설정을 추가해 주어야 한다. (절대 경로 사용)BusName=- D-Bus 의 버스 이름을 지정한다.Type=dbus인 경우 필수 사항이다. 다른 Type 의 경우라도 D-Bus 버스 이름을 다르게 사용하는 경우 별도로 설정을 해주는 것이 좋다.Environment=- 해당 유닛 에서 사용할 환경 변수를 선언한다. 또한 반드시Exec*=옵션보다 상단에 위치해야 한다. 예제는 아래와 같다.
Environment="ONE=one" 'TWO=two two'
EnvironmentFile=- 해당 유닛에서 사용할 환경 변수 파일을 선언한다. 환경 변수 파일에서#와;로 시작되는 라인은 주석으로 처리된다.Environment=와 같이 사용하는 경우Environment=옵션값이 먹게 된다. 또한 반드시Exec*=옵션보다 상단에 위치해야 한다.ExecStart=- 구동 명령어(스크립트)을 선언한다. 실행 명령어는 반드시 절대 경로 또는 변수(${STRINGS} 따위) 로 시작해야 한다. 다중 명령어를 지원한다. 예제는 아래와 같다.
ExecStart="commnad 1; command 2; command 3" 또는 ExecStart="commnad 1" ExecStart="command 2"
ExecStop=- 중지 명령어(스크립트)를 선언한다.ExecStart=동일하게 사용하면 된다. 중지 방식은KillMode=로 지정된다.KillMode=[control-group|process|none]- 중지 방법에 대해서 선언한다.control-group은 해당 유닛의 그룹까지 모두 중지 시킨다. 기본값이다.process은 해당 유닛 즉 메인 프로세스만 중지 시킨다.none은 아무런 액션을 하지 않는다.- 그룹이란 유닛과 그 유닛에 종속성을 가지는 유닛의 묶음을 뜻한다.
ExecReload=- 리로그(reload) 를 수행할 명령어를 선언한다.ExecStartPre=,ExecStartPost=,ExecStopPre=,ExecStopPost=- 유닛 시작, 중지 등의 엑션과 관련하여 수행할 추가 명령어를 선언한다. 사용법은ExecStart=동일하게 사용하면 된다.RestartSec=- 재시작 명령을 수행할때 중지 이후 다시 시작하는데 대기(sleep)하는 시간을 설정한다. 기본값은100ms이다. 각각min,s,ms단위로 설정한다. 해당 설정은Restart=옵션이 있는 경우에만 적용된다.TimeoutStartSec=- 유닛이 시작하는데 대기하는 시간을 설정한다. 기본값은90초(90s)이다. 만일Type=oneshot인 경우 해당 설정이 해당 설정이 적용되지 않는다. 만일 시작 시간을 대기하지 않고 무한정 리턴값을 기다리게 설정할려면TimeoutStartSec=0으로 설정해 주면 된다.TimeoutStopSec=- 옵션을 중지하는데 대기하는 시간을 설정한다. 기본값은90초(90s)로 위의TimeoutStartSec=옵션과 동일하게TimeoutStopSec=0으로 설정하면 무한정 리턴값을 기다리게 된다.TimeoutStopSec옵션에 설정된 값 안에 종료되지 않으면 SIGKILL 시그널을 보내서 강제로 종료하게 된다.TimeoutSec=-TimeoutStartSec=와TimeoutStopSec=을 동시에 설정한다.WatchdogSec=- 유닛이 시작된 이후 유닛 상태 감시(keep-alive ping)할때의 상태 값을 리턴하는데 대기하는 시간을 설정한다.Restart=옵션이on-failure,always인 경우 유닛을 자동으로 재시작하게되고 이때WatchdogSec=설정을 해주어야 한다. 기본값은0으로 유닛 상태 감시를 사용하지 않는다.Restart=[no|on-success|on-failure|on-watchdog|on-abort|always]- 유닛이 죽었을때나 혹은WatchdogSec=만큼의 시간 동안 응답이 없는 경우 재시작한다.ExecStartPre=,ExecStartPost=,ExecStopPre=,ExecStopPost=,ExecReload=에 설정된 유닛의 경우에는 포함되지 않는다. 즉 해당 유닛에만 해당된다.no(기본값), 유닛을 다시 시작하지 않는다.on-success는 유닛이 정상적으로 종료되었을 때만 재시작한다. 종료시에0값을 리턴하여 종료되었거나SIGHUP,SIGINT,SIGTERM,SIGPIPE등과 같은 시그널 또는SuccessExitStatus=' 설정에서 지정된 리턴 코드 목록에 따른 시그널에 대해서 모두 성공으로 인식해 재시작을 하게 된다.on-failure
*유닛이 비정상적으로 종료되었을때 재시작한다. 리턴값이0이 아닌 경우, core dump 와 같이 비정상적인 시그널을 받고 종료된 경우, 타임 아웃값내 응답이 없는 경우 등일때 재시작 하게 된다.on-watchdog
*WatchdogSec=에 설정된 시간내 응답이 없는 경우에만 재시작 한다.on-abort
*지정되지 않은 리턴값을 받은 경우 재시작을 한다.always
*종료 상태 등과 무관하게 무조건 재시작한다. (사용자가 중지해도 시스템이 다시 띄우게 된다. 설정된 유닛 중지 시 주의가 필요하다.)SuccessExitStatus=
*- 성공으로 판단할 시그널을 설정해 준다. 문법은 아래와 같다.RestartPreventExitStatus=
<code>
SuccessExitStatus=1 2 8 SIGKILL
</code>
*- 재시작을 방지할 리턴 코드를 설정한다. 재시작을 하지 않을 리턴 코드를 설정하는데 유용하다. 문법은 아래와 같다.PermissionsStartOnly=[yes|no]
<code>
RestartPreventExitStatus=1 6 SIGABRT
</code>
*-User=,Group=옵션 등과 같이 권한 설정 옵션을 적용 하여 시작한다. 해당 설정은ExecStart=옵션에서만 적용 되며ExecStartPre=,ExecStartPost=,ExecReload=,ExecStop=,ExecStopPost=옵션에서는 적용되지 않는다.User=
*,Group=- 유닛의 프로세스를 수행할 사용자명, 그룹명 등을 지정한다.RootDirectoryStartOnly=[yes|no]
*-/디렉토리를 지정한다.chroot()함수를 사용하여 구동한다. jail 구성의 일반적인 형태이다. 해당 설정은ExecStart=옵션에서만 적용 되며ExecStartPre=,ExecStartPost=,ExecReload=,ExecStop=,ExecStopPost=옵션에서는 적용되지 않는다.RootDirectory=
*-chroot()함수로 변경할/디렉토리를 지정한다.WorkingDirectory=
*- 프로세스의 작업 디렉토리를 지정한다. 별도의 지정이 없으면 유닛은/디렉토리를 작업 디렉토리로 사용한다. 특정 디렉토리에서 실행해야하는 프로세스에서 필요하다.NonBlocking=[yes|no]
*- 소켓 파일 디스크립션 (FD) 에O_NONBLOCK플래그를 선언한다.yes일 경우STDIN/STDOUT/STDERR을 제외하고 모든 소켓에O_NONBLOCK플래그가 지정된다. 즉non-blocking mode로 작동하게 된다.NotifyAccess=[none|main|all]
*- 유닛 상태에 대해서sd_notify()함수를 사용하여 알림(notification) 소켓에 접근할 수 있도록 한다.none
*은 유닛 상태에 대한 모든 정보를 무시한다.main
*은 메인 프로세스에 대해서만 상태 정보 알림을 허용한다.all
*은 모든 유닛 즉 컨트롤 그룹의 유닛 상태 정보 알림을 허용한다.Type=notify
*또는WatchdogSec=가 설정된 경우NotifyAccess=을 접근 가능하게 (즉main이상) 설정해야 한다.NotifyAccess=만 설정하고 값이 없는 경우 기본값은main이다.Sockets=
*- 유닛에서 사용하는 소켓의 이름을 지정한다. 기본으로<유닛명>.socket으로 생성되지만 지정된 이름으로 소켓을 사용하는 경우 별도의 설정이 가능하다. 또한 하나의 유닛에서 여러 소켓 목록을 일괄적으로 관리하는 경우Sockets=옵션이 여러번 사용 될 수도 있다. 만일Sockets=옵션이 아무런 설정값 없이 단독으로 사용되는 경우 소켓 목록이 리셋되게 된다.StartLimitInterval=
*,StartLimitBurst=- 위의 두 설정값을 이용하여 제한된 시간에 너무 많은 재시작 (Restart=) 이 발생되는 것을 방지해 준다. 기본값에 따르면 10초 간격으로 5번까지 서비스 시작을 허용하고 그 이상 더 재시작 이벤트가 발생하면 자동으로 재시작 하지 않도록 설정해 준다. (즉 1분내 5번 재시작 시도이후 복구 불가시 Fail 발생) 나중에 관리자가 수동으로 구동하여 복구 할 수 있도록 하여 무한대의 유닛 재시작 이벤트 발생을 방지한다.StartLimitInterval=
*옵션의 경우 기본값10초(10s),0으로 설정할 경우 비활성화한다.StartLimitBurst=
*옵션의 경우 기본값5회StartLimitAction=[none|reboot|reboot-force|reboot-immediate]
*- 만일 복구 재시도가 제한된 설정 (Service Recovery Limit > StartLimitInterval * StartLimitBurst) 내에 마치지 못하면 다음 조치로 어떠한 방식의 작동을 할지 선언한다.none
*(기본값), 아무런 액션도 하지 않습니다.reboot
*시스템을 재부팅 한다. (systemctl reboot 와 동일)reboot-force
*시스템을 강제 제부팅 한다. 단 데이타 유실은 없다. (systemctl reboot -f 와 동일, sync후 강제 재부팅)reboot-immediate
*시스템을 강제 재부팅 한다. 데이타의 유실이 있다. reboot() 함수를 사용하여 즉각적인 재부팅을 수행한다.sync과정없이 진행Nice=
*- 해당 유닛의 프로세스의nice값을 지정한다.-20부터19까지 정수형으로 등록한다.OOMScoreAdjust=
*-OOM(Out Of Memory)killer 작동시 프로세스 조정값를 미리 지정할 수 있다.-1000에서1000까지 정수형으로 등록한다.UMask=
*-umask값을 선언한다. 별도의 설정이 없으면 기본값은0022이다.SyslogFacility=
*- 로그 카테고리를 설정할 수 있다.kern, user, mail, daemon, auth, syslog, lpr, news, uucp, cron, authpriv, ftp, local0, local1, local2, local3, local4, local5, local6, local7등의 값으로 설정 가능하다.SyslogLevel=
*- 로그 레벨을 설정할 수 있다.emerg, alert, crit, err, warning, notice, info, debug등 설정이 가능하다.TCPWrapName=
*- TCP 래퍼를 사용하기위한 설정이다.PAMName=
*- PAM 보안 사설을 사용하기 위한 설정이다.Alias=
===== [Install] section =====
*- 유닛의 알리아스 이름을 지정한다.systemctl enable명령어를 통해서 알리아스 이름으로 생성할 수 있다. 알리아스 이름은 유닛 파일 확장자(유닛 타입)를 가지고 있어야 한다. (service,socket,mount,swap등이 있다. 예: httpd.service 의 Alias=apache.service)WantedBy=
*,RequiredBy=-systemctl enable명령어로 유닛을 등록할때 등록에 필요한 유닛을 지정한다. 해당 유닛을 등록하기위한 종속성 검사 단계로 보면 된다. 따라서 해당 설정은[Unit]섹션의Wants=와Requires=옵션과 관계 있다.Also=
*-systemctl enable와systemctl disable'' 로 유닛을 등록하거나 해제할때 다른 유닛 또한 같이 등록, 해제를 하도록 구성할 수 있다.