免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4026 | 回复: 7

exec 标准输出 [复制链接]

论坛徽章:
2
IT运维版块每日发帖之星
日期:2016-02-10 06:20:01IT运维版块每日发帖之星
日期:2016-02-11 06:20:00
发表于 2010-11-01 14:16 |显示全部楼层
我想让脚本输出的所有标准输出指定到log文件中,同时在终端执行的时候也能看到输出信息

脚本如下:

  1. #!/bin/bash
  2. exec 1>/tmp/log
  3. echo hello
复制代码
这样可以将hello写入到/tmp/log中,但是在终端下没有输出

脚本2,用tee实现

  1. #!/bin/bash
  2. exec 1>/tmp/log|tee
  3. echo hello
复制代码
运行结果虽然能在终端中输出hello,但是却没有输出内容到/tmp/log

有没有两全奇美的方法,又保存了输出内容,又能在终端输出?

论坛徽章:
0
发表于 2010-11-01 14:28 |显示全部楼层
  1. [oracle@s12071 ~]$ echo "12346" | tee test
  2. 12346
  3. [oracle@s12071 ~]$ cat test
  4. 12346
  5. [oracle@s12071 ~]$
复制代码

论坛徽章:
0
发表于 2010-11-01 14:29 |显示全部楼层
回复 1# nxlinux


    如果不需要在同一个终端显示的话,在另外一个终端用tail -f /tmp/log查看输出

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
发表于 2010-11-01 14:35 |显示全部楼层
exec > >(tee -a /tmp/log)

论坛徽章:
0
发表于 2010-11-01 14:45 |显示全部楼层
>( )

> >()

有什么区别 怎么解释呢

论坛徽章:
2
IT运维版块每日发帖之星
日期:2016-02-10 06:20:01IT运维版块每日发帖之星
日期:2016-02-11 06:20:00
发表于 2010-11-01 14:47 |显示全部楼层
回复 4# waker


    怎么出现语法错误了?

论坛徽章:
0
发表于 2010-11-01 14:51 |显示全部楼层
回复 3# feiliang1983

exec 1>/tmp/log
指令负责将原进程的标准输出定位到文件/tmp/log;
exec之后的进程作为exec的子进程执行

exec 1>/tmp/log | tee
exec 没有执行任何指令,exec 1>/tmp/log作为bash的一个子进程执行,tee作为bash的另一个子进程执行;exec之后的进程仍作为bash进程的子进程执行,
也就是说exec指令没有起到预期的作用;

为了同时将进程的标准输出输出到屏幕和日志文件,首先需要保证子进程的输出能够打印到屏幕,所以exec 1>/tmp/log是不可取的;
你可以考虑采用第二个进程辅助查看/tmp/log日志或者不使用直接打印所有输出到屏幕,并用tee命令
echo hello | tee /tmp/log

论坛徽章:
0
发表于 2010-11-01 14:53 |显示全部楼层
回复 4# waker


    好使,待解
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP