linux 软连接 重定向,五.Linux博客-2016年7月28日索引、硬链接、软连接、inode表、file、重定向、tr、管道、用户、组...

格式说明:

操作

概念

命令

说明及举例

五.索引、硬链接、软连接、inode表、file、重定向、tr、管道、用户、组

索引节点

原数据保存在inode table表中

每个文件或目录都有一个独立的inode number(节点编号在一个分区中是唯一的,每个分区都有自己的inode table)

ls -i 查看节点编号

硬链接

ln f1 dir/f11 为f1文件创建硬链接并放到dir文件夹下,名称为f11.跨设备跨分区不能创建。

链接数=文件名字的数量,为一个文件创建多个硬链接相当于给一个文件取了多个名字,修改任何一个文件都等于全部修改,删除其中一个硬链接,只相当于删除了这文件的名字之一

目录不能创建硬链接

软连接(符号链接)

ln -s f2 f2kuaijiefangshi 为f2文件创建软连接f2kuaijiefangsh

给文件创建软连接,相当于给文件创建快捷方式,写软链接的时候,文件的路径必须写清楚(相对于软连接的路径,而不是当前工作目录的路径),软连接的路径无所谓

inode表结构

前12个是数据块,每个存4k,第13个是指针快,不直接指向数据块,可存4kx1024=4M文件;第14个是二重指针块,后面跟两个指针块,可存4kx1024x024=4G文件,以此类推.

df -i 查询每个分区最大节点数及已用节点数量

节点号消耗完也会提示磁盘空间满了

练习:解释cp rm mv命令的系统后台动作

file命令

flie -f +文档 把想查看的文件目录写到文档里,可以都查看

标准输入和输出

标准输出、错误

标准默认输出在当前窗口,标准输出错误也在当前窗口

重定向

ls > /dev/pts/0 在pts0窗口上显示

ls > /testdir/ls.log 让输出内容重定向到ls.log文件中(没有这个文件会创建,如果存在会覆盖)

ls >> /testdir/ls.log 将信息写到ls.log文件中,保留原有内容

>是重定向标准输出的正确结果的; >=1>

2>是重定向错误信息的

ls /dev /ddd > /tesedir/dui.log 2> /testdir/cuo.log 将命令中正确信息写到dui.log ,错误信息写到cuo.log

ls /dev /ddd &> /tesedir/all.log 把命令中所有标准输出都写到all.log里

以上命令是覆盖

以下命令是累加

ls /dev /ddd >> /tesedir/dui.log 2>> /testdir/cuo.log 将命令中正确信息写到dui.log ,错误信息写到cuo.log

ls /dev /ddd &>> /tesedir/all.log 把命令中所有标准输出都写到all.log里

多条命令重定向:用括号把多条命令括起来

标注输入重定向

cat 

cat  f2 将f1里的信息输出到f2里

cat f1 f2 > f3 将f1 f2的内容输出到f3里

mail -s hello wang 回车后写内容,结束按.

wang 用户 输入mail

mail -s hello wang 

多行重定向

cat <f1 直到打结束的E 才重定向到f1中 (<

tr命令

转换和删除字符

tr 'a-z' 'A-Z' 将所有输入的小写字母转换成大写字母

tr 'a-z' 'A-Z' 

r 'a-z' 'A-Z'  f2 将f1 文件中所有小写字母转换为大写并存到f2中(f1中内容不变)

tr 'abc' 'xyz'

tr 'abc' 'xy'

tr 'ab' 'xyz'

tr -c 'a-z' 取反

tr -d 'abc' 有a/b/c的都干掉

tr -d -c 'abc'  'xxx' 

tr -s  ‘x’  合并重复的x为1个

tr -d '\n' < f1 将f1文件中的换行都干掉

tr ' ' '\n'

mail -s help root <

Hello,I am whoami

the system version is here,please help me to check it,thanks!

< /etc/issue

end

管道

管道接收的是标准输出,不能是标准错误

练习用管道读文档发邮件

ls /err |& tr 'a-z' 'A-Z' 不管前面是否是错误,都处理(|&=2>&1)

ls |tee f2  将ls输出内容存到f2文件,但是前台也显示

重定向输出信息不想看的话最后加 /dev/null

用户、组和权限

组的类别

用户的主要组-主组

用户必须属于一个且只有一个主组

组名同用户名,且仅包含,,,

Linux中默认创建一个用户wang,就会创建一个wang组,组里只有wang一个

查看命令 id

Linux用户和组的配置文件

用户配置文件

/etc/passwd:用户及其属性信息(名称、UID、主组ID等)

/etc/shadow:用户密码及其相关属性

例:m:$6$8BhKzFY7Pl02tuZK$M9ppDJCf6Y8sSx/kFGbmG6Mat/Z2JE.OJ6Mao.izesjpwW0t5MiFxxrtzwLrAwfP6/xvlZ7MG8Y4LeGIAd6Me0:17001:0:99999:7:::

$6=sha512加密算法 $1=md5加密算法 后面两个$中间的玩意($8BhKzFY7Pl02tuZK$)是加的延,目的是即使相同密码加密后也看不出来是相同 ;17001代表时间,后面的0表示随时可以改密码,改成3就是3天以后才能改。后面难道99999代表有效期,7代表提前7天通知;倒数第二个可以填个数,代表此账号的有效期,到时间自动锁定,格式也是类似17001天。

组配置文件

/etc/group:组及其属性信息

/etc/gshadow:组密码及其相关属性

groups +用户名 查看用户属于什么组

getent passwd 用户名,查看某用户的密码信息

将用户加到root组中,该用户创建的文件所有者及所属组依然是该用户(其主组)

newgrp bin 将用户的主组切换为bin 但是需要密码

gpasswd bin 给组设置密码

改密码命令

vipw 改用户密码,格式改错会报警用法等于 vim /etc/passwd

vigr 改组密码。格式改错会报警用法等于 vim /etc/group

原创文章,作者:自己泡面,如若转载,请注明出处:http://www.178linux.com/39180

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值