主頁 > 作業系統 > Linux學習筆記

Linux學習筆記

2021-09-14 06:45:59 作業系統

作者:Grey

原文地址:Linux學習筆記

檔案系統

image

除了/boot的資料,其他目錄下的資料都存在了sda3里面了
/var 可變化的檔案,比如:日志檔案,資料檔案
更多檔案型別說明見:

image

## 級聯創建目錄
mkdir -p a/adir/bdir

mkdir a/adir a/bdir a/cdir
mkdir a/{1,2,3}dir


## 復制檔案夾
## 將a檔案夾復制到cpp檔案夾中,復制檔案夾用
cp -r a cpp/ 

stat和touch 組合使用,可以增量監控資料改變的時間 linux命令系列 stat & touch
?

掛載/卸載
/boot目錄的加載和卸載
在/下:

umount /dev/sda1
mount /dev/sda1 /boot

掛載實驗

演示塊設備

# 生成100m的空img檔案
# dd命令可以用于硬碟的互相拷貝
dd if=/dev/zero of=mydisk.img bs=1048576 count=100

losetup /dev/loop0 mydisk.img 
mke2fs /dev/loop0

mkdir /mnt/myos
mount -t ext2 /dev/loop0 /mnt/myos

# 搜索一下bash的位置 whereis bash
mkdir /mnt/myos/bin
cd /mnt/myos
cp /bin/bash /bin

cd /mnt/myos/bin

# 查看bash需要的依賴
ldd bash
#	linux-vdso.so.1 (0x00007ffe0413d000)
#	libtinfo.so.6 => /lib64/libtinfo.so.6 (0x00007fa608cb0000)
#	libdl.so.2 => /lib64/libdl.so.2 (0x00007fa608aac000)
#	libc.so.6 => /lib64/libc.so.6 (0x00007fa6086e9000)
#	/lib64/ld-linux-x86-64.so.2 (0x00007fa6091fb000)



cd /mnt/myos
mkdir lib64
cp /lib64/{libtinfo.so.6,libdl.so.2,libc.so.6,ld-linux-x86-64.so.2}   ./lib64/

chroot ./
echo "d" > /abc.txt

檔案描述符實驗

https://blog.csdn.net/qq_31186123/article/details/82190776

# 創建一個檔案,寫入一些內容
vi abc.txt

# 寫入如下內容:
dfasdfasdfasdfa1
asdfasdfasd2
sadfasdfasd3

# 將abc.txt讀入fd4
exec 4< abc.txt

# 查看當前行程所有檔案描述符
[root@sec fd]# ll /proc/$$/fd
....
lr-x------. 1 root root 64 May 18 10:11 4 -> /root/abc.txt


[root@sec fd]# lsof -p $$
COMMAND  PID USER   FD   TYPE DEVICE  SIZE/OFF     NODE NAME
....
bash    1719 root    4r   REG  253,0        43 33576569 /root/abc.txt
....


# 將abc.txt第一行讀出來
[root@sec fd]# read a 0<& 4
[root@sec fd]# echo $a
dfasdfasdfasdfa1

檔案偏移量實驗

每個行程的偏移量互不影響,每個fd會單獨維護一個seek(指標)

# 查看檔案偏移量
# 一開始偏移量:0t17
[root@sec fd]# lsof -op $$
COMMAND  PID USER   FD   TYPE DEVICE OFFSET     NODE NAME
....
bash    1719 root    4r   REG  253,0   0t17 33576569 /root/abc.txt
....

# 重新打開一個
# 偏移量0t0
[root@sec fd]# exec 4< /root/abc.txt 
[root@sec fd]# lsof -op $$
COMMAND  PID USER   FD   TYPE DEVICE OFFSET     NODE NAME
....
bash    1719 root    4r   REG  253,0    0t0 33576572 /root/abc.txt
....


模擬socket實驗

[root@sec fd]# echo $$
1719
[root@sec fd]# cd /proc/1719/fd
[root@sec fd]# exec 8<> /dev/tcp/www.baidu.com/80
[root@sec fd]# ll
total 0
....
lrwx------. 1 root root 64 May 18 10:11 8 -> 'socket:[32794]'

[root@sec fd]# lsof -op $$
COMMAND  PID USER   FD   TYPE DEVICE OFFSET     NODE NAME
....
bash    1719 root    8u  IPv4  32794    0t0      TCP sec:55974->183.232.231.174:http (ESTABLISHED)
....

重定向運算子

[root@sec ~]# ls ./
abc.txt  anaconda-ks.cfg
[root@sec ~]# ls ./ 1> ~/ls.out
[root@sec ~]# ll
total 12
-rw-r--r--. 1 root root   80 May 18 10:18 abc.txt
-rw-------. 1 root root 1060 Apr 20 17:15 anaconda-ks.cfg
-rw-r--r--. 1 root root   31 May 18 10:34 ls.out
[root@sec ~]# cat ls.out 
abc.txt
anaconda-ks.cfg
ls.out

[root@sec ~]# cat 0< ls.out 1>cat.out
[root@sec ~]# cat cat.out 
abc.txt
anaconda-ks.cfg
ls.out

# 覆寫操作
[root@sec ~]# read a
fasdfasdfasdfas
[root@sec ~]# echo $a
fasdfasdfasdfas
[root@sec ~]# read a 0< cat.out
[root@sec ~]# echo $a
abc.txt


標準輸入輸出,錯誤輸出

# 由于asdfasdfasdf目錄不存在,所以執行ls會報錯
[root@sec ~]# ls ./ /asdfasdfasdf 1>ls01.out
ls: cannot access '/asdfasdfasdf': No such file or directory
[root@sec ~]# cat ls01.out 
./:
abc.txt
anaconda-ks.cfg
cat.out
ls01.out
ls.out


# 如果要保存錯誤資訊
[root@sec ~]# ls ./ /asdfasdfasdf 1>ls01.out 2>ls03.out
[root@sec ~]# cat ls03.out 
ls: cannot access '/asdfasdfasdf': No such file or directory

# 或者這樣
[root@sec ~]# ls ./ /asdfasdfasdf 1> ls04.out 2>& 1
[root@sec ~]# cat ls04.out 
ls: cannot access '/asdfasdfasdf': No such file or directory
./:
a
abc.txt
anaconda-ks.cfg
cat.out
ls01.out
ls02.out
ls03.out
ls04.out
ls.out

管道

# 查詢第五行[root@sec ~]# head -5 abc.txt | tail -1d123

父子行程

[root@sec ~]# echo $$1719[root@sec ~]# /bin/bash[root@sec ~]# echo $$1824# pstree,安裝:yum install psmisc -y [root@sec ~]# pstreesystemd─┬─NetworkManager───2*[{NetworkManager}]        ├─auditd───{auditd}        ├─crond        ├─dbus-daemon───{dbus-daemon}        ├─firewalld───{firewalld}        ├─login───bash        ├─polkitd───5*[{polkitd}]        ├─rngd───{rngd}        ├─sshd───sshd───sshd───bash───bash───pstree        ├─sssd─┬─sssd_be        │      └─sssd_nss        ├─systemd───(sd-pam)        ├─systemd-journal        ├─systemd-logind        ├─systemd-udevd        └─tuned───3*[{tuned}]        # 父子行程的資料是無法互相訪問的[root@sec ~]# x=100[root@sec ~]# echo $x100[root@sec ~]# exitexit[root@sec ~]# echo $x[root@sec ~]# a=1[root@sec ~]# echo $a1[root@sec ~]# { a=9 ; echo "dassdf"; } | catdassdf[root@sec ~]# echo $a1# $$ 和 $BASHPID 優先級 , $$ 優先級高, $BASHPID 優先級低[root@sec ~]# echo $$2163[root@sec ~]# echo $$ | cat2163[root@sec ~]# echo $BASHPID | cat2191# 如果父子行程資料互相訪問,需要用export[root@sec ~]# a=10[root@sec ~]# export a[root@sec ~]# /bin/bash[root@sec ~]# echo $a10

永久關閉SELinux的方法

vim /etc/selinux/config

把SELinux設定為disabled

image.png

配置ssh密鑰連接Linux

首先Win10系統上需要有OpenSSH,像這樣:終端輸入ssh

這樣就是有的(好像Win10 1809+默認就是有的),
然后生成密鑰對:
ssh-keygen -t rsa
接著按提示資訊可根據個人需求選擇,這里是默認(連續三個回車即可),
生成的密鑰對默認保存在當前用戶的根目錄下的.ssh目錄中(C:\Users\username.ssh):

接著我們將公鑰id_rsa.pub上傳至Linux服務器(保存到你要連接的用戶根目錄下~/.ssh/中,沒有.ssh目錄則創建):
修改/etc/ssh/sshd_config配制檔案,修改以下內容
RSAAuthentication yes
PubkeyAuthentication yes
PasswordAuthentication no

上傳好后,將Linux中的id_rsa.pub重命名為authorized_keys,更改檔案權限為600,更改.ssh目錄權限為700:
mv id_rsa.pub authorized_keys
chmod 600 authorized_keys
chmod 700 .ssh

然后就可以通過ssh方式連接到Linux

Linux的命令

分為內部命令和外部命令 內部命令(Shell自帶的命令)

image.png

外部命令(不是Shell自帶的命令,由用戶安裝的)

image.png

查看命令是一個什么型別的檔案

image.png

查看ifconfig命令在哪個位置

whereis ifconfig

什么是Shell? bash shell,就是一個程式,就是Linux系統安裝的一個軟體

root/密碼寫對后,直接進入bash shell軟體

image.png

image.png

echo $PATH

image.png

內部命令的幫助用help指令,外部命令的幫助用man指令

echo $$: 當前bash shell的行程號

如果平時退出不了某個程式,可以復制一個ssh對話,用ps -ef找到那個行程,用kill -9 退出即可

bash shell在執行命令的時候,做了兩步優化:

  1. 通過PATH來
  2. 通過hash來,hash查看,hash -r(清空hash)

Shell

撰寫腳本時候要賦予該檔案執行權限chmod u+rx filename

如果bash執行,不需要賦予執行權限

bash ./filename.sh
./filename.sh
以上兩種執行方式都是新開一個行程

source ./filename.sh
.filename.sh
這種方式執行不會產生新的子行程

#!/bin/bash/cd /tmppwd

輸入重定向符號 <

read var < /path/to/a/file

輸出重定向 >   >> 2> &>

echo 123 > /path/to/a/file  清空輸入
echo 123 >> /path/to/a/file 追加
echo 12343 2> /path/to/a/file 錯誤輸入
echo 122 &> /path/to/a/file 全部輸入

#!/bin/bashcat > /data/m.sh << EOFecho "hello bash"EOF

變數賦值

  • a=123
  • let a=10+2
  • l=ls
  • letc=$(ls -l /etc) 或 letc=ls -l /etc
  • 變數值有空格等特殊字符可以包括在"" 或 ``中
  • echo ${變數名} 查看變數的值

變數的默認作用范圍
默認自己的shell行程中

變數的匯出,讓子行程獲得父行程的變數值

  • export 變數名
    變數的洗掉
  • unset 變數名

環境變數:每個Shell打開都可以獲得的變數

  • set和env命令

  • $? 上一條命令是否正確執行(正確:0, 錯誤:1)

  • $PATH

  • $PS1

位置變數

  • $1 $2 ... $n
#!/bin/bash# $1 $2 ...$9 ${10}echo $1# 默認列印第二個引數值,如果為空則顯示_echo ${2-_}

環境變陣列態檔所在目錄

  • /etc/profile
  • /etc/profile.d/
  • ~/.bash_profile
  • ~/.bashrc
  • /etc/bashrc

說明:/etc/下的組態檔,表示所有用戶通用的配置,用戶家目錄的組態檔只能特定用戶使用,
su - 用戶名  login shell 所有都可以執行
su 用戶名 nologin shell  /bashrc, /etc/bashrc

所用終端都應用新的環境變數: export PATH=$PATH:/new/to/path
讓環境變數立即生效:source /etc/profile

定義陣列

# 陣列定義IPTS=(10.0 1.0 3.0)# 顯示陣列中所有元素echo ${IPTS[@]}#顯示陣列元素個數echo ${#IPTS[@]}顯示陣列的第一個元素echo ${IPTS[0]}

Q:

  • 內建命令不需要創建子行程
  • 內建命令對當前shell有效

stat && touch命令

https://www.cnblogs.com/z-joshua/p/10042681.html

命令積累

與時間服務器上的時間同步

  1. 安裝ntpdate工具
yum -y install ntp ntpdate
  1. 設定時間為阿里服務器的時間
ntpdate ntp1.aliyun.com
  1. 將系統時間寫入硬體時間
hwclock –systohc

一屏可以顯示的檔案,可以用cat 一屏顯示不出來的內容,用more命令,space翻頁,無法回看 使用less 命令就可以往后推(space),按b鍵往前翻(less是將檔案一次性load記憶體,所以檔案大的時候只能用more)

head -n 檔案名 前n行的資料 tail -n 檔案名 后n行資料 tail -f 檔案名 監控檔案內容改變

管道命令 cat xxx | head -3 cat xxx作為輸出流的形式作為后面命令的輸入流

ls -l 無法接受前面的輸出流的內容,如果要解決,需要這樣用: echo "/" | xargs ls -l

head -5 xxx | tail -1 獲取第五行的資料

screen -S yourname ## 新建一個叫yourname的session
screen -ls         ## 列出當前所有的session
screen -r yourname ## 回到yourname這個session
screen -d yourname ## 遠程detach某個session
screen -d -r yourname ## 結束當前session并回到yourname這個session

硬連接
ln /data/x.txt /data/b.txt
stat x.txt
stat b.txt
Innode號一致
修改任何一個,另外一個都可以同步修改
刪掉任何一個,不會影響另外那個

軟連接
ln -s /data/x.txt /data/b.txt
Innode號不一致
刪掉x.txt個,b.txt的鏈接會丟失

拒絕用戶登錄

Linux用戶管理之使用/bin/false和/usr/sbin/nologin拒絕用戶登錄及其功能分析(轉)

參考資料

Linux命令列大全

Linux就該這么學

Linux預習資料 提取碼:7w30

CentOS6.x升級到CentOS7.x的注意事項視頻 提取碼: yhfd

Linux內核設計與實作

極客時間-Linux實戰技能100講

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

標籤:其他

上一篇:k8s 常用命令

下一篇:Linux 配置Java環境變數

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