今天给大家分享一个 shell 脚本工具,通过 shell 脚本与 mysql 的结合,将某个具体服务的错误输出日志入库到指定的 mysql 表中,以便于进行错误问题的定位与分析。...日常工作中,经常需要和 linux 系统打交道,例如:服务部署、日志和服务状态查看等,而 shell 脚本是和 linux 交互的一种常见方法。...以下代码实例为在 shell 脚本中嵌入 mysql 配置信息将错误日志信息落入到数据库中。 shell脚本如下: #!...echo "***********start*************" echo $insert_sql #开始执行sql语句 mysql...脚本中关键信息都标有对应的注释,如需实操,可将 mysql 对应的配置信息及监控的日志服务路径进行更改和替换为目标信息即可。
INFO,所以所有的日志信息均输出出来了。...默认情况下,logging模块将日志打印到屏幕上(stdout),日志级别为WARNING(即只有日志级别高于WARNING的日志信息才会输出),日志格式如下图所示: ?...打印当前执行程序名称 %(funcName)s 打印日志的当前函数 %(lineno)d 打印日志的当前行号 %(asctime)s 打印日志的时间 %(thread)d 打印线程id %(threadName...%(pathname)s 调用日志输出函数的模块的完整路径名,可能没有 %(filename)s 调用日志输出函数的模块的文件名 %(module)s 调用日志输出函数的模块名...,保留最近30天的日志文件。
SQL语句写Shell 满足条件: mysql的配置文件 my.ini 中,secure_file_priv 为空或者secure_file_priv 配置是目录地址。...未开启全局GPC 关于mysql的secure_file_priv属性得多说几句 当secure_file_priv为空时,mysql对导入导出文件是没有限制的 当secure_file_priv为目录地址时...,mysql可以在目录位置下 进行导入导出操作,当secure_file_priv为NULL时,mysql就不能进行导入导出操作 union select 后写入 在union select 后拼接 into...dumpfile 和 into outfile 来进行写shell ?...>' INTO OUTFILE '/var/www/shell.php'; 使用方法:http://localhost/shell.php?
有时候在渗透测试过程中 我们会得到php myadmin 的账号和密码 既然登陆了php myadmin 就可以用php myadmin 来get shell。...简单说明 登陆进php myadmin 有些朋友可能会直接选择去写入一个webshell 执行后会弹出大概无法写入的意思 这里和php myadmin的设置有关系 在实战情况下一般都不能直接去写入一个shell...这时候我们需要换个思路 利用mysql 错误日志写入一句话 这里需要先设置 general log (日志保存状态)general log file(日志保存路径) 先执行 show variables...执行完后因为我是本地搭建环境所以可以看到成功创建了 现在我们只需要输入一个错误的sql语句即可 这里我写入一句话 可以看到一句话已经存在于infos.php里面了 之后我们菜刀直接链接即可 总结 网上有许多相关的文章 不过自己写一遍印象才会更深刻吧
最近在做一个Linux系统方案的设计,写了一个之前升级服务程序的配置和日志管理。...而执行脚本就写具体如何实施,包括,显示时间,执行程序,重定向等。 具体笔记如下: 01. 脚本读取另一个脚本,用了两种方法: ....02. shell中系统时间显示方法: date "+%F %H:%M:%S" C语言中可以用如下显示: time_t now ; struct tm *tm_now ; time(&now) ; tm_now...经过测试,在Linux中,c语言编译出来的程序不像shell脚本那样一行一行的执行,实时显示,而printf的输出原理是利用缓冲区输出stdout,在终端输出情况下,它是行输出模式,也就是说遇到换行符就输出
Python调用Shell命令 os.system os.system函数与系统编程中的exec族函数调用一致,创建出子进程后代码段由外部程序替换,不会返回外部程序运行结果。...subprocess improt call # 可以将命令和参数以列表的形式传入 code = call(['ls', '-l', '-a']) # 也可以用字符串作为传入的参数(通过设置参数shell...=True) code = call('ls -l -a', shell=True) 文件操作API 创建文件 import os # touch a.c file = open('a.c', 'w'
工作学习中,shell脚本是日常基本需求,你印象中的脚本应该是这样的:命令的堆砌、从上到下依次执行、杂乱无章、实现功能就行,导致自己写的脚本自己都不想看,今天我就教你怎么写脚本,学完之后,一定会说一句,...脚本还能这么写!...,命令的堆砌,这就导致脚本复用性差,不易维护,解决这问题的关键在于函数化、模块化思想,shell虽然是一种比较简单的语言,但语言基本的逻辑控制、函数功能都有,这就让我们编写高质量shell脚本充满了想象...reload } # main在此需要获取脚本本身的参数, 故将$@传递给main函数 main $@ 4.函数返回值 在其他编程语言,可以通过return获取函数的返回值,但是return语句在shell...,需要两条命令,在一定条件下,一起执行,类似于事务的概念,这就要通过()来实现,括号中的命令将会新开一个子shell顺序执行,所以括号中的变量不能够被脚本余下的部分使用。
文章目录 一.任务计划 1.一次性调度执行——at 2.循环调度执行——cron 3.符号说明 4.使用实例 二.日志管理 rsyslogd配置文件 rules规则 三.日志轮转程序logrotate...Linux11任务计划,日志管理 一.任务计划 1.一次性调度执行——at #at 时间 eg.两分钟后执行以下指令 at执行后可以设置多条命令,ctrl+d退出 2.循环调度执行——cron...一般存放在/var/log/… 1.日志管路进程rsyslog——产生日志进程 什么程序-做了什么事-记录到什么位置 如果没有这个进程要安装#yum install -y rsyslog 然后再启动...#systemctl start rsyslog 其配置文件是rsyslogd 2.系统日志文件/var/log/里面的文件基本后缀都为.log 系统主日志文件/var/log/message 用于记录大多数系统的操作...此时再开一个终端执行watch命令,就可以实时看到日志文件的变化 ---- tail /var/log/secure ——认证安全相关的日志 tail /var/log/yum.log ——yum相关的日志
背景 服务器有敏感数据,不允许直接登陆服务器查看日志文件,也不允许使用如ELK等日志功能收集日志,所以只能使用最简单的办法,只将错误日志进行收集,然后通过应用的webhook进行收集。...思路 两种思路: 周期轮询 实时抓取 周期轮询 每隔一分钟去抓取一次,错误日志的内容上送webhook。 这样的好处是不会抓到过多的错误日志,但是也有个问题,有可能会错过关键的错误日志。...另外脚本尽量使用python而不是shell,python更好维护,也利于扩展。写shell是因为历史原因。...exclude.txt SLACK=https://hooks.slack.com/services/test_webhook LOG_DIR=/Users/liukai/workspaces/temp/shell...echo $message | sed s/\'//g` #echo "$IP,$(date),$line" >> /Users/liukai/workspaces/temp/shell
MySQL 也不例外。...日志分类 错误日志 二进制日志 查询日志 慢查询日志 错误日志 错误日志是 MySQL 中最重要的日志之一,它记录了当 mysqld 启动和停止时,以及服务器在运行 过程中发生任何严重错误时的相关信息...该日志是默认开启的 , 默认存放目录为 mysql 的数据目录, 默认的日志文件名为 hostname.err(hostname是主机名)。...此日志对于灾难时的数据恢复起着极其重要的作用,MySQL的主 从复制, 就是通过该binlog实现的。...二进制日志,MySQl8.0默认已经开启,低版本的MySQL的需 要通过配置文件开启,并配置MySQL日志的格式。
当我们利用TraceSource记录某条跟踪日志时,日志消息会分发给注册的每一个TraceListener并由它们将日志消息写到对应的目的地。...具体来说,SourceSwitch定义了相应的过滤条件来帮助TraceSource决定是否应该将跟踪日志分发给TraceListener,如果指定的日志消息不满足过滤条件,TraceSource将不会进行任何实质性的日志记录工作...,它仅仅将日志的写入请求分发给注册的TraceListener并委托它们来完成写日志的功能。..."System.Text.Encoding.CodePages": "4.0.1" 6: } 7: } 由于TraceSource总是利用注册在它上面的TraceListener来完成写日志的工作...,需要指定追踪日志的事件类型,该类型由提供的日志等级来决定,下表展示了日志等级与跟踪事件类型之间的映射关系很简单。
因为最近下班前都要拿机子搞压测,所以这段时间对shell脚本比较感兴趣,用chatGPT写shell脚本很方便。...如下是一些案列 比如我需要写一个批处理:写一个批处理在当前文件夹下建立20个文件夹每个文件夹里面有一个文本文档文本文档的第一句话是hello word 将下面代码保存为create_folders.bat...是不是非常方便~~ 如果想把文件夹重命名,比如:写一个批处理将目录下所有文件夹重名为1.2.3.4等形式 @echo off setlocal enabledelayedexpansion set...按照刚刚的步骤,再新建一个txt文档,copy进去,保存再重命名运行就好 不过我一般都在linux下写.sh后缀的脚本,他们之间的区别如下: .sh和.bat是不同操作系统中脚本文件的后缀名,它们有以下区别...Shell脚本是一种文本文件,包含一系列用于执行命令和控制流程的Shell命令。通常使用Bash或其他Shell解释器来执行.sh脚本文件。
因为我不想使用自己写文件,我的软件是绿色的,所以把日志写到 Windows 日志。 首先告诉大家什么是系统日志,请看下面,这就是我要告诉大家的日志。写在这里就把日志放在 系统日志那里,看起来很厉害。...,程序一般都是写到程序 写日志 如果已经创建了日志事件,那么继续来写入日志就不需要管理员权限了。...所以在安装程序的过程创建日志就可以让程序不需要再写入日志时需要管理员权限。...,可以传入日志类型,是成功、失败还是其他。...还可以传入 id ,通过id 可以找到为什么需要写日志,不过需要在自己定义,还可以添加附件,于是我就不需要自己写文件日志。 ? ----
在写的时候,SQLite将之写入到WAL文件中即可,但是必须保证独占写入,因此写写之间不能并行执行。 ...WAL(write-ahead log,预写式日志)文件格式(1) WAL(write-ahead log,预写式日志)文件格式(2) Write-Ahead Transaction Log
因为我不想使用自己写文件,我的软件是绿色的,所以把日志写到 Windows 日志。 首先告诉大家什么是系统日志,请看下面,这就是我要告诉大家的日志。写在这里就把日志放在 系统日志那里,看起来很厉害。...,程序一般都是写到程序 写日志 如果已经创建了日志事件,那么继续来写入日志就不需要管理员权限了。...所以在安装程序的过程创建日志就可以让程序不需要再写入日志时需要管理员权限。...,可以传入日志类型,是成功、失败还是其他。...还可以传入 id ,通过id 可以找到为什么需要写日志,不过需要在自己定义,还可以添加附件,于是我就不需要自己写文件日志。
/** * @author ZhangYi */ var LOGIN_WIN_STATE = 0;//多次调用且不关闭,会出现bug function g...
# MySQL 日志 错误日志 二进制日志 介绍 格式 查看 删除 查询日志 慢查询日志 # 错误日志 错误日志是 MySQL 中最重要的日志之一,它记录了当 mysqld 启动和停止时,以及服务器在运行过程中发生任何严重错误时的相关信息...在MySQL8版本中,默认二进制日志是开启着的,涉及到的参数如下: show variables like '%log_bin%'; -rw-r----- 1 mysql mysql 523...# 格式 MySQL服务器中提供了多种格式来记录二进制日志,具体格式及特点如下: 日志格式 含义 STATEMENT 基于SQL语句的日志记录,记录的是SQL语句,对数据进行修改的SQL都会记录在日志文件中...:ss" 之前产生的所有日志 也可以在mysql的配置文件中配置二进制日志的过期时间,设置了之后,二进制日志过期会自动删除。..., 如果没有指定, 默认的文件名为 host_name.log general_log_file=mysql_query.log 开启了查询日志之后,在MySQL的数据存放目录,也就是 /var/lib
前面我们说了shell分析日志常用指令,现在我们随ytkah一起看看shell日志分析进阶篇,假设日志文件为ytkah.log //统计不重复抓取数量 cat ytkah.log | awk '{print
我们平时查日志,在测试环境,日志文件只有几个的情况下,我们可以通过找时间接近的文件然后根据关键词定位报错位置,大不了都查一遍,这都可以忍受。...但是在实际的生产环境下,服务器集群部署,每天的日志非常多非常多,每台机器都会有几十个甚至多达上百个、数百个日志文件产生。遇到问题需要查询日志时,你会发现如果一个个文件去查,你会崩溃掉。...为了解决这种问题,大多数人会去编写shell脚本,用来检索日志文件,这样能筛掉很多无用文件,减轻查日志的工作量。...缩小报错文件范围,是查日志提高效率的前提。 下面这段代码是就是简单的筛选日志文件的shell脚本。如果你懂shell编程,可以在此基础上修改,添加你自己需要的功能。 #!...(与shell脚本同目录),然后我们对tmp下的日志进行操作。
数据分析对于网站运营人员是个非常重要的技能,日志分析是其中的一个。日志分析可以用专门的工具进行分析,也可以用原生的shell脚本执行,下面就随ytkah看看shell分析日志常用指令有哪些吧。...表示打印第一部分,就是ip uniq 是将重复行去掉, -c表示前面前面加上数目, sort -rn 就是按照数字从大到小排序, head -20取前面20行 你可能会喜欢:shell...日志分析进阶篇
领取专属 10元无门槛券
手把手带您无忧上云