Linux shell脚本输出日志笔记整理
2016-04-26 17:50
543 查看
1.日志方法简介:
#日志名称
log="./upgrade.log" #操作日志存放路径
fsize=2000000 #如果日志大小超过上限,则保存旧日志,重新生成日志文件
exec 2>>$log #如果执行过程中有错误信息均输出到日志文件中
#日志函数
#参数
#参数一,级别,INFO ,WARN,ERROR
#参数二,内容
#返回值
function zc_log()
{
#判断格式
if [ 2 -gt $# ]
then
echo "parameter not right in zc_log function" ;
return ;
fi
if [ -e "$log" ]
then
touch $log
fi
#当前时间
local curtime;
curtime=`date +"%Y%m%d%H%M%S"`
#判断文件大小
local cursize ;
cursize=`cat $log | wc -c` ;
if [ $fsize -lt $cursize ]
then
mv $log $curtime".out"
touch $log ;
fi
#写入文件
echo "$curtime $*" >> $log;
}
2.使用举例
shell脚本内容:
#! /bin/bash
#数据库变量
localpasswd=xxxx
mysqlhost=xxxx
mysqluser=xxxx
mysqlpasswd=xxxx
#日志名称
log="./upgrade.log" #操作日志存放路径
fsize=2000000
exec 2>>$log #如果执行过程中有错误信息均输出到日志文件中
#日志函数
#参数
#参数一,级别,INFO ,WARN,ERROR
#参数二,内容
#返回值
function zc_log()
{
#判断格式
if [ 2 -gt $# ]
then
echo "parameter not right in zc_log function" ;
return ;
fi
if [ -e "$log" ]
then
touch $log
fi
#当前时间
local curtime;
curtime=`date +"%Y%m%d%H%M%S"`
#判断文件大小
local cursize ;
cursize=`cat $log | wc -c` ;
if [ $fsize -lt $cursize ]
then
mv $log $curtime".out"
touch $log ;
fi
#写入文件
echo "$curtime $*" >> $log;
}
echo "start update shell" ;
mysql -h$sqlip -u$sqluser -p$sqlpasswd -e "use $db;
set names gbk;
--
-- 表的结构 msgm_qdjyly
--
DROP TABLE IF EXISTS msgm_qdjyly;
CREATE TABLE IF NOT EXISTS msgm_qdjyly (
jylyid int(11) NOT NULL AUTO_INCREMENT COMMENT '主键id',
jylb varchar(20) DEFAULT NULL COMMENT '交易类别',
jylbmc varchar(50) DEFAULT NULL COMMENT '交易类别名称',
jgm varchar(10) NOT NULL COMMENT '机构码',
lyfs int(11) NOT NULL COMMENT '路由方式,1指定渠道,2按卡bin渠道',
qdbh varchar(20) DEFAULT NULL COMMENT '渠道编号',
qdmc varchar(50) DEFAULT NULL COMMENT '渠道名称',
zt int(11) NOT NULL DEFAULT '1' COMMENT '状态,1正常,2关闭',
bz varchar(100) DEFAULT NULL COMMENT '备注',
PRIMARY KEY (jylyid)
) ENGINE=InnoDB DEFAULT CHARSET=gbk COMMENT='交易路由信息' AUTO_INCREMENT=7 ;
zc_log INFO "执行 CREATE TABLE msgm_qdjyly 命令的结果为 : $? " ;
echo "执行 CREATE TABLE msgm_qdjyly 命令的结果为 : $? " ;
#日志名称
log="./upgrade.log" #操作日志存放路径
fsize=2000000 #如果日志大小超过上限,则保存旧日志,重新生成日志文件
exec 2>>$log #如果执行过程中有错误信息均输出到日志文件中
#日志函数
#参数
#参数一,级别,INFO ,WARN,ERROR
#参数二,内容
#返回值
function zc_log()
{
#判断格式
if [ 2 -gt $# ]
then
echo "parameter not right in zc_log function" ;
return ;
fi
if [ -e "$log" ]
then
touch $log
fi
#当前时间
local curtime;
curtime=`date +"%Y%m%d%H%M%S"`
#判断文件大小
local cursize ;
cursize=`cat $log | wc -c` ;
if [ $fsize -lt $cursize ]
then
mv $log $curtime".out"
touch $log ;
fi
#写入文件
echo "$curtime $*" >> $log;
}
2.使用举例
shell脚本内容:
#! /bin/bash
#数据库变量
localpasswd=xxxx
mysqlhost=xxxx
mysqluser=xxxx
mysqlpasswd=xxxx
#日志名称
log="./upgrade.log" #操作日志存放路径
fsize=2000000
exec 2>>$log #如果执行过程中有错误信息均输出到日志文件中
#日志函数
#参数
#参数一,级别,INFO ,WARN,ERROR
#参数二,内容
#返回值
function zc_log()
{
#判断格式
if [ 2 -gt $# ]
then
echo "parameter not right in zc_log function" ;
return ;
fi
if [ -e "$log" ]
then
touch $log
fi
#当前时间
local curtime;
curtime=`date +"%Y%m%d%H%M%S"`
#判断文件大小
local cursize ;
cursize=`cat $log | wc -c` ;
if [ $fsize -lt $cursize ]
then
mv $log $curtime".out"
touch $log ;
fi
#写入文件
echo "$curtime $*" >> $log;
}
echo "start update shell" ;
mysql -h$sqlip -u$sqluser -p$sqlpasswd -e "use $db;
set names gbk;
--
-- 表的结构 msgm_qdjyly
--
DROP TABLE IF EXISTS msgm_qdjyly;
CREATE TABLE IF NOT EXISTS msgm_qdjyly (
jylyid int(11) NOT NULL AUTO_INCREMENT COMMENT '主键id',
jylb varchar(20) DEFAULT NULL COMMENT '交易类别',
jylbmc varchar(50) DEFAULT NULL COMMENT '交易类别名称',
jgm varchar(10) NOT NULL COMMENT '机构码',
lyfs int(11) NOT NULL COMMENT '路由方式,1指定渠道,2按卡bin渠道',
qdbh varchar(20) DEFAULT NULL COMMENT '渠道编号',
qdmc varchar(50) DEFAULT NULL COMMENT '渠道名称',
zt int(11) NOT NULL DEFAULT '1' COMMENT '状态,1正常,2关闭',
bz varchar(100) DEFAULT NULL COMMENT '备注',
PRIMARY KEY (jylyid)
) ENGINE=InnoDB DEFAULT CHARSET=gbk COMMENT='交易路由信息' AUTO_INCREMENT=7 ;
zc_log INFO "执行 CREATE TABLE msgm_qdjyly 命令的结果为 : $? " ;
echo "执行 CREATE TABLE msgm_qdjyly 命令的结果为 : $? " ;
相关文章推荐
- Mysql 数据库升级shell脚本编写与测试心得
- xshell 中 alt+. 快捷键无法使用
- HELL编程-shell编程实战
- linux关于bashrc与profile的区别(转)
- HBase 常用Shell命令
- hbase shell基础和常用命令详解
- shell基础语法
- Shell中遍历整个目录查找某个关键字
- 改变当前shell工作目录
- shell------随机产生三位数
- shell 查看当前目录下文件的个数
- shell学习随笔
- shell 判断一个变量是否为空
- 使用Powershell批量设置Exchange 2013 虚拟目录URL
- 十一.Shell编程之运算符
- 十.Shell编程之变量
- shell 之 grep 控制显示关键字的 上下行数和不区分大小写
- HoloLens开发手记 - HoloLens shell概述 HoloLens shell overview
- shell除法保留两位小数
- shell命令练习 20160425