自学内容网 自学内容网

linux之管道重定向

管道与重定向

一、重定向

将原输出结果存储到其他位置的过程

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

进程在运行的过程中根据需要会打开多个文件,每打开一个文件会有一个数字标识。这个标识叫文件描述符。
进程使用文件描述符来管理打开的文件(FD----file descriptors).
文件描述符:每打开一个程序都会有文件描述

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

二、输出重定向 (覆盖,追加)

>   ----覆盖:直接把内容生成到指定文件,会覆盖源文件中的内容。
>>  ----追加:尾部追加,不会覆盖掉文件中原有的内容,相当于append
正确输出: 1> 1>> 等价于 > >>
错误输出: 2> 2>>

2.1. 案例1:输出重定向(覆盖)

[root@linux-server ~]# date 1> date.txt  #正确输出--覆盖
# 注意:如果 > 前面什么都不加默认为1,标准正确输出

2.2.案例2:输出重定向(追加)

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

2.3. 案例3:错误输出重定向

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

2.4.正确和错误都输入到相同位置

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

2.5.重定向到空设备/dev/null

[root@linux-server ~]# ls /home/  /aaaaaaaaa >list.txt 2>/dev/null #空设备,将错误的输出丢掉
[root@linux-server ~]# ls /home/  /aaaaaaaaa &>/dev/null #空设备,将正确与错误的输出丢掉
echo 会将输入的内容送往标准输出(打印)
echo 内容 >> 文件名或脚本 (使用重定向的方式创建文件或脚本)

2.6.脚本中使用重定向

实战一(没有使用重定向)

[root@linux-server ~]# vim ping1.sh
#!/bin/bash
ping -c1 10.18.40.100
if [ $? -eq 0 ];then     # $?判断上一条命令的执行返回值,0为真,非0为执行失败
  echo "10.18.40.100 is up."
else
  echo "10.18.40.100 is down!" 
fi
[root@linux-server ~]# chmod +x ping1.sh 
[root@linux-server ~]# ./ping1.sh #执行文件(执行脚本)
PING 10.18.40.100 (10.18.40.100) 56(84) bytes of data.
​
--- 10.18.40.100 ping statistics ---
1 packets transmitted, 0 received, 100% packet loss, time 0ms
​
10.18.40.100 is down!

实战二(使用重定向)

[root@linux-server ~]# vim ping1.sh
#!/bin/bash
ping -c1 10.18.40.100 &>/dev/null
if [ $? -eq 0 ];then
  echo "10.18.40.100 is up." >>up.txt
else
  echo "10.18.40.100 is down!"
fi
[root@linux-server ~]# ./ping1.sh

实战三

[root@linux-server ~]# vim ping.sh
#!/bin/bash
ip=10.31.160
for i in {10..20}   #变量i取值
do
ping -c1 $ip$i &> /dev/null
if [ $? -ne 0];then        # -ne不等于
    echo "network is not ok";
else
    echo "$ip.$i" >> /mnt/up.txt
fi
dine
[root@linux-server ~]# bash ping.sh
[root@linux-server ~]# cat /mnt/up.txt

三、输入重定向 <

标准输入: <   等价 0<
通过输入重定向创建文件

(cat > file <<EOF )是用来创建文件或者在脚本中使用,并向文件中输入信息输入的任何东西会被写入文件中,EOF命令结束。

​语法:cat > filename <<EOF  #可以写到脚本或者文件里面
EOF:开始和结束的标记。命令不是固定的,可以是任意字符,但结尾字符必须与开始字符一致,成对使用;
结尾字符必须顶格写。如果不是在脚本中,可以用Ctrl-D输出EOF的标识;
在脚本输入多行文本内容时,<<-EOF可以去除结尾分界符EOF所在行开头部分的制表符,忽略所有的前导制表符(tab)字符。

实战案例一:

[root@linux-server ~]# cat >file4 <<EOF
> 111
> 222
> 333
> 444
> EOF
[root@linux-server ~]# cat file4 
111
222
333
444

实战案例二

利用重定向建立多行的文件 脚本创建多行文件

[root@linux-server ~]# vim create_file.sh
#!/bin/bash
cat >file200.txt <<EOF
111
222
333
yyy
ccc
EOF
[root@linux-server ~]# chmod +x create_file.sh 
[root@linux-server ~]# ./create_file.sh 
[root@linux-server ~]# cat file200.txt 
111
222
333
yyy
ccc

四、管道 |

进程间通信的一种方式

用法:command1 | command2 |command3 |...

实战案例一

[root@linux-server ~]# rpm -qa  | grep 'httpd'
                                #查询所有安装的软件包,过滤包含httpd包
httpd-tools-2.4.6-90.el7.centos.x86_64
httpd-2.4.6-90.el7.centos.x86_64
​
[root@linux-server ~]# ps aux | grep 'sshd'

实战案例二

将/etc/passwd中的用户按UID大小排序

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

实战案例三

[root@linux-server ~]# netstat -lntp | awk 'NR==3 {print $4}' | awk -F':' '{print $2}'
            # awk截取 NR指定截取的行 print打印 $指定截取的列, -F指定截取的分隔符
22        

五、参数传递:xargs

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

实战案例一

[root@linux-server ~]# touch /home/file{1..5}
[root@linux-server ~]# vim files.txt
/home/file1
/home/file2
/home/file3 
/home/file4
/home/file5
[root@linux-server ~]# cat files.txt |ls -l #不加xargs传参,看输出结果
[root@linux-server ~]# cat files.txt |rm -rvf  #不加xargs传参,看输出结果
[root@linux-server ~]# 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
-rw-r--r--. 1 root root  0 Nov  7 21:57 /home/file4
-rw-r--r--. 1 root root  0 Nov  7 21:57 /home/file5
[root@linux-server ~]# cat files.txt | xargs rm -rvf
removed ‘/home/file1’
removed ‘/home/file2’
removed ‘/home/file3’
removed ‘/home/file4’
removed ‘/home/file5’

实战案例二

[root@linux-server ~]# touch /home/file{1..5}
[root@linux-server ~]# # cat files.txt | xargs -i cp -rvf {} /tmp/
‘/home/file1’ -> ‘/tmp/file1’
‘/home/file2’ -> ‘/tmp/file2’
‘/home/file3’ -> ‘/tmp/file3’
‘/home/file4’ -> ‘/tmp/file4’
‘/home/file5’ -> ‘/tmp/file5’
常用小命令

du:查看文件大小

wc:(word count)计算文件的行数、字数和字节数

[root@linux-server ~]# du -h /etc/   #查看目录及目录中的文件大小
[root@linux-server ~]# du -sh /etc/  #查看目录的总大小
[root@linux-server ~]# ls /etc/ | wc -l #查看目录中有多少个文件(一级目录下的)
[root@linux-server ~]# ls -R /etc/ | wc -l #-R递归目录,可查看目录下的所有文件

作业

1.cat /2.txt 将它的结果混合输出到/opt/file.txt
cat /2.txt &> /opt/file.txt
2.怎么判断一个账户是否存在??
id user_name
3.将22覆盖到a.txt文件中
echo 22 > a.txt
4.>与>>区别是什么
>(1)直接把内容生成到指定文件,会覆盖源文件中的内容(2)直接生成一个空白文件,相当于touch命令
>>尾部追加,不会覆盖掉文件中原有的内容
5.将cat /home/b.txt中将正确的输出重定向到a.txt中将错误的输出重定向到c.txt
cat /home/b.txt >a.txt 2>c.tst
6.请将vsftpd的进程杀掉,他的IPD为11223?    kill -9 11223
7.请描述一下kill与pkill的区别
kill 指定pid进程号
pkill 指定进程名,可以删除某个终端,或者某个用户的进程
8.请描述一下什么是nice值
进程优先级,范围是-20到+19,nice值越大意味着更低的优先级,低nice值会获得更多的处理器时间。
nice值并不是优先级,但会影响优先级:PRI = PRI(old) + nice(PRI就是优先级值,越小越先被调度)
9.如何删除当前目录下以.log结尾的文件?   rm -rf ./*.log
10.打印当前工作目录的Linux命令是?       pwd
11.如何查看在后台运行的程序?            jobs
12.如何将后台运行的程序调出之前台运行?   fg 工作号
13.2>与&>是什么意思?
标准错误的内容输出覆盖到指定文件
正确和错误混合输出到指定文件
14.请用输入重定向将123456写入a.txt文件中。 echo 123456 > a.txt
15.动态查看进程的命令你知道哪几个?top,htop,uptime
扩展--阅读

什么是CC攻击?

攻击者借助代理服务器生成指向受害主机的合法请求,实现DDOS和伪装就叫:CC(ChallengeCollapsar)。
CC主要是用来攻击页面的。大家都有这样的经历,就是在访问论坛时,如果这个论坛比较大,访问的人比较多,打开页面的速度会比较慢,
访问的人越多,论坛的页面越多,数据库压力就越大,被访问的频率也越高,占用的系统资源也就相当可观。

如何防御CC攻击

1.开启防火墙,过滤掉访问次数多的IP地址
2.拒绝代理服务器访问你服务器
怎么拒绝代理服务器访问呢?
代理服务器有固定的IP地址,将这些IP地址都加到防火墙下,全部drop掉

CC攻击危害是什么?

大量的流量不断冲击你的服务器,会让你的服务器负载及压力越来越大,直到服务器崩溃宕机

6.什么是DOS攻击

DoS是Denial of Service的简称,即拒绝服务,造成DoS的攻击行为被称为DoS攻击,其目的是使计算机或网络无法提供正常的服务。最常见的DoS攻击有计算机网络带宽攻击和连通性攻击。

云计算基础 练习试题I

第一题:如何查看你的服务器IP地址?

ip a
ifconfig

第二题:你所使用的linux是哪个版本?请描述一下你所知道的其他发行版?

Centos7
Debian, RHEL, Ubuntu, openSUSE

第三题:请简述一下什么是绝对路径什么是相对路径?

绝对路径以/开头的路径,相对路径是从非/开始的路径,从当前目录开始

第四题:请给jack用户设置密码,密码为123456

useradd jack && passwd jack 123456

第五题:请创建用户tom,登录shell为/sbin/nologin,并指定uid为1200

useradd -u 1200 -s /sbin/nologin tom

第六题:请描述下面目录的作用

/root:root用户的家目录
/home:普通用户的家目录
/usr/local:安装软件的目录
/etc:存放配置文件
/bin:普通用户使用的命令文件
/sbin:管理员使用的命令文件

第七题:如何查看系统中alice用户是否存在?

id alice 

第八题:在权限设置中请说明下面内容

r是什么? 对应数字是几?读取  4
w是什么? 对应数字是几?写入  2
x是什么? 对应数字是几?执行  1

第九题:请回答下面的问题

root:x:0:0:root:/root:/bin/bash
分隔符是什么?冒号
第一列是什么?用户
第二列是什么?密码
第四列是什么?gid
第六列是什么?家目录
第七列是什么?登录的shell

第十题: 请简述vim编辑器中的如下命令

i ----- 光标所在处进入编辑模式
o -----  在光标下一行进入编辑模式
yy -----复制光标所在行
dd -----删除光标所在行
u -----撤销
G ------到页尾
shift+v -----进入可视行模式
x ------删除光标处的字符
gg ------到页首
r ------修改光标所在字符
p ------在光标下一行粘贴

第十一题:请简述一下rwx对文件和对目录的影响和对应的命令

对文件:
r: 读--cat、less
w: 写--vi、vim
x: 执行--bash ./file_name
​
对目录:
r: 读--ls 
w: 写--touch、mv、rm  
x: 执行--cd
​

第十二题:创建用户jack和it组,并将jack添加到it组里面,同时it组对文件a.txt有读写权限

groupadd it
useradd jack -G it
chmod g+w a.txt
chown .it a.txt

第十三题:如何查看/opt/目录下面的所有文件包括隐藏文件

ls -a /opt

第十四题:请将/opt/test/目录以及目录中的所有文件设置为读和执行权限

chomd -r g=rx o=rx /opt/test/

第十五题:请简述一下在公司里面为什么不能使用root用户

 root用户为管理员用户,权限太高,使用root用户容易造成误操作,带来安全隐患,因此使用普通用户


原文地址:https://blog.csdn.net/m0_54563444/article/details/140131362

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!