1. 输出重定向:

默认条件下,标准输出和错误输出都是终端,可以把标准输出和错误内容进行重定向:

[~]# echo "hello\!"

hello\!

[~]# echo "hello!"

-bash: !": event not found "

把标准输出重定向到文件

[~]# echo "hello" > test.sh

[~]# cat test.sh

hello

'>'输出方式默认等价'1>'

[~]#  echo "hello" 1> test.sh

[~]# cat test.sh

hello

但是错误内容还是会显示在屏幕上:

[~]$cat edit.sql /root/test.sh > temp.sh

cat: /root/test.sh: Permission denied

可以把错误内容也输出到文件中(利用文件描述符):

[~]$cat edit.sql /root/test.sh 1> temp.sh 2> error.sh

[~]$cat temp.sh

select           dbms_rowid.rowid_object('AAAZdQAAGAAATxjAAk') data_object_id#,

dbms_rowid.rowid_relative_fno('AAAZdQAAGAAATxjAAk') rfile#,

dbms_rowid.rowid_block_number('AAAZdQAAGAAATxjAAk') block#,

dbms_rowid.rowid_row_number('AAAZdQAAGAAATxjAAk') row# from dual

/

[~]$cat error.sh

cat: /root/test.sh: Permission denied

把标准输出和错误信息写入同一个文件:

[~]$cat edit.sql /root/test.sh > temp.sh 2>&1

[~]$cat temp.sh

select           dbms_rowid.rowid_object('AAAZdQAAGAAATxjAAk') data_object_id#,

dbms_rowid.rowid_relative_fno('AAAZdQAAGAAATxjAAk') rfile#,

dbms_rowid.rowid_block_number('AAAZdQAAGAAATxjAAk') block#,

dbms_rowid.rowid_row_number('AAAZdQAAGAAATxjAAk') row# from dual

/

cat: /root/test.sh: Permission denied

这个看起来比较麻烦,实际应用中可能用的最多的是:

[~]$cat edit.sql /root/test.sh &>temp.sh

[~]$cat temp.sh

select           dbms_rowid.rowid_object('AAAZdQAAGAAATxjAAk') data_object_id#,

dbms_rowid.rowid_relative_fno('AAAZdQAAGAAATxjAAk') rfile#,

dbms_rowid.rowid_block_number('AAAZdQAAGAAATxjAAk') block#,

dbms_rowid.rowid_row_number('AAAZdQAAGAAATxjAAk') row# from dual

/

cat: /root/test.sh: Permission denied

&>把所有输出都写入同一个文件

如果不想输出到文件,也不想在屏幕上显示,可以利用/dev/null这一特殊设备文件(bit bucket)

[~]$cat edit.sql /root/test.sh &>/dev/null

如果把标准输出写入到文件,就没法利用管道符号'|'把内容传给接下来的命令,可以利用tee命令解决这个问题:

[~]$cat edit.sql /root/test.sh | tee temp.sh | cat -n

cat: /root/test.sh: Permission denied

select           dbms_rowid.rowid_object('AAAZdQAAGAAATxjAAk') data_object_id#,

dbms_rowid.rowid_relative_fno('AAAZdQAAGAAATxjAAk') rfile#,

dbms_rowid.rowid_block_number('AAAZdQAAGAAATxjAAk') block#,

dbms_rowid.rowid_row_number('AAAZdQAAGAAATxjAAk') row# from dual

/

tee命令相当于把stdout副本写入文件,再把stdout传给下一个命令,但是错误内容是无法用tee传递的,如同使用>>追加内容,tee可以使用-a选项追加:

[~]$cat edit.sql /root/test.sh | tee -a temp.sh | cat -n

cat: /root/test.sh: Permission denied

select           dbms_rowid.rowid_object('AAAZdQAAGAAATxjAAk') data_object_id#,

dbms_rowid.rowid_relative_fno('AAAZdQAAGAAATxjAAk') rfile#,

dbms_rowid.rowid_block_number('AAAZdQAAGAAATxjAAk') block#,

dbms_rowid.rowid_row_number('AAAZdQAAGAAATxjAAk') row# from dual

/

[~]$cat temp.sh

select           dbms_rowid.rowid_object('AAAZdQAAGAAATxjAAk') data_object_id#,

dbms_rowid.rowid_relative_fno('AAAZdQAAGAAATxjAAk') rfile#,

dbms_rowid.rowid_block_number('AAAZdQAAGAAATxjAAk') block#,

dbms_rowid.rowid_row_number('AAAZdQAAGAAATxjAAk') row# from dual

/

select           dbms_rowid.rowid_object('AAAZdQAAGAAATxjAAk') data_object_id#,

dbms_rowid.rowid_relative_fno('AAAZdQAAGAAATxjAAk') rfile#,

dbms_rowid.rowid_block_number('AAAZdQAAGAAATxjAAk') block#,

dbms_rowid.rowid_row_number('AAAZdQAAGAAATxjAAk') row# from dual

/

2.输入重定向:

输入重定向,在一些场合,例如数据库监控中用的比较多,常见的是使用内联重定向

[~]$cat < edit.sql

select           dbms_rowid.rowid_object('AAAZdQAAGAAATxjAAk') data_object_id#,

dbms_rowid.rowid_relative_fno('AAAZdQAAGAAATxjAAk') rfile#,

dbms_rowid.rowid_block_number('AAAZdQAAGAAATxjAAk') block#,

dbms_rowid.rowid_row_number('AAAZdQAAGAAATxjAAk') row# from dual

/

例如,如下操作,把 < temp.sh到最后EOF之间的内容当作stdin,然后把stdout写入文件temp.sh

[~]$cat < temp.s

this is my log

EOF

[~]$cat temp.sh

this is my log

3.自定义文件描述符:

自定义文件描述符的原理是使用基本的三种文件打开模式

只读(

截断(>)

追加(>>)

创建一个文件描述符3,用于打开文件

[~]# exec 3< test.sh

下面就可以直接使用文件描述符打开文件了,但是只能使用一次:

[~]# cat

hello

hello

创建文件描述符4,用于写入文件(可以复用):

[~]# exec 4>test.sh

[~]# echo okok >&4

[~]# cat test.sh

okok

这个实际类似前面的:

[~]$cat edit.sql /root/test.sh > temp.sh 2>&1

创建文件描述符5,用于向文件追加内容(也可以复用,不像输入文件描述符那样只能使用1次):

[~]# exec 5>>test.sh

[~]# echo okokok >&5

[~]# cat test.sh

okokok

[~]# echo okokok >&5

[~]# cat test.sh

okokok

okokok

linux标准输出重定向到文件夹,linux输入输出重定向使用详解相关推荐

  1. Linux下zip格式文件的解压缩与压缩操作命令详解

    < Linux下zip格式文件的解压缩与压缩操作命令详解 > * 声明:网上找来比较凌乱,整理了一下,方便自己查看 zip格式文件的解压缩与压缩操作: 1.把/home目录下面的huaza ...

  2. 在linux系统中创建文件夹,Linux系统中创建文件夹命令详解

    Linux系统中创建一个新的文件夹我们可以使用命令来执行,下面由学习啦小编为大家整理了Linux系统中创建文件夹命令详解,希望对大家有帮助! Linux系统中创建文件夹命令详解 一.mkdir命令使用 ...

  3. Linux使用命令移动文件夹,linux虚拟机中如何用命令来移动文件夹

    对于新手来说,经常会碰到如何移动linux系统中的文件夹之类的问题,这些命令都很简单,关键在于熟能生巧,接下来跟着小编一起学习一下如何在装有linux的虚拟机中进行文件夹的移动. linux虚拟机中如 ...

  4. linux ssh怎样删除文件夹,Linux服务器一键删除文件夹SSH命令

    Linux服务器管理不像Windows服务器管理那么方便,当然Linux也可以直观可视化操作,本人习惯使用SSH命令管理操作,常常会碰到网站产生 大量垃圾文件的苦恼,直接登录FTP删除的话,曾经试过删 ...

  5. linux搜索有哪些文件夹,Linux常见几个查找命令

    以下命令是很久以前学习Linux,网上查到的命令自己做了下总结.记录在这里方便以后查看. Linux常见五种查找命令 1.which which命令的作用是,在PATH变量指定的路径中,搜索某个系统命 ...

  6. linux 新建1 10文件夹,linux创建目录和文件的命令

    linux下进行操作难免会遇到创建文件或者目录的情况,那么我们要使用什么目录来创建目录和文件呢?下面由学习啦小编为大家整理了linux创建目录和文件命令的相关知识,希望大家喜欢! 一.linux创建目 ...

  7. linux svn添加新文件夹,linux svn 添加文件夹

    安装doxygen 安装包 doxygen-1.7.4.linux.bin.tar.gz(可在官网下载) 命令: 1) tar xvfz doxygen-1.7.4.linux.bin.tar.gz ...

  8. linux服务器拷贝目录文件夹,linux两台服务器之间文件/文件夹拷贝

    linux两台服务器之间文件/文件夹拷贝 跨服务器拷贝需要用到的命令是scp. ----------------------拷贝文件夹--------------------------------- ...

  9. linux查询所建文件夹,linux中的文件和文件夹的新建、查询、删除

    新建文件夹 使用的mkdir命令可以新建文件夹. mkdir filename 这样就创建了一个叫做filename文件夹. 新建一个文件 新建的文件可以包括任何扩展名,.txt/.cpp/.csv ...

最新文章

  1. rsa证书ssh登陆服务器
  2. Mysql一些重要配置参数的学习与整理(一)
  3. Linux 下 hosts 应用
  4. Centos 7下查看当前目录大小及文件个数
  5. Windows远程连接的用户名和密码怎么设置?
  6. vue 限制渲染条数_深入理解Vue 的条件渲染和列表渲染
  7. 解决scanf_s函数报错:没有为格式字符串传递足够的参数
  8. json对象合并的方法
  9. [ZJOI 2006]书架
  10. iOS 中可能用到的数学公式(绝对值、平方、取整、正余弦)
  11. 本机查看文件服务器所有共享的文件,谁访问,谁打开,
  12. 优秀的Web前端工程师需要具备什么?
  13. vue打包app网络错误和空白页问题
  14. 国标GB/T28181视频流媒体服务器4G摄像头视频无插件直播方案对接过程中前端设备正常上线但视频无法播放问题解决
  15. Grbl limit.c代码分析
  16. html中的 语言设置
  17. 腾讯手游助手android文件夹,腾讯手游助手中找到文件安装目录位置的详细操作方法...
  18. java—set创建迭代器的两个方法
  19. 099 复习:中值定理习题之型二:有ξ,有a,b ,型三: 有ξ,η
  20. 被这5个资源网站惊到了!老司机秒懂!

热门文章

  1. svn 小乌龟没有详细日志
  2. 计算机图形学【1】基础概念,图片格式及C++实现
  3. quagga安装配置
  4. Reqtify需求追踪中遇到SCADE ALM GateWay问题
  5. 适合拼多多小商家配件的一些思路跟技巧
  6. cs231n_two_layer_net
  7. 【CS231n】Two Layer Neural Network 代码实现
  8. java 添加gif图片_一个简单的数据库插入gif图片,帮我看看哪里不对
  9. 关于AIR724UG连入Tlink云平台的后续(完成)
  10. 前端技术搭建五子棋游戏(内含源码)