Linux 神奇命令大合集:掌控操作系統(tǒng),成為技術(shù)達(dá)人!
1 firewall-cmd
?# 開啟防火墻 ? systemctl start firewalld.service ?? ?# 防火墻開機(jī)啟動 ? systemctl enable firewalld.service ?? ?# 關(guān)閉防火墻 ? systemctl stop firewalld.service ?? ?# 查看防火墻狀態(tài) ? firewall-cmd --state ?? ?#查看區(qū)域信息 ?? ?firewall-cmd--get-active-zones ?? ?#查看指定接口所屬區(qū)域 ?? ?firewall-cmd--get-zone-of-interface=eth0 ?? ?# 查看現(xiàn)有的規(guī)則 ?? ?firewall-cmd --list-all ? 或 ? iptables -nL ?? ?# 重載防火墻配置 ? firewall-cmd --reload ?? ?# 添加單個單端口 ? firewall-cmd --permanent --zone=public --add-port=81/tcp ?? ?# 添加多個端口 ? firewall-cmd --permanent --zone=public --add-port=8080-8083/tcp ?? ?# 刪除某個端口 ? firewall-cmd --permanent --zone=public --remove-port=81/tcp ?? ?# 針對某個 IP開放端口 ? firewall-cmd --permanent --add-rich-rule="rule family="ipv4" source address="192.168.142.166" port protocol="tcp" port="6379" accept" ? firewall-cmd --permanent --add-rich-rule="rule family="ipv4" source address="192.168.0.233" accept" ?? ?# 刪除某個IP ? firewall-cmd --permanent --remove-rich-rule="rule family="ipv4" source address="192.168.1.51" accept" ?? ?# 針對一個ip段訪問 ? firewall-cmd --permanent --add-rich-rule="rule family="ipv4" source address="192.168.0.0/16" accept" ? firewall-cmd --permanent --add-rich-rule="rule family="ipv4" source address="192.168.1.0/24" port protocol="tcp" port="9200" accept" ? ?# 開放服務(wù) 如samba ?firewall-cmd --permanent --add-service=samba ?firewall-cmd --reload 2 iptables
?# 添加開放3306端口 ?sudo iptables -A INPUT -p tcp -s 0.0.0.0 --dport 3306 -j ACCEPT ?? ?# 保存 ?sudo iptables-save ?? ?# 查看iptables 規(guī)則 通過 iptables -L -n --line-number 可以顯示規(guī)則和相對應(yīng)的編號 ?sudo iptables -L -n ?? ?? 3 screen
?## 語法 ?? ?# screen [-AmRvx -ls -wipe][-d <作業(yè)名稱>][-h <行數(shù)>][-r <作業(yè)名稱>][-s ][-S <作業(yè)名稱>] ?? ?## 參數(shù)說明 ?-A 將所有的視窗都調(diào)整為目前終端機(jī)的大小。 ?-d <作業(yè)名稱> 將指定的screen作業(yè)離線。 ?-h <行數(shù)> 指定視窗的緩沖區(qū)行數(shù)。 ?-m 即使目前已在作業(yè)中的screen作業(yè),仍強(qiáng)制建立新的screen作業(yè)。 ?-r <作業(yè)名稱> 恢復(fù)離線的screen作業(yè)。 ?-R 先試圖恢復(fù)離線的作業(yè)。若找不到離線的作業(yè),即建立新的screen作業(yè)。 ?-s 指定建立新視窗時(shí),所要執(zhí)行的shell。 ?-S <作業(yè)名稱> 指定screen作業(yè)的名稱。 ?-v 顯示版本信息。 ?-x 恢復(fù)之前離線的screen作業(yè)。 ?-ls或--list 顯示目前所有的screen作業(yè)。 ?-wipe 檢查目前所有的screen作業(yè),并刪除已經(jīng)無法使用的screen作業(yè)。 ?? ?## 常用screen參數(shù) ?screen -S yourname -> 新建一個叫yourname的session ?screen -ls -> 列出當(dāng)前所有的session ?screen -r yourname -> 回到y(tǒng)ourname這個session ?screen -d yourname -> 遠(yuǎn)程detach某個session ?screen -d -r yourname -> 結(jié)束當(dāng)前session并回到y(tǒng)ourname這個session ?? ?在每個screen session 下,所有命令都以 ctrl+a(C-a) 開始。 ?C-a ? -> 顯示所有鍵綁定信息 ?C-a c -> 創(chuàng)建一個新的運(yùn)行shell的窗口并切換到該窗口 ?C-a n -> Next,切換到下一個 window ?C-a p -> Previous,切換到前一個 window ?C-a 0..9 -> 切換到第 0..9 個 window ?Ctrl+a [Space] -> 由視窗0循序切換到視窗9 ?C-a C-a -> 在兩個最近使用的 window 間切換 ?C-a x -> 鎖住當(dāng)前的 window,需用用戶密碼解鎖 ?C-a d -> detach,暫時(shí)離開當(dāng)前session,將目前的 screen session (可能含有多個 windows) 丟到后臺執(zhí)行,并會回到還沒進(jìn) screen 時(shí)的狀態(tài),此時(shí)在 screen session 里,每個 window 內(nèi)運(yùn)行的 process (無論是前臺/后臺)都在繼續(xù)執(zhí)行,即使 logout 也不影響。 ?C-a z -> 把當(dāng)前session放到后臺執(zhí)行,用 shell 的 fg 命令則可回去。 ?C-a w -> 顯示所有窗口列表 ?C-a t -> Time,顯示當(dāng)前時(shí)間,和系統(tǒng)的 load ?C-a k -> kill window,強(qiáng)行關(guān)閉當(dāng)前的 window ?C-a [ -> 進(jìn)入 copy mode,在 copy mode 下可以回滾、搜索、復(fù)制就像用使用 vi 一樣 ??C-b Backward,PageUp ??C-f Forward,PageDown ??H(大寫) High,將光標(biāo)移至左上角 ??L Low,將光標(biāo)移至左下角 ???0 移到行首 ???$ 行末 ??w forward one word,以字為單位往前移 ??b backward one word,以字為單位往后移 ??Space 第一次按為標(biāo)記區(qū)起點(diǎn),第二次按為終點(diǎn) ??Esc 結(jié)束 copy mode ?C-a ] -> Paste,把剛剛在 copy mode 選定的內(nèi)容貼上 ?? ?# 常用場景 ?# 在指定的session下運(yùn)行springboot應(yīng)用 ?1、screen -S myapp #新建一個叫myapp 的session ?2、screen -r myapp #切換到 myapp session ?3、java -jar myapp,jar #運(yùn)行jar ?4、按 Ctrl a d 組合鍵退出當(dāng)前session ?5、下次需要進(jìn)入時(shí) 輸入 screen -r myapp?或 screen -D -r myapp ?? ?# 強(qiáng)制刪除一個session ?screen -X -S ${想要刪除的session} quit ?? ??