时间:2021-05-22
cat /mnt/log_function.sh #!/bin/bash #log function####log_correct函数打印正确的输出到日志文件 function log_correct () { DATE=`date “+%Y-%m-%d %H:%M:%S”` ####显示打印日志的时间 USER=$(whoami) ####那个用户在操作 echo “${DATE} ${USER} execute $0 [INFO] $@” >>/var/log/log_info.log ######($0脚本本身,$@将参数作为整体传输调用) }
log_error打印shell脚本中错误的输出到日志文件
function log_error () { DATE=`date “+%Y-%m-%d %H:%M:%S”` USER=$(whoami) echo “\${DATE} \${USER} execute \$0 [INFO] \$@” >>/var/log/log_error.log }###fn_log函数 通过if判断执行命令的操作是否正确,并打印出相应的操作输出
function fn_log () { if [ $? -eq 0 ] then log_correct “$@ sucessed!” echo -e “\033[32m $@ sucessed. \033[0m” else log_error “$@ failed!” echo -e “\033[41;37m $@ failed. \033[0m” exit fi }知识点:
(1)$?判断执行命令的返回值,命令执行正确返回0,命令执行错误返回1
(2)”$@” 将执行命令 以一个参数的形式显示出来。
(3)echo -e “\033[32m $@ sucessed. \033[0m” 成功时以红色形式显示执行命令的内容。
(4)echo -e “\033[41;37m $@ failed. \033[0m” 失败时以绿色的形式显示执行命令的内容
(5)date “+%Y-%m-%d %H:%M:%S” 显示详细的日志时间(年月日时分秒)
调用日志函数脚本的执行脚本(log_correct log_error fn_log)
vi log_exec.sh #!/bin/sh if [ -e /mnt/log_function.sh ] then source /mnt/log_function.sh else echo -e “\033[41;37m /mnt/log_function.sh is not exist. \033[0m” exit 1 fiUSER=`whoami` if [ $USER == root ] then log_correct “execute by root” else log_error “execute by ${USER}” echo -e “\033[41;37m you must execute this scritp by root. \033[0m” exit 1 fiif [ -e /var/log/message ] then echo 0 > /var/log/message fn_log “echo 0 > /var/log/message” fi以上这篇输出执行操作和打印日志的shell脚本实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
shell脚本如何优雅的记录日志信息,下面让我们一步一步,让shell脚本的日志也变得高端起来,实现如下功能①设定日志级别,实现可以输出不同级别的日志信息,方便
Shell脚本:1、#!指定脚本执行的shell2、#注释3、命令或语法结构echo"输入内容"echo输出空行执行:1、shell脚本shexample2、给
前言很多shell脚本里面需要打印不同格式的时间或日期,以及要根据时间和日期执行操作。延时通常用于脚本执行过程中提供一段等待的时间。日期可以以多种格式去打印,也
log4j2支持日志的异步打印,日志异步输出的好处在于,使用单独的进程来执行日志打印的功能,可以提高日志执行效率,减少日志功能对正常业务的影响。异步日志在程序的
平常都使用console来打印node脚本执行时需要看到的信息,但这些信息也就只能在控制台查看。假如你希望将打印的信息输出到日志(log)文件查看的话,那就往下