linux_day02

1、链接:LN

一个点表示当前工作目录,两个点表示上一层工作目录;

目录的本质:文件(该文件储存目录项,以链表的形式链接,每个结点都是目录项,创建文件相当于把目录项添加到链表中)

如果想在一个目录中添加或者删除目录项,需要获取这个目录的写权限;

软连接:符号链接,单独的文件里面存储了文件路径,类似于指针,指向目录;

硬链接:文件以链表形式存于物理文件系统,虚拟文件系统(VFS)与物理文件系统存在一种映射,上图he目录和点目录指向同一个文件,这种映射情形叫硬链接;

创建硬链接:

dir目录下创建三个子文件夹,dir目录下有五个硬链接:如果创建文件硬链接为1;

创建a.txt和link_hard的硬链接:在dir下面创建了一个路径,这个路径名叫link-hard,都指向同一个文件a.txt;

link_hard和a.txt的路径都一样,都是523423;所以指向同一个文件

创建软链接参数:-s

在dir目录下的dir1创建符号链接,存储了b.txt的相对路径;

回到上级目录dir,利用echo(输出流命令,可以输出stdout打印指定字符)利用 > 符号重定向输出,输出到b.txt,cd 到dir1,操作link_sym这个符号链接,操作的是它指向的文件;

运用绝对路径创建软链接二;

一般采用相对链接进行符号链接;

符号连接类似于window的快捷方式,c语言的指针;

硬链接不能跨分区链接,不能为文件夹创建硬链接;

查找文件:

locate

windows的everything查找插件原理:有自己的数据库,把文件系统中的文件进行分析创建索引存入数据库,如果要查找的文件未存于数据库中是查找不到的;

locate查找原理:有一个自己的数据库,通过分析文件系统,把索引存入数据库;

所有满足查找条件的都会打印出来;

新添加的文件未来得及添加到数据库,所以·查找不到

which:查找可执行程序

command(可执行程序)

tree:以树状格式列出目录内容

find:在目录的层次结构中搜索(包含子目录)

find 起始目录 查找条件 操作

-name:根据名字查找

find 后添加根目录 / ,在整个文件系统中查找

find / -name "stdio.h"

在linux-5.16.12(内核版本),src目录下存放linux内核源代码;linux内核用c实现

在内核中查找所有 .c 结尾的文件

find 可以组合多个查找条件:

-a :and ;

-o:or ;

!:逻辑取反;

查找改内核的所有 .c 文件和 按名字查找.h 文件:

根据类型查找:-type c代表文件类型

f(常规文件):find . -type f (根据类型查找)

l (链接文件查找):find . -type l

在本目录下查找名包含soft 而且是软链接的文件(find 命令可以多种组合查找)

根据用户组ID进行查找:

-user:用户

-group:组

-uid:用户id

-gid:组id

添加用户 test //创建家目录,用bash这个shell(命令行解释器)

根据test 查找,在家目录下

根据大小进行查找:rouding up(近视规则:如果文件有1.1kb,对应的是2kb,向上取整)

(b)block:块(512字节为一块)

(c)character:一个字符占一个字节(以字节为单位)

-size 默认以b为参数;

find ~ -size 4096 :在家目录下查找大小为4096*512 字节大小的文件;默认为block,一块512byte

find ~ -size 4096c:以字节为单位,4096byte(加了参数表示精确查找)

超过5M的文件:

小于5M文件:

查找4k向上取整:

查找空文件或空目录:-empty

find . -size 0c (查找不到一些空目录)

-empty:空目录默认大小为4096byte,如果要查空目录应使用-empty;

根据权限查找:-perm

perm + mode 进行查找;

权限中rwx用三位二进制就可以表示,而三位二进制数可以用一位8进制数表示;

-rw- rw- r--:有权限记作1,无权限记作0

-110 110 100;

-6 6 4;

find . -perm 664

用户拥有执行权限,或用户只拥有执行权限,查手册具体用法;

命令的组合:

按顺序组合:命令依次执行

可以把一个命令的输出结果,以行为单位当作另一个命令的参数;

把find 的命令结果放入下一个命令的参数{ };

查找某些文件并且直到该文件详细信息:

管道 + xargs:

管道符 | (将前一个的输出stdout作为后一个命令的输入stdin,管道使用字符竖杠表示)

语法格式:命令1 | 命令2 | 命令 3

并不是所有的命令都支持管道符运算,

xargs 完成了两个行为:xargs 将标准输入作为命令行的参数

1、处理管道传输过来的stdin;

2、将处理后的数据传递到正确的位置;

不加xargs,管道符的左侧的命令输出格式与右侧的命令输入格式不匹配,

加了xargs,xargs会把管道符左侧的输出格式转化为右侧命令行所期望的输入格式;

权限:

当有时候没有权限的时候,不能使用一些对应的功能,所以需要用到更改权限;

上图所示,hello.py没有执行权限x,使用 chmod u+x hello.py后获得执行权限;

chmod:按位编码;

rwx rwx rwx

user group other

权限的设置:

文字设定法:

chmod [ugoa] [+ = -] [rwx] file/dir //a--all,

chmod u+x hello.py ///添加执行权限

chmod a+x aabbcc.txt /给所有用户添加对aabbcc.txt的写权限

chmod a-x aabbcc.txt ;给所有用户减少对aabbcc.txt的执行权限

chmod a=x aabbcc.txt ;所有的用户都只有执行权限

权限可以组合使用:

chmod u=rw,g=rw,o=r a.txt ;给user 读写权限,组读写权限,其他用户读权限;

数字设定法:

chmod 三位八进制数字 file/dir

第一位用户权限,第二位组权限,第三位其他人权限

chmod 664 hello.py ;;

文件掩码:umask

文件掩码关注后三位八进制数字,

普通用户的文件掩码:002

root用户的文件掩码:022

创建文件夹时默认的权限是777;最终生成文件夹的时候生成775;(对umask(002)取反再与默认权限777按位与最终生成775)

创建普通文件时,默认权限是666,对umask取反再将取反的结果与默认权限按位与最终生成权限

临时改变umask(文件掩码):umask 0···;退出用户,重启动后生效;

在bash.rc文件中修改umask,可以永久改变;

umask :222

创建文件夹:

创建普通文件:

查看文件内容:

cat:(拼接到流的末尾)把标准输入中的内容输出到标准输出

文件描述符(非负整数):可以用文件描述符表示输入输出;

stdin(标准输入) 键盘 0(文件描述符)

stdout(标准输出) 显示器 1(文件描述符)

stderr(标准错误输出) 显示器 2(文件描述符)

重定向 :

> 标准输出重定向

< 标准输入重定向

2> 标准错误重定向 (2表示标准错误输出)

>> 标准输出重定向(追加)

cat hello.py > a.txt 标准输出重定向到a.txt

cat把标准输入的内容读取到缓存中然后输出到标准输出流中;

cat > d.txt (ctrl + D)结束输入

创建了d.txt文件并输出了输入流内容

cat可以重定向标准输入,把输入流换成文件;

echo:

echo "hello world" e.txt

创建了e.txt 并重定向了字符串的流向

head:显示文件的头几行信息(默认前10行)

可以指定head的参数

head -n 5 a.txt (输出前5行)

tail :输出文件后几行 (默认显示后10行)

用-n 限制显示后5行

tail可以用来查看日志文件;

more :单页浏览

more file

只显示第一页,可以按f下翻,b上翻;

less:单页浏览

less file

f(forward):向前翻页

b (backward):往后翻页

q (quit):退出

其他操作:

排序:sort (以行为单位)

读取文件的内容,并且在内存中对文件的内容(行)进行排序,并把排序后的结果输出到stdout中;

uniq:去重(去除连续重复的,以行为单位)

只去除了不同行且相邻的重复项的一项:

读取文件的内容,并对连续的行去重,并把去重后的结果输出到stdout中;

如果想把所用行进行去重,可以先排序后去重;

也可以用xargs;

管道排序后去重,不加xargs是读取文件为参数,加了xargs就会把文件里的行作为参数,导致uniq找不到文件;

file:确认文件类型

WC:统计文件行,字节数等

行数,单词数,字节数(wc默认格式)

iconv:修改字符集,(修改编码格式)

-f:从哪个字符集开始(from)

-t:要转化的目标字符集

转化后需要重定向保存,不然会输出到输出流;

grep:搜索文件内容

G:globally;(全局)

re:regex--regular expression(正则表达式)

p:print;

-E:使用扩展版本的正则表达式规则(正则表达式有很多版本,添加-E增加兼容性)

-n:显示行号

-i :ignore 忽略正则表达式中的大小写;

grep -nE "txt" a (查找含txt的内容并显示其行号,双引号里是正则表达式)

"[ro]+" (ro至少出现一次)

".*" (点是匹配任意字符,*是重复任意次,会匹配所有的行)

正则表达式:

基本单位:普通字符,转义字符,. (用点代表任意字符),[ ] (集合), () (把小括号的整体当基本单位,)

基本操作:

连接:ab,

重复:?(问号表示重复0次或1次),+(加号表示重复一次或者多次),*(重复任意次数){m,n}(可以用{ }表示重复次数)

匹配以t开头以e结尾的单词:

贪婪匹配模式(尽量匹配更多内容,该正则表达式匹配方式"\<t.*e\>"会尽量匹配更多内容)

可以利用集合取反,不匹配空格即可避免空格;

找到家目录中所有的main函数:

1、找到所有.c结尾的文件

find home/ -name "*.c"

2、利用grep找到main函数;grep -nE "int main\("

3、利用管道 | 和xargs 组合完成对所用文件的查找

可以直接通过vim命令打开对应的文件的行:vim +2 home/leao/work/bit2.c (+2 表示查到的行号,后面则是路径)

在test01里查找以.txt结尾的内容:

grep -nE "\.txt" test01 (符号表示结尾,)

正则表达式会尽量匹配更多的内容;

其他命令:

alias :别名

直接输入alias会显示已有的别名;

history:显示最近敲过的命令

可以给history起别名:

该起别名方式只是临时生效(类似umask)

把最近输出的20条命令保存到文件中:


打包和压缩:

把多个文件包成一个文件,打包后的文件大小一般高于打包前文件的总和(会预留空间用于后续添加),压缩便于传输;

tarball的大小大于打包的文件:

打包:tar

打包后的文件叫tarball;

tar (主选项 + 辅选项) 目标文件名 源文件或目录

主选项:(只能选择一个)

c(create):创建一个包;

r():追加;

x:释放文件;

辅选项:

f:指定文件的名称

v (verbose):显示打包过程

z:用gzip算法来压缩或解压缩文件,后缀名为.gz;

把所有.txt结尾的文件打包成tarball:

移动包到dir5,使用sudo获得临时授权;

在dir5中进行解包:

压缩:sudo tar cvfz tarball *

以上打包和解包以及压缩的命令不加-;

打包所有.txt结尾的文件到tarball中:sudo tar cvf tarball *.txt

解包tarball:sudo tar xvf tarball

压缩所有文件到tarball:sudo tar cvfz tarball *

相关推荐
Diamond技术流10 分钟前
从0开始学习Linux——环境变量详解
linux·服务器·学习·centos·软件安装·环境变量
疯狂吧小飞牛11 分钟前
openssl颁发包含主题替代名的证书–SAN
运维·服务器·网络
疯狂吧小飞牛12 分钟前
openssl创建自签名证书
linux·服务器·ssl
qhd吴飞35 分钟前
在linux下用二进制方式安装mysql8
linux·运维·服务器
水饺编程1 小时前
【英特尔IA-32架构软件开发者开发手册第3卷:系统编程指南】2001年版翻译,2-32
linux·嵌入式硬件·fpga开发·硬件架构
刘登辉1 小时前
雷电模拟器charles代理抓包
运维·服务器
股票GPT分析1 小时前
《Python 股票交易分析:开启智能投资新时代》(二)
大数据·服务器·python·c#·fastapi
Wang's Blog1 小时前
RocketMQ: Broker 使用指南
服务器·网络·rocketmq
藤原拓远1 小时前
二.LoadBalancer负载均衡服务调用(1)
运维·负载均衡
抽象文学带师1 小时前
配置ssh免密登陆
运维·服务器·ssh