主頁 > 作業系統 > 配置sshd_使用CA簽名證書登錄_更新sshd服務端的通訊密鑰

配置sshd_使用CA簽名證書登錄_更新sshd服務端的通訊密鑰

2022-11-15 06:22:06 作業系統

配置sshd_使用CA簽名證書登錄_更新sshd服務端的通訊密鑰

轉載注明來源: 本文鏈接 來自osnosn的博客,寫于 2022-11-06.

用CA簽名證書登錄

  • 請參考【SSH 證書登錄教程】,這個舊了,
  • 參考:【Creating SSH CA Certificate Signing Keys】,這是基于openSSH-5.3p1
  • 【SSH 證書登錄教程】
  • 【基于CA簽名的用戶公鑰管理】,【基于CA簽名的用戶公鑰管理】
  • 【證書登錄的流程】
  • 【Linux 采用 SSH CA 登陸驗證】
  • putty-0.77 還不支持這種認證,putty-0.78 開始支持CA簽名證書認證,
  • winscp-5.21.5 還不支持這種認證,下一個版本可能會支持,

ssh登錄程序中,基于簽名(證書)的用戶認證

  • 基于 openSSH-8.0p1 , 測驗成功,

  • 創建 用于簽發用戶證書的密鑰(用戶CA),管理員創建,私鑰不傳遞,
    ssh-keygen -t ed25519 -C user_ca@myCA -f user_ca
    得到兩個檔案,user_ca , user_ca.pub
    只是密鑰對,不是證書,因為沒做自簽名證書,

  • 讓sshd服務端信任"用戶CA"的公鑰,(方法一,用戶級)
    建議限制 principals,如果多個服務器信任同一個CA,只要每個服務器上的 principals 都不同,
    就能做到,用同一個CA簽發的用戶證書,能登錄其中一個服務器,而不能登錄別的服務器,
    在sshd服務器上,用戶的 ~/.ssh/authorized_keys 中加入一行(用戶CA的公鑰),此檔案權限mode要求是0600,
    cert-authority,principals="host02,allhost" ssh-ed25519 AAAAC.....xx user_ca@myCA
    內容為 user_ca.pub 檔案的內容,
    如果用戶證書包含 host02 或 allhost 才能登錄(此種情況不判斷用戶名),
    每個想用證書登錄的用戶的 ~/.ssh/authorized_keys 都要加一行,

    • 不做限制,在sshd服務器上,用戶的 ~/.ssh/authorized_keys 中加入一行(用戶CA的公鑰),
      cert-authority ssh-ed25519 AAAAC.....xx user_ca@myCA
      如果用戶證書沒有principals,可以登錄
      如果用戶證書有principals,必須包含用戶名 才能登錄,
  • 讓sshd服務端信任"用戶CA"的公鑰,(方法二,全域系統級)
    在sshd服務器上,在 /etc/ssh/sshd_config 中加入一行:
    TrustedUserCAKeys /etc/ssh/user_ca_list.pub ,
    重啟 sshd 服務生效, service sshd restart
    這種配置,用戶證書必須有principals,且包含用戶名才能登錄,
    user_ca_list.pub 可以多行,CA公鑰檔案user_ca.pub的內容占其中一行,檔案權限mode可以是0600或0644,
    例如: ssh-ed25519 AAAAC.....xx Comment

    • 靜態限制 principals
      在sshd服務器上,創建 principals 目錄 mkdir /etc/ssh/principals,此目錄權限mode要求是0755,
      然后在 /etc/ssh/sshd_config 中再加入一行,重啟 sshd 服務,
      AuthorizedPrincipalsFile /etc/ssh/principals/%u
      之后再次修改 user_ca_list.pub/etc/ssh/principals/ 中的檔案,無需重啟sshd即生效,

      • AuthorizedPrincipalsFile,只能配置一個路徑,不支持多個路徑,
      • 根據不同的用戶名, 限制 principals, 比如 /etc/ssh/principals/root 檔案:
        一行一個 principal,檔案權限mode必須是0644,
        ## 注釋:/etc/ssh/principals/root檔案內容
        principl_01
        principl_02
        
      • 用戶證書包含任意一個 principal 才能登錄,這種情況不匹配用戶名,用戶證書的principals包含"用戶名"無用,
      • 如果對應用戶的檔案不存在或為空,用戶證書無論包含什么princpals,或者無principal,都不能登錄,
    • 動態限制 principals
      在sshd服務器上, /etc/ssh/sshd_config 中再加入兩行:
      AuthorizedPrincipalsCommand /etc/ssh/princ.sh %u %U %s %i ,
      AuthorizedPrincipalsCommandUser root , (或指定一個別的用戶身份)
      重啟 sshd 服務生效, service sshd restart

      #!/bin/sh
      # 例子 /etc/ssh/princ.sh 檔案, 權限mode是 0755,owner,group 都是 root
      # 傳入四個引數 $1=username,$2=user ID, $3=證書的serial num, $4=證書的key ID
      # 例子中, $3 $4 沒有使用
      # 因 OpenSSH 權限提升漏洞 (CVE-2021-41617), 此程式只能由管理員撰寫,不應該開放給用戶修改,
      
      host=myhost02
      
      buf="$host-$1"
      buf2=$(echo "$buf" |/bin/shasum -)
      buf2=${buf2%% *-}
      echo "$buf2"
      if [ "$2" -eq 0 ]; then
         echo "$host-root"
         echo "allhost-root"
      else
         echo "$buf"
         echo "allhost-user"
      fi
      
    • AuthorizedPrincipalsCommandUser abc 指定程式以 abc 用戶身份執行,
      可以接受 "%u" 表示以登錄的身份執行, 但不建議,

    • 另一個例子,也可以通過webserver查詢principals,
      AuthorizedPrincipalsCommand /bin/curl -s http://localhost/sshprincipals?user=%u&serial=%s&id=%i

    • 任何用戶登錄,使用的用戶證書,簽名的CATrustedUserCAKeys串列中,
      sshd 都會先檢查 AuthorizedPrincipalsFile 中的 principals,
      如果找不到,才會執行 AuthorizedPrincipalsCommand 程式,
      如果程式的輸出中,也沒有找到匹配的 principals,則認證失敗,

    • 任何用戶登錄,使用的用戶證書,簽名的CA不在TrustedUserCAKeys串列中,
      sshd不使用AuthorizedPrincipalsFile,AuthorizedPrincipalsCommand中的principals,

    • 用戶證書的簽名CA通過TrustedUserCAKeys認證的,都必須有principals,
      無principals的用戶證書,不能登錄,即使sshd服務端的principals為空,也不能登錄,

    • AuthorizedPrincipalsFileAuthorizedPrincipalsCommand配置時,
      這種情況不匹配用戶名,用戶證書的principals包含"用戶名"無用,

  • 只要是用這個密鑰(用戶CA)簽名過的用戶公鑰,滿足 principals 要求,就能登錄此sshd服務器的相應用戶,

  • 創建用戶密鑰,用戶自己創建,私鑰不傳遞,
    ssh-keygen -t ed25519 -C user@myhost -f users_key
    得到兩個檔案,users_key , users_key.pub

  • 用 user_ca (私鑰)對用戶密鑰的公鑰簽名,得到一個用戶證書,
    只把用戶公鑰發給管理員簽名即可,只須要有"users_key.pub"公鑰檔案,無需用戶的私鑰檔案,
    ssh-keygen -s user_ca -I ident -n user1,principal_02 -V -10m:+90d users_key.pub
    得到一個檔案 users_key-cert.pub,發回給用戶,
    -n user1,principal_02 限制證書的用戶名 或principals,不限制就去掉這個引數,
    -V -1m:+10d 限制證書的時效,不限制就去掉這個引數,
    -O source-address=192.168.123.0/24,10.1.2.3 限制來源IP,
    -O force-command="date" 強制只執行某個命令,

  • 查看已經簽名的用戶證書的內容,
    ssh-keygen -L -f users_key-cert.pub

  • 在ssh客戶端上,
    把兩個檔案放在一起 users_key , users_key-cert.pub,這個檔案沒用 users_key.pub
    用命令 ssh user1@sshd服務器 -i users_key 就能夠登錄了,

  • 創建或更新 KRL 檔案,然后把 KRL 檔案傳到sshd服務器上,或者直接在sshd服務器上創建或更新,
    創建 revoke 檔案,并把證書加入: ssh-keygen -k -f KRL_file key-cert.pub
    更新 revoke 檔案,并把公鑰加入: ssh-keygen -ku -f KRL_file key.pub
    更新 revoke 檔案,并把CA公鑰加入: ssh-keygen -ku -f KRL_file user_ca.pub
    不僅能吊銷ca簽名證書,也可以吊銷普通密鑰的公鑰,

  • 列出 KRL 檔案內容: ssh-keygen -Ql -f KRL_file
    測驗 key-cert.pub 是否被 revoked : ssh-keygen -Q -f KRL_file key-cert.pub

  • KRL 檔案也可以是純文本的,不用 ssh-keygen 生成,格式同/etc/ssh/user_ca_list.pub,一行一個公鑰,
    例如: ssh-ed25519 AAAAC.....xx Comment
    可以是CA公鑰 user_ca.pub,也可以是普通密鑰的公鑰,也可以是用戶證書users_key-cert.pub的內容,

  • 讓sshd服務器檢查 KRL 檔案,(KRL檔案,純文本或者二進制格式,都支持)
    在sshd服務器上, /etc/ssh/sshd_config 中加入一行 RevokedKeys /path_to/KRL_file ,
    重啟 sshd 服務生效, service sshd restart
    /path_to/KRL_file 檔案的權限mode可以是 0600 或 0644,
    之后再次修改 KRL 檔案,無需重啟sshd,

  • sshd服務器會最先檢查 KRL 檔案,
    即,會吊銷在 TrustedUserCAKeys,AuthorizedKeysFile,AuthorizedKeysCommand中的公鑰,

  • 區別:

    • 用戶證書認證, 可以限制登錄用戶名 或principals, 可以設定有效期, 可以限制來源IP,
    • 密鑰認證, 無這些功能,

公鑰的動態認證

  • 在sshd服務器上, /etc/ssh/sshd_config 中加入兩行:
    AuthorizedKeysCommandUser /etc/ssh/keys.sh %u %U
    AuthorizedKeysCommandUser root , (或指定一個別的用戶身份)
    重啟 sshd 服務生效, service sshd restart
    #!/bin/sh
    # 例子 /etc/ssh/keys.sh 檔案, 權限mode是 0755,owner,group 都是 root
    # 傳入兩個引數 $1=username,$2=user ID
    # 例子中, $1 $2 沒有使用
    # 因 OpenSSH 權限提升漏洞 (CVE-2021-41617), 此程式只能由管理員撰寫,不應該開放給用戶修改,
    echo "ssh-ed25519 AAAAC.....xx Comment"   # 普通密鑰的公鑰
    echo "cert-authority ssh-ed25519 AAAAC.....xx Comment"   # CA的公鑰,無principals限制
    # CA的公鑰, 有principals限制
    echo 'cert-authority,principals="host02,allhost" ssh-ed25519 AAAAC.....xx Comment'
    
  • AuthorizedKeysCommandUser abc 指定程式以 abc 用戶身份執行,
    可以接受 "%u" 表示以登錄的身份執行, 但不建議,
  • 任何用戶登錄,sshd 都會先檢查 AuthorizedKeysFile 中的公鑰,
    如果找不到,才會執行 AuthorizedKeysCommand 程式,
    如果程式的輸出中,也沒有找到匹配的公鑰,則繼續其他認證,如TrustedUserCAKeys
  • 任何用戶登錄,使用的用戶證書,簽名的CAAuthorizedKeysFileAuthorizedKeysCommand中找到,
    是否有principals限制看匹配行的principals=""
    AuthorizedPrincipalsFile,AuthorizedPrincipalsCommandcert-authority...匹配行中,
    • 如果無principals= 則用戶證書無principals可以登錄,或者用戶證書有principals,且包含用戶名 才能登錄,
    • 如果有principals="xx02,xx03" 則用戶證書有principals,且包含任意一個principal 才能登錄,

ssh登錄程序中,基于簽名(證書)的服務器認證

  • 基于 openSSH-8.0p1 , 測驗成功,
  • 創建 用于簽發服務器證書的密鑰(服務器CA),管理員創建,私鑰不傳遞,
    ssh-keygen -t ed25519 -C server_ca@myCA -f server_ca
    得到兩個檔案,server_ca , server_ca.pub
    只是密鑰對,不是證書,因為沒做自簽名證書,
  • 讓ssh客戶端信任"服務器CA"的公鑰,(用戶級)
    在ssh客戶端上, 用戶的 ~/.ssh/known_hosts 中加入一行(服務器CA的公鑰),此檔案權限mode通常是0644,
    @cert-authority * ssh-ed25519 AAAAC.....xx server_ca@myCA
    內容為 server_ca.pub 檔案的內容,
  • 讓ssh客戶端信任"服務器CA"的公鑰,(全域)
    在ssh客戶端上,/etc/ssh/ssh_known_hosts 中加入一行(服務器CA的公鑰),此檔案權限mode是0644,
    @cert-authority * ssh-ed25519 AAAAC.....xx server_ca@myCA
    內容為 server_ca.pub 檔案的內容,
  • 只要是這個密鑰(服務器CA)簽名過的服務器公鑰,配置到sshd服務器之后,ssh連接服務器時,就不會有連接警告,
  • 用 server_ca (私鑰)對服務器的公鑰簽名,得到服務器證書,
    直接在sshd服務器上簽名,或者把服務器的三個公鑰發給管理員簽名,
    對于openSSH-8,是這三個ssh_host_ecdsa_key.pub,ssh_host_ed25519_key.pub,ssh_host_rsa_key.pub
    比如,簽其中一個: ssh-keygen -s server_ca -I ident -h /etc/ssh/ssh_host_ed25519_key.pub
    得到一個檔案 ssh_host_ed25519_key-cert.pub
    別忘了 -h 引數,漏了就無效了,
    可以帶上 -V -1m:forever -n "*.myhost.cn,*.xxx.com"
    -n abc.mydomain.com 限制證書的域名,IP,不限制就去掉這個引數,
    -V -1m:+3d 限制證書的時效,不限制就去掉這個引數,
    可以對多個不同型別的公鑰簽名,得到不同型別的服務器證書,
    sshd服務器原本使用的密鑰,不滿意,可以在sshd服務器上重新生成一遍,保證服務器私鑰不傳遞,見下面【更新sshd服務端的通訊密鑰/證書】部分,
  • 查看已經簽名的服務器證書的內容,
    ssh-keygen -L -f ssh_host_ed25519_key-cert.pub
  • 在sshd服務器上,修改 /etc/ssh/sshd_config 加三行,
    HostCertificate /etc/ssh/ssh_host_ecdsa_key-cert.pub
    HostCertificate /etc/ssh/ssh_host_ed25519_key-cert.pub
    HostCertificate /etc/ssh/ssh_host_rsa_key-cert.pub
    如果只簽一個型別的服務器證書,HostCertificate /etc/ssh/.... 就只寫一行吧,
    重啟 sshd,執行 /sbin/service sshd reload
  • 在ssh客戶端上,用命令 ssh user1@sshd服務器 就沒有連接警告了,
  • 讓ssh客戶端 revoked 服務器的公鑰,(用戶級)
    在ssh客戶端上,用戶的 ~/.ssh/known_hosts 中加入一行的公鑰,
    @revoked * ssh-ed25519 AAAAC.....xx server_ca@myCA
    內容可以是CA公鑰 server_ca.pub,也可以是普通服務器的公鑰,也可以是服務器證書ssh_host_ed25519_key-cert.pub的內容,
  • 讓ssh客戶端 revoked 服務器的公鑰,(全域)
    在ssh客戶端上,/etc/ssh/ssh_config 中加入 RevokedHostKeys /path_to/KRL_file
    /path_to/KRL_file檔案權限mode是0644,
    KRL檔案格式,可以是純文本,一行一個公鑰,也可以是由ssh-keygen生成的二進制格式,
    ssh-keygen 創建 KRL 檔案,見前面【基于簽名(證書)的用戶認證】部分,
  • 讓ssh客戶端 revoked 服務器的公鑰,(全域)
    在ssh客戶端上,/etc/ssh/ssh_known_hosts 中加入一行,也可以,此檔案權限mode是0644,
    @revoked * ssh-ed25519 AAAAC.....xx server_ca@myCA

更新 sshd 服務端的通訊密鑰/證書,保證服務器安全

  • 目前的 OpenSSH-8 需要三套密鑰,一共六個檔案,
    cd /etc/ssh/
    ssh-keygen -l -f ssh_host_rsa_key  #看一下,原來密鑰的注釋是什么,然后決定下面的 -C 引數寫什么
    
    ssh-keygen -t ecdsa -b 384 -C root@你的機器名 -f ssh_host_ecdsa_key
    ssh-keygen -t ed25519 -C root@你的機器名 -f ssh_host_ed25519_key
    ssh-keygen -t rsa -b 4096 -C root@你的機器名 -f ssh_host_rsa_key
    service sshd restart   #重啟sshd服務
    
  • 其中,
    ecdsa默認是256bit,可以用 -b 指定,
    ed25519固定是256bit,不能改,
    rsa默認已經從2048改為3072bit了,可以用 -b 指定,
  • 還有個簡單的辦法,
    洗掉所有的服務器密鑰 rm /etc/ssh/ssh_host_* , 重新用默認值生成一遍 ssh-keygen -A
    重啟sshd服務 service sshd restart
  • 參考【更換ssh通信證書,ssh更改公鑰和密鑰,以保證服務器安全】
    【更換ssh通信證書,ssh更改公鑰和密鑰,以保證服務器安全】

---end---


轉載注明來源: 本文鏈接 https://www.cnblogs.com/osnosn/p/16870594.html 來自osnosn的博客.

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

標籤:Linux

上一篇:PandasDataframe:將單列拆分為多列

下一篇:第四章 linux字符設備驅動一

標籤雲
其他(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