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."
elseecho "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 ];thenecho "10.18.40.100 is up." >>up.txt
elseecho "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";
elseecho "$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用户容易造成误操作,带来安全隐患,因此使用普通用户

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/41592.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

windows USB 设备驱动开发-控制传输的数据包

每次在主机控制器和 USB 设备之间移动数据时&#xff0c;都会发生传输。 通常&#xff0c;USB 传输可大致分为控制传输和数据传输。 所有 USB 设备都必须支持控制传输&#xff0c;并且可以支持用于数据传输的端点。 每种类型的传输都与设备缓冲区USB 端点 的类型相关联。 控制传…

泛微开发修炼之旅--32ecology对接海康威视综合安防管理系统,人脸识别机器数据同步代码方案及源码

文章链接&#xff1a;32ecology对接海康威视综合安防管理系统&#xff0c;人脸识别机器数据同步代码方案及源码

Open3D 在点云中构建八叉树

目录 一、概述 二、代码实现 2.1关键函数 2.2完整代码 三、实现效果 3.1原始点云 3.2构建后点云 一、概述 八叉树&#xff08;Octree&#xff09;是一种树状数据结构&#xff0c;用于递归地将3D空间分割成较小的立方体。八叉树特别适用于3D计算机图形学、点云处理和空间…

[图解]企业应用架构模式2024新译本讲解22-标识映射

1 00:00:01,080 --> 00:00:04,710 我们来看一下标识映射这个模式 2 00:00:08,030 --> 00:00:10,110 它是属于对象-关系 3 00:00:10,120 --> 00:00:11,150 行为模式 4 00:00:11,160 --> 00:00:13,890 就是说&#xff0c;在动态的时候 5 00:00:15,770 --> 00:…

C# Application.DoEvents()的作用

文章目录 1、详解 Application.DoEvents()2、示例处理用户事件响应系统事件控制台输出游戏和多媒体应用与操作系统的交互 3、注意事项总结 Application.DoEvents() 是 .NET 框架中的一个方法&#xff0c;它主要用于处理消息队列中的事件。在 Windows 应用程序中&#xff0c;当一…

实验四 图像增强—灰度变换之直方图变换

一&#xff0e;实验目的 1&#xff0e;掌握灰度直方图的概念及其计算方法&#xff1b; 2&#xff0e;熟练掌握直方图均衡化计算过程&#xff1b;了解直方图规定化的计算过程&#xff1b; 3&#xff0e;了解色彩直方图的概念和计算方法 二&#xff0e;实验内容&#xff1a; …

课设:选课管理系统(Java+MySQL)

在本博客中&#xff0c;我将介绍用Java、MySQL、JDBC和Swing GUI开发一个简单的选课管理系统。 技术栈 Java&#xff1a;用于编写应用程序逻辑MySQL&#xff1a;用于存储和管理数据JDBC&#xff1a;用于连接Java应用程序和MySQL数据库Swing GUI&#xff1a;用于构建桌面应用程…

555 定时器芯片工作原理

在本教程中&#xff0c;您将学习如何使用 555 定时器做一些有趣的事情。许多人用它做的第一件事就是制造闪烁的灯光。但这只是用该芯片可以做很多事情的简单示例之一。您还可以控制电机、创建闹钟、创建乐器等等。 让我们先来概览一下这些引脚。 555 定时器引脚排列 引脚 1 接地…

【SpringCloud】概述 -- 微服务入门

在Java的整个学习过程中&#xff0c;大家势必会听见一些什么分布式-微服务、高并发、高可用这些专业术语&#xff0c;给人的感觉很高级&#xff0c;有一种高深莫测的感觉。可以看一下这篇博客对这些技术架构的演变有一个初步的认识: 服务端⾼并发分布式结构演进之路-CSDN博客文…

image媒体组件属性配合swiper轮播

图片组件&#xff08;image&#xff09; 先插入个图片试试&#xff0c;插入图片用src属性&#xff0c;这是图片&#xff1a; 代码如下&#xff1a; <template><view><swiper indicator-dots indicator-color "#126bae" indicator-active-color &…

CobaltStrike的内网安全

1.上线机器的Beacon的常用命令 2.信息收集和网站克隆 3.钓鱼邮件 4.CS传递会话到MSF 5.MSF会话传递到CS 1上线机器的Beacon的常用命令 介绍&#xff1a;CobaltStrike分为服务端和客户端&#xff0c;一般我们将服务端放在kali&#xff0c;客户端可以在物理机上面&#xff0…

tongweb 部署软航流版签一体化应用示例 提示跨域错误CORS ERROR

目录 问题现象与描述 解决办法 原理解析 什么是CORS 浏览器跨域请求限制 跨域问题解决方法 跨域请求流程 浏览器请求分类解析 http请求方法简介 问题现象与描述 重庆软航科技有限公司提供了一套针对针对word、excel等流式文件转换成PDF版式文件并进行版式文件在线签章…

Qt 加载图片的几种方式 以及加载 loading

项目中经常使用加载图片&#xff1a; 常用有两种方式&#xff1a; 1.使用 QWidget 加载图片&#xff1a; 效果&#xff1a; 样例源码&#xff1a; int pict_H ui->widgetImage->height();int pict_W ui->widgetImage->width();ui->widgetImage->setFixe…

昇思25天学习打卡营第17天|SSD目标检测

学AI还能赢奖品&#xff1f;每天30分钟&#xff0c;25天打通AI任督二脉 (qq.com) SSD目标检测 模型简介 SSD&#xff0c;全称Single Shot MultiBox Detector&#xff0c;是Wei Liu在ECCV 2016上提出的一种目标检测算法。使用Nvidia Titan X在VOC 2007测试集上&#xff0c;SSD…

利用border绘制三角技巧

绘制三角形的效果如图 <html lang"zh-cn"> <head><meta charset"UTF-8"><title>demo</title><style>* {margin: 0;padding: 0;}.box {/* 盒子宽高改成零就变成三角形 &#xff0c;需要哪个方向的三角形就设置哪个方向…

【分布式系统五】监控平台Zabbix实际监控运用(命令+截图详细版)

目录 一.Zabbix 监控 Windows 1.安装zabbix 2.Web 页面添加主机&#xff0c;关联模板 二.Zabbix 监控 Java 应用 1.安装tomcat 2.服务端安装 zabbix-java-gateway 3.Web 页面添加主机&#xff0c;关联模板 三.Zabbix 监控 SNMP 1.服务端安装 snmp 监控程序 2.修改 sn…

RT-Thread和freeRTOS启动流程

一. freeRTOS启动流程 二. RT-Thread启动流程 因为RT-Thread中我们定义了补丁函数也叫做钩子函数--$Sub$$main()--作为一个新功能函数&#xff0c;可以将原有函数劫持下来&#xff0c;并在之后的程序运行中加上$Super $ $前缀来重新调用原始函数。 所以启动流程是$Sub$$main(…

Chiasmodon:一款针对域名安全的公开资源情报OSINT工具

关于Chiasmodon Chiasmodon是一款针对域名安全的公开资源情报OSINT工具&#xff0c;该工具可以帮助广大研究人员从各种来源收集目标域名的相关信息&#xff0c;并根据域名、Google Play应用程序、电子邮件地址、IP地址、组织和URL等信息进行有针对性的数据收集。 该工具可以提…

Nginx-简介

介绍 nginx是一款HTTP和反向代理服务器、邮件代理服务器和通用TCP/IP代理服务器&#xff0c;在俄罗斯广泛使用&#xff0c;用于代理高负载站点。 版本 nginx开源版nginx plus企业版openresty将nginx和lua脚本结合 tengine更稳定、高性能 正向代理 客户端和代理服务是一伙的…

【vue动态组件】VUE使用component :is 实现在多个组件间来回切换

VUE使用component :is 实现在多个组件间来回切换 component :is 动态父子组件传值 相关代码实现&#xff1a; <component:is"vuecomponent"></component>import componentA from xxx; import componentB from xxx; import componentC from xxx;switch(…