====== systemd ======
* [[https://mxlinux.org/wiki/system/systemd-overview/|MX Linux systemd overview]]
* [[https://lunatine.net/2014/10/21/about-systemd/|systemd 살펴보기]]
* [[http://linux.systemv.pe.kr/centos-7-systemd-%EC%9D%B4%ED%95%B4%ED%95%98%EA%B8%B0/|CentOS 7 Systemd 이해하기 - Voyager of Linux]]
* [[https://wiki.archlinux.org/index.php/systemd|systemd Arch wiki]]
* [[linux:arch|Arch Linux]]는 ''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'' 형태만 된다.
* [[https://www.freedesktop.org/software/systemd/man/environment.d.html|environment.d]]
* ''/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 시작 프로그램 =====
* [[https://linux.systemv.pe.kr/systemd-user-%EC%82%AC%EC%9A%A9%ED%95%98%EA%B8%B0/|systemd -user 사용하기 - Voyager of Linux]]
* [[https://tanzolab.it/systemd|How to use systemd for applications start (revised on May 2019)]]
* [[https://wiki.archlinux.org/title/Systemd/User|systemd/User - ArchWiki]]
* [[https://nodesource.com/blog/running-your-node-js-app-with-systemd-part-1/|Running Your Node.js App With Systemd - Part 1 - NodeSource]]
* [[https://support.nine.ch/articles/manage-daemons-as-user-with-systemd#enable-a-service|Manage daemons as user with systemd - nine Support]]
===== systemd bootchart =====
* [[http://manpages.ubuntu.com/manpages/focal/man1/systemd-bootchart.1.html|Ubuntu Manpage: systemd-bootchart - Boot performance graphing tool]]
sudo apt install systemd-bootchart
systemd-analyze
systemd-analyze blame
* [[linux:grub|Linux Grub]] 에서 커널 설정에 ''init=/lib/systemd/systemd-bootchart'' 넣고 부팅하면 ''/run/log/bootchart-날짜-번호.svg'' 파일이 생성되고 이 이미지를 보고 부팅 성능 병목 지점을 찾을 수 있다.
* [[https://www.facebook.com/groups/ubuntu.ko/permalink/3721279894576497/|systemd bootchart 설명]]
===== 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 명령으로 사용가능하다.
* [[https://unix.stackexchange.com/questions/233468/how-does-systemd-use-etc-init-d-scripts/233581#233581|How does systemd use /etc/init.d scripts? - Unix & Linux Stack Exchange]]
* 이는 [[https://www.freedesktop.org/software/systemd/man/systemd-sysv-generator.html|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''의 서비스 파일에는 주석으로 [[https://refspecs.linuxbase.org/LSB_3.1.1/LSB-Core-generic/LSB-Core-generic/iniscrptact.html|LSB Headers]]라는 값이 들어있어서 systemd 로 변환하는 정보로 사용한다.
===== 참조 =====
* [[https://www.youtube.com/playlist?list=PL6IQ3nFZzWfpKKWfZMRxiuEBwqQBwjzS1|Systemd Tutorials - youtube]]
* [[https://www.debugpoint.com/2021/01/systemd-journald-clean/|A Guide to systemd journal clean up process [With Examples]]]
* [[https://www.youtube.com/watch?v=5JVBpXiYMKo&t=4s|Linux Essentials - systemd: Using the systemctl command - YouTube]]
* [[https://gist.github.com/oprypin/0f0c3479ab53e00988b52919e5d7c144|systemd user unit + timer example]]