Linux管道&重定向


只有在开水里,茶叶才能展开生命浓郁的香气。

文件权限(扩展)–接上节

文件权限管理: 隐藏权限防止root误删除

文件属性添加与查看

1.查看文件属性

[root@localhost ~]# touch file1 file2 file3
[root@localhost ~]# lsattr file1 file2 file3 
---------------- file1
---------------- file2
---------------- file3

2.设置权限

[root@localhost ~]# chattr +a file1  # 不允许修改,只允许追加
[root@localhost ~]# chattr +i file2  # 不允许做任何操作
[root@localhost ~]# chattr +A file3
[root@localhost ~]# lsattr file1 file2 file3
-----a---------- file1
----i----------- file2
-------A-------- file3
i:即Immutable,系统不允许对这个文件进行任何的修改
a:即Append Only,系统只允许在这个文件之后追加数据,不允许任何覆盖或截断这个文件
A:即Atime,告诉系统不要修改对这个文件的最后访问时间  # 不能更名mv file1 file2

3.取消权限

[root@localhost ~]# chattr -a file1 
[root@localhost ~]# chattr -i file2 

重定向

标准输入、标准正确输出、标准错误输出

0,标准输入(键盘)
1,标准输出
2,标准错误,
3+,进程在执行过程中打开的其他文件。  
&:表示正确错误混合输出

输出重定向(>)

覆盖

[root@localhost ~]# date 1> date.txt 	# 正确输出--覆盖

注意 :如果 > 前面什么都不加默认为1,标准正确输出。
追加

[root@localhost ~]# date >> date.txt 	# 正确输出--追加

错误输出

[root@localhost ~]# ls /home/  /aaaaaaaaa >list.txt
ls: cannot access /aaaaaaaaa: No such file or directory
[root@localhost ~]# ls /home/  /aaaaaaaaa >list.txt 2>error.txt 	# 重定向到不同的位置
[root@localhost ~]# cat error.txt 
ls: cannot access /aaaaaaaaa: No such file or directory

对错都输入到相同位置

[root@localhost ~]# ls /home/  /aaaaaaaaa &>list.txt 	# 混合输出到相同文件

重定向到空设备(/dev/null)

[root@localhost ~]# ls /home/  /aaaaaaaaa >list.txt 2>/dev/null 	# 空设备,将错误的输出丢掉
[root@localhost ~]# ls /home/  /aaaaaaaaa &>/dev/null 	# 空设备,将正确与错误的输出丢掉

输入重定向(<)

语法: 标准输入: < 等价 0<

[root@localhost ~]# cat /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
...
[root@localhost ~]# cat < /etc/passwd 	# 输入重定向
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
...
虽然执行结果相同,但第一行代表是以键盘作为输入设备,而第二行代码是以 /etc/passwd 文件作为输入设备
注意:将/etc/passwd作为cat的输入,读出/etc/passwd的内容

输入重定向创建文件
语法:cat >> file5 <<EOF # 可以写到脚本或者文件里面
EOF:开始和结束的标记。
成对使用
结尾的另一个必须定格写。

[root@localhost ~]# cat >file4 <<EOF 	# cat >文件<<EOF 	# 开始
> 111		# 输入	
> 222
> 333
> 444
> EOF		# 结束
[root@localhost ~]# cat file4 	# 查看
111
222
333
444

管道

语法:command1 | command2 |command3 |…
例1

[root@localhost ~]# ls /etc  |grep 'sys' 	# 查询目录内符合要求的文件

例2

[root@localhost ~]# sort -t":" -k3 -n /etc/passwd 	# 以: 分隔,将第三列按字数升序
[root@localhost ~]# sort -t":" -k3 -n /etc/passwd -r 	# 以: 分隔,将第三列按字数降序
[root@localhost ~]# sort -t":" -k3 -n /etc/passwd |head 	# 以: 分隔,将第三列按字数升序看前十行
[root@localhost ~]# sort -t":" -k3 -n /etc/passwd |tail 	# 以: 分隔,将第三列按字数升序看后十行
参数详解:
sort 排序,默认升序
-t 指定分隔符
-k 指定列
-n 按数值
-r 降序
head 默认输出前十行
tail 默认输出后十行

参数传递:xargs

当不能执行ls、cp、rm管道时,使用xargs。
语法:

 cat a.txt | xargs  -i cp {} /目录  
 {}:前面传过来的内容
 -i :为了让大括号生效
 目录时  -r
 解释:前面传过来的东西交给大括号
 cat file.txt |xargs ls -l          
 前面是目录或者目录的路径。  ls - l  后面可以不加大括号,直接执行。

例1

[root@localhost ~]# touch /home/file{1..3}
[root@localhost ~]# vim files.txt
/home/file1
/home/file2
/home/file3 
[root@localhost ~]# cat files.txt |ls -l 	# 不加xargs传参,看输出结果
[root@localhost ~]# cat files.txt |rm -rvf 	# 不加xargs传参,看输出结果
加xargs传参
[root@localhost ~]# cat files.txt |xargs ls -l
-rw-r--rwx. 1 root root 12 Nov  7 21:57 /home/file1
-rw-r--r--. 1 root root  0 Nov  7 21:57 /home/file2
-rw-r--r--. 1 root root  0 Nov  7 21:57 /home/file3
[root@localhost ~]# cat files.txt |xargs rm -rvf
removed ‘/home/file1’
removed ‘/home/file2’
removed ‘/home/file3’

例2

[root@localhost ~]# touch /home/file{1..5}
[root@localhost ~]# # cat files.txt | xargs -i cp -rvf {} /tmp/
‘/home/file1’ -> ‘/tmp/file1’
‘/home/file2’ -> ‘/tmp/file2’
‘/home/file3’ -> ‘/tmp/file3’

扩展

kill与pkill

语法
kill:杀掉单个进程

1(HUP):重新加载进程。
9 (KILL):杀死进程。
15(TERM):完美地停止一个进程。
kill pid 	# 同下-15默认的安全停止进程
kill -15 pid 
kill -9 pid 	# 彻底杀死进程

pkill:杀掉一类进程或者某个用户的所有进程。

pkill mysql 	# 结束 mysql 进程
pkill -u mark,danny 	# 结束mark,danny用户的所有进程
w 	# 使用w命令查询本机已经登录的用户
pkill -9 -t pts/1 	# 强制杀死从pts/1虚拟终端登陆的进程

nice值

解释:每个进程都拥有一个 nice 值,其取值范围为−20(高优先级)~19(低优先级),默认值为 0
传统上,只有特权进程(-20 ~ 0)才能够赋给自己(或其他进程)一个负(高)优先级;非特权进程(0 ~ 19)只能降低自己的优先级,即赋一个大于默认值 0 的nice 值。
作用/影响

  • 进程的调度不是严格按照nice值的层次进行的,nice值只是一个权重因素,会导致内核调度器倾向于调度高优先级的进程。
  • 给一个进程赋一个低优先级(即高 nice 值)并不会导致它完全无法用到 CPU,但会导致它使用 CPU 的时间变少
  • nice值对进程调度的影响程度则依据Linux内核版本的不同而不同,在不同Unix系统之间也是不同的

查看后台

jobs命令
功能:查看当前终端后台运行的任务

 jobs -l 选项可显示当前终端所有任务的PID
 jobs的状态可以是running,stopped,Terminated
 + 号表示当前任务,- 号表示后一个任务

ps命令
功能:查看当前的所有进程

ps -aux | grep "test.sh"  	# a:显示所有程序  u:以用户为主的格式来显示   x:显示所有程序,不以终端机来区分

在这里插入图片描述

切换进程

fg   %[number] 	让后台运行的进程 [number] 到前台来
bg   %[number]	让进程 [number] 到后台去
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值