Linux Admin-systemctl을 사용한 리소스 관리
systemctlsystemd를 제어하는 데 사용되는 유틸리티입니다. systemctl은 CentOS 관리자에게 다음을 포함하여 systemd에서 다양한 작업을 수행 할 수있는 기능을 제공합니다.
- 시스템 단위 구성
- systemd untis 상태 가져 오기
- 서비스 시작 및 중지
- 런타임 등을위한 systemd 서비스 활성화 / 비활성화
systemctl 의 명령 구문 은 매우 기본적이지만 스위치 및 옵션과 얽힐 수 있습니다. CentOS Linux 관리에 필요한 systemctl 의 가장 필수적인 기능을 소개 합니다.
Basic systemctl syntax:
systemctl [OPTIONS] COMMAND [NAME]
다음은 systemctl 과 함께 사용되는 일반적인 명령입니다 -
- start
- stop
- restart
- reload
- status
- is-active
- list-units
- enable
- disable
- cat
- show
이미 systemctl을 사용 하여 start , stop , reload , restart , 활성화 및 비활성화 에 대해 논의했습니다. 이제 나머지 일반적으로 사용되는 명령을 살펴 보겠습니다.
상태
가장 간단한 형태로 상태 명령을 사용하여 시스템 상태를 전체적으로 볼 수 있습니다.
[root@localhost rdc]# systemctl status
● localhost.localdomain
State: running
Jobs: 0 queued
Failed: 0 units
Since: Thu 2017-01-19 19:14:37 EST; 4h 5min ago
CGroup: /
├─1 /usr/lib/systemd/systemd --switched-root --system --deserialize 21
├─user.slice
│ └─user-1002.slice
│ └─session-1.scope
│ ├─2869 gdm-session-worker [pam/gdm-password]
│ ├─2881 /usr/bin/gnome-keyring-daemon --daemonize --login
│ ├─2888 gnome-session --session gnome-classic
│ ├─2895 dbus-launch --sh-syntax --exit-with-session
위의 출력이 응축되었습니다. 실제 systemctl 상태에서 약 100 줄의 트리 프로세스 상태가 출력됩니다.
방화벽 서비스의 상태를 확인하고 싶다고 가정 해 보겠습니다.
[root@localhost rdc]# systemctl status firewalld
● firewalld.service - firewalld - dynamic firewall daemon
Loaded: loaded (/usr/lib/systemd/system/firewalld.service; enabled; vendor preset: enabled)
Active: active (running) since Thu 2017-01-19 19:14:55 EST; 4h 12min ago
Docs: man:firewalld(1)
Main PID: 825 (firewalld)
CGroup: /system.slice/firewalld.service
└─825 /usr/bin/python -Es /usr/sbin/firewalld --nofork --nopid
보시다시피 방화벽 서비스는 현재 활성화되어 있으며 4 시간 이상 지속되었습니다.
목록 단위
list-units 명령을 사용하면 특정 유형의 모든 단위를 나열 할 수 있습니다. 소켓에 대한하자 검사에 의해 관리 systemd -
[root@localhost]# systemctl list-units --type=socket
UNIT LOAD ACTIVE SUB DESCRIPTION
avahi-daemon.socket loaded active running Avahi mDNS/DNS-SD Stack Activation Socket
cups.socket loaded active running CUPS Printing Service Sockets
dbus.socket loaded active running D-Bus System Message Bus Socket
dm-event.socket loaded active listening Device-mapper event daemon FIFOs
iscsid.socket loaded active listening Open-iSCSI iscsid Socket
iscsiuio.socket loaded active listening Open-iSCSI iscsiuio Socket
lvm2-lvmetad.socket loaded active running LVM2 metadata daemon socket
lvm2-lvmpolld.socket loaded active listening LVM2 poll daemon socket
rpcbind.socket loaded active listening RPCbind Server Activation Socket
systemd-initctl.socket loaded active listening /dev/initctl Compatibility Named Pipe
systemd-journald.socket loaded active running Journal Socket
systemd-shutdownd.socket loaded active listening Delayed Shutdown Socket
systemd-udevd-control.socket loaded active running udev Control Socket
systemd-udevd-kernel.socket loaded active running udev Kernel Socket
virtlockd.socket loaded active listening Virtual machine lock manager socket
virtlogd.socket loaded active listening Virtual machine log manager socket
이제 현재 실행중인 서비스를 확인해 보겠습니다.
[root@localhost rdc]# systemctl list-units --type=service
UNIT LOAD ACTIVE SUB DESCRIPTION
abrt-ccpp.service loaded active exited Install ABRT coredump hook
abrt-oops.service loaded active running ABRT kernel log watcher
abrt-xorg.service loaded active running ABRT Xorg log watcher
abrtd.service loaded active running ABRT Automated Bug Reporting Tool
accounts-daemon.service loaded active running Accounts Service
alsa-state.service loaded active running Manage Sound Card State (restore and store)
atd.service loaded active running Job spooling tools
auditd.service loaded active running Security Auditing Service
활성
는 인 액티브 명령은 장치의 상태 정보를 반환하도록 설계 systemctl 명령의 일례이다.
[root@localhost rdc]# systemctl is-active ksm.service
active
고양이
cat 은 거의 사용되지 않는 명령 중 하나입니다. 셸에서 cat을 사용하고 단위 파일의 경로를 입력하는 대신 systemctl cat을 사용 하면 됩니다.
[root@localhost]# systemctl cat firewalld
# /usr/lib/systemd/system/firewalld.service
[Unit]
Description=firewalld - dynamic firewall daemon
Before=network.target
Before=libvirtd.service
Before = NetworkManager.service
After=dbus.service
After=polkit.service
Conflicts=iptables.service ip6tables.service ebtables.service ipset.service
Documentation=man:firewalld(1)
[Service]
EnvironmentFile = -/etc/sysconfig/firewalld
ExecStart = /usr/sbin/firewalld --nofork --nopid $FIREWALLD_ARGS
ExecReload = /bin/kill -HUP $MAINPID
# supress to log debug and error output also to /var/log/messages
StandardOutput = null
StandardError = null
Type = dbus
BusName = org.fedoraproject.FirewallD1
[Install]
WantedBy = basic.target
Alias = dbus-org.fedoraproject.FirewallD1.service
[root@localhost]#
systemd 와 systemctl 을 더 자세히 살펴 보았 으므로 이제이를 사용하여 cgroup 또는 control groups 의 리소스를 관리해 보겠습니다 .