五.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 < f1 将f1里的信息输出
cat < f1 > f2 将f1里的信息输出到f2里
cat f1 f2 > f3 将f1 f2的内容输出到f3里

mail -s hello wang 回车后写内容,结束按.
wang 用户 输入mail
mail -s hello wang < f1.txt  将f1.txt中内容作为正文发送

多行重定向
cat <<E >f1 直到打结束的E 才重定向到f1中 (<<+关键字开始。再出现独立的一行关键字结束)

tr命令

转换和删除字符

tr 'a-z' 'A-Z' 将所有输入的小写字母转换成大写字母    
tr 'a-z' 'A-Z' < f1 将f1 文件中所有小写字母转换为大写
r 'a-z' 'A-Z' < f1 > 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' < f1 将文件f1 中的除了abc以外的字符都换成xxx

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

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

mail -s help root <<end
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)
自己泡面自己泡面
上一篇 2016-08-23 14:50
下一篇 2016-08-23 14:54

相关推荐

  • 磁盘管理

    回顾 {a..f} a b c d e f ]# arr=({a..z}) ]# echo ${#arr[*]} 26 ]# N1=N2 ]# N2=zhuchaoming ]# echo ${!N1} eval N1=\$$N2 echo $N1 创建临时文件 mktemp NAME.XXX 交互式登录 /etc/profile –> /…

    Linux干货 2016-09-07
  • grep 命令详解

    grep 命令详解 概述:本文档基于 info grep 翻译,完成度可能 90% 左右。 作者:N10-guli 时间:2016-01-05 版本:v1.0 目录:     1,grep 命令的选项     2,grep 命令的正则表达式     3,gre…

    Linux干货 2016-02-14
  • iptables

      iptables(1) Firewall:隔离工具;Packets Filter Firewall;工作于主机或网络的边缘,对经由的报文根据预先定义的规则(匹配条件) 进行检测,对于能够被规则匹配到的报文实行某预定义的处理机制的一套组件;     硬件防火墙:在硬件级别实现部分功能的防…

    Linux干货 2016-11-01
  • 实现基于MYSQL验证的vsftpd虚拟用户

    马哥教育面授21期 运维 vsftpd MySQL 说明:本实验在两台CentOS主机上实现,一台做为FTP服务器,一台做数据库服务器 一、安装所需要包和包组: 在数据库服务器上安装包: yum –y install mariadb-server mariadb-devel systemctl start mariad…

    Linux干货 2016-12-21
  • 学习宣言~~

    学如逆水行舟,不进则退。

    Linux干货 2016-12-26
  • 堡垒机-麒麟堡垒机动态口令使用手册

      一.管理员部分 1.在其它-licenses菜单查看动态口令许可是否打开,如果未打开联系厂商重新生成许可   2.找厂商生成密钥文件,密钥文件中包含令牌种子,在其它–动态令牌菜单将密钥文件导入即可看到所有的令牌种子,每个令牌可以绑定给多个用户     3.令牌绑定可以在 资源管理–…

    安全运维 2016-05-29