사용자 도구

사이트 도구


linux:systemd

systemd

unit 모음 디렉토리

  • /etc/systemd/system
  • /run/systemd/system
  • /usr/local/lib/systemd/system
  • /usr/lib/systemd/system

사용법

# 지금 시작
systemctl start unit
 
# 종료
systemctl stop unit
 
# 재시작
systemctl restart unit
 
# booting 시 시작하게 설정
systemctl enable unit
 
# booting 시 시작하게 하면서, 지금 당장도 실행하게
systemctl enable --now unit

environment.d

  • 세션 시작시 환경 변수를 설정하기
  • script 는 안되고, NAME=value 형태만 된다.
  • /etc/environment.d/*.conf, ~/.config/environment.d/*.conf 파일에 환경변수를 NAME=VALUE 형태로 지정한다.
  • 스크립트를 넣을 수는 없다.
# 예시 /etc/environment.d/60-foo.conf:

FOO_DEBUG=force-software-gl,log-verbose
PATH=/opt/foo/bin:$PATH
LD_LIBRARY_PATH=/opt/foo/lib${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}
XDG_DATA_DIRS=/opt/foo/share:${XDG_DATA_DIRS:-/usr/local/share/:/usr/share/}

user 시작 프로그램

systemd bootchart

sudo apt install systemd-bootchart
systemd-analyze
systemd-analyze  blame
  • Linux Grub 에서 커널 설정에 init=/lib/systemd/systemd-bootchart 넣고 부팅하면 /run/log/bootchart-날짜-번호.svg 파일이 생성되고 이 이미지를 보고 부팅 성능 병목 지점을 찾을 수 있다.

Shutdown 이 너무 느릴 때

  • shutdown / 종료 등이 너무 느릴 때 분석해서 문제가 되는 서비스를 종료처리하거나 각종 타임아웃 설정을 해줘야 한다.

분석

  • journalctl -b -1 은 이전 부팅 로그를 표시하며, 종료 전의 로그를 확인할 수 있다.
sudo journalctl -b -1 > log
  • log 파일을 분석해서 stopping 로그 들 중에 timeout 분석해서 처리한다.

일괄로 종료 Timeout 지정

  • 분석이 힘들거나 할 경우 다음과 같이 일괄 타임아웃을 지정할 수도 있다.
  • /etc/systemd/system.conf
    DefaultTimeoutStopSec=10s # 원래 90s 임.
  • 재시작
    sudo systemctl daemon-reexec

systemd 는 어떻게 기존 SysVInit 의 /etc/init.d/* 서비스를 인식하는가

  • Systemd 로 변경했음에도 기존 SysVInit 이 사용하던 /etc/init.d/* 의 서비스를 systemd 명령으로 사용가능하다.
  • 이는 systemd-sysv-generator/etc/init.d/*의 서비스를 읽어서 동적으로 systemd unit 으로 바꿔주기 때문이다. (/usr/lib/systemd/system-generators/systemd-sysv-generator)
  • systemd unit 은 /run/systemd/generator.late*.service로 동적으로 생성된다.
  • systemd 는 init.d를 자동 인식하는게 아니라, systemd unit 이라고 인식하게 되는 것이다.
  • init.d의 서비스 파일에는 주석으로 LSB Headers라는 값이 들어있어서 systemd 로 변환하는 정보로 사용한다.

참조

linux/systemd.txt · 마지막으로 수정됨: 2025/01/17 14:01 저자 kwon37xi