主頁 > 作業系統 > linux 基礎入門(9) 系統服務 systemctl 與 xinted的運用

linux 基礎入門(9) 系統服務 systemctl 與 xinted的運用

2020-09-30 04:08:01 作業系統

9.系統服務

9.1系統服務

可以把計算機理解為一個地點比如中關村大街系統服務理解為中關村大街的理發店、飯店、商場等等,每一個都是一個系統服務,為客戶提供不同內容的服務

服務:常駐在記憶體中的程式,且可以提供一些系統或網路功能,那就是服務,
計算機中的系統服務有很多,比如
apache提供web服務
ftp提供檔案下載上傳服務
ssh提供了遠程連接服務
防火墻提供了安全防護服務等等

9.2守護行程

Linux服務器的主要任務就是為本地或遠程用戶提供各種服務,通常 Linux系統上提供服務的程式是由運行在后臺的守護行程( Daemon)來執行,一個實際運行中的 Linux系統一般會有多個這樣的程式在運行,這些后臺守護行程在系統開機后就運行了,并且在時刻地監聽前臺客戶地服務請求,一旦客戶發出了服務請求,守護行程便為它們提供服務,

9.3特殊守護行程

系統初始化行程是一個特殊的的守護行程,其PD為1,它是所有其他守護行程的父行程或者祖先行程,也就是說,系統上所有的守護行程都是由系統初始化行程進行管理的(如啟動、停止等),
系統上所有的守護行程都是由系統初始化行程進行管理的(如啟動、停止等)

systemV(紅帽7之前)
ini按照優先級的高低,先后喚醒其他服務
服務有依賴關系
多命令協同作業管理服務

命令包括 init service chkconfig

systemd
并行啟動,速度更快
服務依賴性的自我檢查
一個命令管理服務
向下兼容int服務腳本

命令就一個systemctl

9.4服務分類

  • 獨立服務
    采用 systemd管理,服務獨立的運行在記憶體中,服務回應速度快,但占用更多記憶體,
  • 非獨立服務
    xinetd服務本身獨立存在,管理一些服務,用戶通過 xinetd服務請求其管理的一些服務,然后 xinetd回傳請求服務的回復給用戶,相當代理,

9.4.1獨立服務

獨立服務運行在記憶體中,服務回應塊,但占用更多記憶體,

獨立服務的服務啟動腳本 都在目錄 /usr/lib/systemd/system里

systemctl命令

systemctl [command] [unit]
command主要有
start:立刻啟動后面接的unit
stop:立刻關閉后面接的unit,
restart:立刻關閉后啟動后面接的unt,亦即執行stop再 start的意思,
reload:不關閉unit的情況下,重新載入組態檔,讓設定生效,
enable:設定下次開機時,后面接的unit會被啟動
disable:設定下次開機時,后面接的unit不會被啟動,
status:目前后面接的這個unt的狀態,會列出有沒有正在執行、開機時是否啟動等資訊,
is- active:目前有沒有正在運行中,
is- enabled:開機時有沒有默認要啟用這個unit,
kill:不要被kill這個名字嚇著了,它其實是向運行unit的行程發送信號
show:列出unit的配置,
mask:注銷unit,注銷后你就無法啟動這個unit了
unmask:取消對unit的注銷

部署獨立服務 vsftpd

查看是否安裝

[wangzirui@laotie system]$ yum list vsftpd
已加載插件:fastestmirror, langpacks
Loading mirror speeds from cached hostfile
 * base: ap.stykers.moe
 * extras: ap.stykers.moe
 * updates: ap.stykers.moe
已安裝的軟體包
vsftpd.x86_64                       3.0.2-25.el7                       installed

Systemctl status vsftpd

可以查看當前vsftpd的狀態

[wangzirui@laotie system]$ systemctl status vsftpd
● vsftpd.service - Vsftpd ftp daemon
   Loaded: loaded (/usr/lib/systemd/system/vsftpd.service; disabled; vendor preset: disabled)
   Active: inactive (dead)

Loaded是是否開機啟動,是disabled,,Active是指是否現在啟動,是Inactive,所以這個服務現在是沒啟動呢,

啟動服務

sytemctl start vsftpd

[root@laotie system]# systemctl start vsftpd

沒有回執說明已經啟動成功,

現在來查看vsftpd的狀態

[wangzirui@laotie system]$ systemctl status vsftpd
● vsftpd.service - Vsftpd ftp daemon
   Loaded: loaded (/usr/lib/systemd/system/vsftpd.service; disabled; vendor preset: disabled)
   Active: active (running) since 一 2020-02-10 22:20:40 CST; 1min 17s ago
  Process: 4204 ExecStart=/usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf (code=exited, status=0/SUCCESS)
 Main PID: 4206 (vsftpd)
    Tasks: 1
   CGroup: /system.slice/vsftpd.service
           └─4206 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf

2月 10 22:20:40 laotie systemd[1]: Starting Vsftpd ftp daemon...
2月 10 22:20:40 laotie systemd[1]: Started Vsftpd ftp daemon.

關閉vsftpd

[wangzirui@laotie system]$ systemctl stop vsftpd
[wangzirui@laotie system]$ systemctl status vsftpd
● vsftpd.service - Vsftpd ftp daemon
   Loaded: loaded (/usr/lib/systemd/system/vsftpd.service; disabled; vendor preset: disabled)
   Active: inactive (dead)

2月 10 22:20:40 laotie systemd[1]: Starting Vsftpd ftp daemon...
2月 10 22:20:40 laotie systemd[1]: Started Vsftpd ftp daemon.
2月 10 22:24:15 laotie systemd[1]: Stopping Vsftpd ftp daemon...
2月 10 22:24:15 laotie systemd[1]: Stopped Vsftpd ftp daemon.

關于restart和reload

restart 之后 他的Main PID會改變,而reload之后Main PID不會改變,

關于開機是否啟動

Systemctl enable vsftpd

[wangzirui@laotie system]$ systemctl enable vsftpd
Created symlink from /etc/systemd/system/multi-user.target.wants/vsftpd.service to /usr/lib/systemd/system/vsftpd.service.

相當于把vsftpd.service連接到了multi-user.target.wants.然后實作了開機啟動,這時候我們查看

[wangzirui@laotie system]$ systemctl status vsftpd
● vsftpd.service - Vsftpd ftp daemon
   Loaded: loaded (/usr/lib/systemd/system/vsftpd.service; enabled; vendor preset: disabled)
   Active: active (running) since 一 2020-02-10 22:27:53 CST; 9min ago
 Main PID: 4508 (vsftpd)
   CGroup: /system.slice/vsftpd.service
           └─4508 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf

2月 10 22:27:53 laotie systemd[1]: Starting Vsftpd ftp daemon...
2月 10 22:27:53 laotie systemd[1]: Started Vsftpd ftp daemon.

Loaded變成了enabled,表示他開機就啟動了

要不想讓他啟動了就disable就行了,

[wangzirui@laotie system]$ systemctl disable vsftpd
Removed symlink /etc/systemd/system/multi-user.target.wants/vsftpd.service.

禁用服務

[wangzirui@laotie system]$ systemctl mask vsftpd
Created symlink from /etc/systemd/system/vsftpd.service to /dev/null.

現在這種狀態不能開始,不能暫停,

那有沒有可以直接判定一個服務是否在服務呢?

Systemctl is-active vsftpd

[root@laotie system]# systemctl is-active vsftpd
active

9.5非獨立服務

xinetd:超級守護行程,可以把—些小服務放到κinet里進行托管,托管后的好處就是可以使用 xinetd強大的引數來控制這些服務,并且增強安全性,
Xinetd提供類似于 inetd+ TCP Wrappers的功能,但是更加強大和安全,后面 xinetd已經取代了 inetd,并且提供了訪問控制、加強的日志和資源管理功能,
TCP Wrappers是一個應用層的訪問控制程式,其原理是在服務器向外提供的TCP服務上包裹一層安全檢測機制,外來的連接請求首先要通過這層安全檢測,獲得認證之后才能被系統服務接收,

相關目錄

xinetd服務的主組態檔:etc/ xinetd.conf
用于存放被托管的服務的目錄:/etc/ xinetd.d/

部署一個非獨立服務telnet

首先安裝這個服務的服務端和客戶端還有超級守護行程xinetd

[root@laotie system]# yum -y install telnet-server telnet xinetd

-y的意思就是默認都是Y,安裝的時候省了來回的輸入y了,

接下來進入/etc/xinetd.d/然后新建一個telnet的檔案

[root@laotie system]# cd /etc/xinetd.d
[root@laotie xinetd.d]# vim telnet

內容為下面的:

service telnet

{flags=REUSE
socket_type= stream
wait = no
user= root
server=/usr/sbin/in.telnetd
log_on_ failure += USERID
disable= no

}

引數的宣告

可以設定為yes或no,設定為yes將禁用一個服務,詳見fags的 disable標簽

? disable =no

指定失敗時登記的資訊,總是登記表明錯誤性質的訊息,默認時不登記仼何資訊,該屬性攴持所有運算子,∪ SERID

通過RFC1413呼叫捕獲客戶機用戶的∪D,只可用于多執行緒的流服務
log on failure += USERID

使用的 TCP/IP socket型別,值可能為stam(TCP), dgram(UDP),raW和 Iseqpacket(可靠的有序資料包)

? socket type= stream

指定傳送給該行程的引數,但是不包括服務程式名

? server args =--daemon

用來設定連接速率,它需要兩個引數,第一個引數表示每秒可以處理的連接數,如果超過了這個連接數時,之后進入的連接將被暫時停止處理;第二個引數表示停止處理多少秒后,繼續處理先前暫停處理的連接
cps=2530

指定該服務使用的協議,其值必須是在 etc/protocols中定義的,如果不指定,使用該項服務的默認協議

? protocol = tcp

這個屬性有兩個可能的值,如果是yes,那么 xinetd會啟動對方請求的行程,并停止處理該項服務的其他請求直到行程終止,適合于單執行緒服務;如果是no,那xnet會為每個請求啟動的一個行程,而不管先前啟動的行程的狀態,適合于多執行緒服務
wait=no

設定服務行程的UD,若 xinetd的有效UD不是0,該屬性無效

? user=root

要激活的行程,必須指定完整的路徑

? server =/usr/sbin/sshd

指定傳送給該行程的引數,但是不包括服務程式名

? server= args

用空格分開的允許訪問服務的客戶機串列,如果不為該屬性指定一個值,就拒絕仼何人訪問這項服務,該屬性支持所有運算子,
only_from=192.168.1.0/24
no_access=192.168.1.20192.168.1.200

最大連接數為3

? instances =3

每個源P只能有1個連接

? per source =1

只能9:00到18:00才能ssh連接

? access times =9: 00-18: 00

指定日志記錄到arog/ xinetd ssh. log里

? log type=fe/ ar/log/xinetd_ssh. log#指定日志記錄到 var/log/xinetd ssh. log里
服務埠
? pot=7722

[root@laotie xinetd.d]# systemctl start xinetd

怎么證明是不是開啟了,可以直接看網路的狀態,用netstat這個命令

[root@laotie wangzirui]# netstat -ntpl
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name    
tcp        0      0 127.0.0.1:631           0.0.0.0:*               LISTEN      1076/cupsd          
tcp        0      0 127.0.0.1:25            0.0.0.0:*               LISTEN      1354/master         
tcp        0      0 0.0.0.0:111             0.0.0.0:*               LISTEN      1/systemd           
tcp        0      0 192.168.122.1:53        0.0.0.0:*               LISTEN      1396/dnsmasq        
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      1080/sshd           
tcp6       0      0 ::1:631                 :::*                    LISTEN      1076/cupsd          
tcp6       0      0 :::23                   :::*                    LISTEN      1084/xinetd         
tcp6       0      0 ::1:25                  :::*                    LISTEN      1354/master         
tcp6       0      0 :::111                  :::*                    LISTEN      1/systemd           
tcp6       0      0 :::22                   :::*                    LISTEN      1080/sshd           

可以看到23這個埠號,所以就可以進行talnet的啟動了,

[wangzirui@laotie ~]$ telnet localhost
Trying ::1...
Connected to localhost.
Escape character is '^]'.

Kernel 3.10.0-1062.el7.x86_64 on an x86_64
laotie login: wangzirui
Password: 
Last login: Tue Feb 11 00:15:56 on pts/0

轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/140833.html

標籤:Linux

上一篇:記一次生產事故--磁盤被占滿

下一篇:linux 基礎入門(8) 軟體安裝 rpm、yum與原始碼安裝詳解

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • CA和證書

    1、在 CentOS7 中使用 gpg 創建 RSA 非對稱密鑰對 gpg --gen-key #Centos上生成公鑰/密鑰對(存放在家目錄.gnupg/) 2、將 CentOS7 匯出的公鑰,拷貝到 CentOS8 中,在 CentOS8 中使用 CentOS7 的公鑰加密一個檔案 gpg -a ......

    uj5u.com 2020-09-10 00:09:53 more
  • Kubernetes K8S之資源控制器Job和CronJob詳解

    Kubernetes的資源控制器Job和CronJob詳解與示例 ......

    uj5u.com 2020-09-10 00:10:45 more
  • VMware下安裝CentOS

    VMware下安裝CentOS 一、軟硬體準備 1 Centos鏡像準備 1.1 CentOS鏡像下載地址 下載地址 1.2 CentOS鏡像下載程序 點擊下載地址進入如下圖的網站,選擇需要下載的版本,這里選擇的是Centos8,點擊如圖所示。 決定選擇Centos8后,選擇想要的鏡像源進行下載,此 ......

    uj5u.com 2020-09-10 00:12:10 more
  • 如何使用Grep命令查找多個字串

    如何使用Grep 命令查找多個字串 大家好,我是良許! 今天向大家介紹一個非常有用的技巧,那就是使用 grep 命令查找多個字串。 簡單介紹一下,grep 命令可以理解為是一個功能強大的命令列工具,可以用它在一個或多個輸入檔案中搜索與正則運算式相匹配的文本,然后再將每個匹配的文本用標準輸出的格式 ......

    uj5u.com 2020-09-10 00:12:28 more
  • git配置http代理

    git配置http代理 經常遇到克隆 github 慢的問題,這里記錄一下幾種配置 git 代理的方法,解決 clone github 過慢。 目錄 git配置代理 git單獨配置github代理 git配置全域代理 配置終端環境變數 git配置代理 主要使用 git config 命令 git單獨 ......

    uj5u.com 2020-09-10 00:12:33 more
  • Linux npm install 裝包時提示Error EACCES permission denied解

    npm install 裝包時提示Error EACCES permission denied解決辦法 ......

    uj5u.com 2020-09-10 00:12:53 more
  • Centos 7下安裝nginx,使用yum install nginx,提示沒有可用的軟體包

    Centos 7下安裝nginx,使用yum install nginx,提示沒有可用的軟體包。 18 (flaskApi) [root@67 flaskDemo]# yum -y install nginx 19 已加載插件:fastestmirror, langpacks 20 Loading ......

    uj5u.com 2020-09-10 00:13:13 more
  • Linux查看服務器暴力破解ssh IP

    在公網的服務器上經常遇到別人爆破你服務器的22埠,用來挖礦或者干其他嘿嘿嘿的事情~ 這種情況下正確的做法是: 修改默認ssh的22埠 使用設定密鑰登錄或者白名單ip登錄 建議服務器密碼為復雜密碼 創建普通用戶登錄服務器(root權限過大) 建立堡壘機,實作統一管理服務器 統計爆破IP [root ......

    uj5u.com 2020-09-10 00:13:17 more
  • CentOS 7系統常見快捷鍵操作方式

    Linux系統中一些常見的快捷方式,可有效提高操作效率,在某些時刻也能避免操作失誤帶來的問題。 ......

    uj5u.com 2020-09-10 00:13:31 more
  • CentOS 7作業系統目錄結構介紹

    作業系統存在著大量的資料檔案資訊,相應檔案資訊會存在于系統相應目錄中,為了更好的管理資料資訊,會將系統進行一些目錄規劃,不同目錄存放不同的資源。 ......

    uj5u.com 2020-09-10 00:13:35 more
最新发布
  • vim的常用命令

    Vim的6種基本模式 1. 普通模式在普通模式中,用的編輯器命令,比如移動游標,洗掉文本等等。這也是Vim啟動后的默認模式。這正好和許多新用戶期待的操作方式相反(大多數編輯器默認模式為插入模式)。 2. 插入模式在這個模式中,大多數按鍵都會向文本緩沖中插入文本。大多數新用戶希望文本編輯器編輯程序中一 ......

    uj5u.com 2023-04-20 08:43:21 more
  • vim的常用命令

    Vim的6種基本模式 1. 普通模式在普通模式中,用的編輯器命令,比如移動游標,洗掉文本等等。這也是Vim啟動后的默認模式。這正好和許多新用戶期待的操作方式相反(大多數編輯器默認模式為插入模式)。 2. 插入模式在這個模式中,大多數按鍵都會向文本緩沖中插入文本。大多數新用戶希望文本編輯器編輯程序中一 ......

    uj5u.com 2023-04-20 08:42:36 more
  • docker學習

    ###Docker概述 真實專案部署環境可能非常復雜,傳統發布專案一個只需要一個jar包,運行環境需要單獨部署。而通過Docker可將jar包和相關環境(如jdk,redis,Hadoop...)等打包到docker鏡像里,將鏡像發布到Docker倉庫,部署時下載發布的鏡像,直接運行發布的鏡像即可。 ......

    uj5u.com 2023-04-19 09:26:53 more
  • 設定Windows主機的瀏覽器為wls2的默認瀏覽器

    這里以Chrome為例。 1. 準備作業 wsl是可以使用Windows主機上安裝的exe程式,出于安全考慮,默認情況下改功能是無法使用。要使用的話,終端需要以管理員權限啟動。 我這里以Windows Terminal為例,介紹如何默認使用管理員權限打開終端,具體操作如下圖所示: 2. 操作 wsl ......

    uj5u.com 2023-04-19 09:25:49 more
  • docker學習

    ###Docker概述 真實專案部署環境可能非常復雜,傳統發布專案一個只需要一個jar包,運行環境需要單獨部署。而通過Docker可將jar包和相關環境(如jdk,redis,Hadoop...)等打包到docker鏡像里,將鏡像發布到Docker倉庫,部署時下載發布的鏡像,直接運行發布的鏡像即可。 ......

    uj5u.com 2023-04-19 09:19:04 more
  • Linux學習筆記

    IP地址和主機名 IP地址 ifconfig可以用來查詢本機的IP地址,如果不能使用,可以通過install net-tools安裝。 Centos系統下ens33表示主網卡;inet后表示IP地址;lo表示本地回環網卡; 127.0.0.1表示代指本機;0.0.0.0可以用于代指本機,同時在放行設 ......

    uj5u.com 2023-04-18 06:52:01 more
  • 解決linux系統的kdump服務無法啟動的問題

    問題:專案麒麟系統服務器的kdump服務無法啟動,沒有相關日志無法定位問題。 1、查看服務狀態是關閉的,重啟系統也無法啟動 systemctl status kdump 2、修改grub引數,修改“crashkernel”為“512M(有的機器數值太大太小都會導致報錯,建議從128M開始試,或者加個 ......

    uj5u.com 2023-04-12 09:59:50 more
  • 解決linux系統的kdump服務無法啟動的問題

    問題:專案麒麟系統服務器的kdump服務無法啟動,沒有相關日志無法定位問題。 1、查看服務狀態是關閉的,重啟系統也無法啟動 systemctl status kdump 2、修改grub引數,修改“crashkernel”為“512M(有的機器數值太大太小都會導致報錯,建議從128M開始試,或者加個 ......

    uj5u.com 2023-04-12 09:59:01 more
  • 你是不是暴露了?

    作者:袁首京 原創文章,轉載時請保留此宣告,并給出原文連接。 如果您是計算機相關從業人員,那么應該經歷不止一次網路安全專項檢查了,你肯定是收到過資訊系統技術檢測報告,要求你加強風險監測,確保你提供的系統服務堅實可靠了。 沒檢測到問題還好,檢測到問題的話,有些處理起來還是挺麻煩的,尤其是線上正在運行的 ......

    uj5u.com 2023-04-05 16:52:56 more
  • 細節拉滿,80 張圖帶你一步一步推演 slab 記憶體池的設計與實作

    1. 前文回顧 在之前的幾篇記憶體管理系列文章中,筆者帶大家從宏觀角度完整地梳理了一遍 Linux 記憶體分配的整個鏈路,本文的主題依然是記憶體分配,這一次我們會從微觀的角度來探秘一下 Linux 內核中用于零散小記憶體塊分配的記憶體池 —— slab 分配器。 在本小節中,筆者還是按照以往的風格先帶大家簡單 ......

    uj5u.com 2023-04-05 16:44:11 more