首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

用日志记录Linux用户执行一条命令(history)

工作中,需要把用户执行的每一个命令都记录下来,并发送到日志服务器的需求,为此我做了一个简单的解决方案。...这个方案会在每个用户退出登录时把用户所执行的每一个命令都发送给日志守护进程rsyslogd,你也可通过配置“/etc/rsyslog.conf”进一步将日志发送给日志服务器 第一种方法 # vi /etc...HISTTIMEFORMAT="[%Y-%m-%d %H:%M:%S] [`who am i 2>/dev/null| awk '{print $NF}'|sed -e 's/[()]//g'`] " #记录shell执行一条命令...=====下面是第二种方法,较笨===== 第一步:全局设置(这是一次性设置,需要root用户权限) 命令# vi /etc/profile #用户登录时执行此脚本 #设置history显示格式 export..." > .bash_history 第二步:不同用户分别设置 命令# source /etc/profile 命令# vi /home/user1/.bash_logout #当用户退出登录时会执行此脚本

2.7K50

MySQL- SQL执行计划 & 统计SQL执行阶段的耗时

请求的过程, 我们来看下 MySQL处理SQL请求的过程 客户端将SQL请求发送给服务器 服务器检查是否在缓存中是否命中该SQL,未命中的话进入下一步 服务器进行SQL解析、预处理,再由优化器生成对应的执行计划...根据执行计划来,调用存储引擎API来查询数据 将结果返回给客户端 ---- 查询缓存对SQL性能的影响 query_cache_type:设置查询缓存是否可用 , 可选值 ON OFF DEMAND...接着上一步说,查询缓存未启用,或者 未命中查询缓存 , 服务器进行SQL解析、预处理,再由优化器生成对应的执行计划 。...MySQL会依赖这个执行计划和存储引擎进行交互 . 包括以下过程 语法解析: 包含语法等解析校验 预处理 : 检查语法是否合法等 执行计划: 上面都通过了,会生成执行计划。...---- 造成MySQL生成错误的执行计划的原因 存储引擎提供的统计信息不准确 执行计划中的估算不等同于实际的执行计划的成本 MySQL不考虑并发的查询 MySQL有时候会基于一些特定的规则来生成执行计划

2.8K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    踩坑记录-crontab10秒执行一次

    写在前面,记录一个linux小白使用crontab中遇到的各种坑及解决思路方法。网上帖子千千万,坑也是千千万。记录下,分享给大家。...需求:linux中使用crontab十秒执行一次 场景:需要在ubuntu14服务器中使用代理十秒执行一次curl来访问互联网,来测试代理网络稳定性。...然后,任务没有执行就一直纠结任务没有执行这个问题。 坑2.ubuntu系统第一次使用crontab -e 需要选择比编辑器,如果选nano上,对我这种小白可就蒙圈。...cc.sh >>/usr/local/log.txt 2>&1* * * * * sleep 20; /usr/local/cc.sh >>/usr/local/log.txt 2>&1 如果都写上的话就是十秒执行一次啦...>/dev/null 缺省默认是1 即 1>/dev/null 2,linux中有三种标准输入输出,分别是STDIN,STDOUT,STDERR,对应的数字是0,1,2 2>&1就是把2错误输出重定向到

    6.3K30

    Linux命令执行过程

    一.命令分类 Linux命令分为两类,具体为内部命令和外部命令 内部命令: 指shell内部集成的命令,此类命令无需人为安装,开机后自动运行在内存中,命令help查看所有内部命令的详情,如cd、type...命令查看: type查看命令分类,内部命令显示 shell相关信息,外部命令则显示$PATH路径 二.命令执行顺序 命令形态主要分为4类:alias别名命令、内部命令、hash缓存命令和外部命令。...ls命令执行过程: 下面进行简单分析: 1、shell不断询问是否有键盘输入,用户以enter结束键盘输入后,shell程序以空格为分隔符,得到”ls”,”-l”,”*.c”,三个字符串。...4、ls程序执行后,会分析argc和argv,”-l”表示这是一个选项开关,表明用户想得到文件的详细信息,并把这个开关量保存,以便最后输出的时候选择信息的格式。...5、ls执行完既定的步骤后,退出并返回退出码,若成功则返回0,否则根据错误的不同返回不同的非零数字。 6、shell在得到成功退出码后,继续等待用户输入。

    4.5K30

    Linux命令执行过程

    一.命令分类 Linux命令分为两类,具体为内部命令和外部命令 内部命令: 指shell内部集成的命令,此类命令无需人为安装,开机后自动运行在内存中,命令help查看所有内部命令的详情,如cd、type...命令查看: type查看命令分类,内部命令显示 shell相关信息,外部命令则显示$PATH路径 二.命令执行顺序 命令形态主要分为4类:alias别名命令、内部命令、hash缓存命令和外部命令。...ls命令执行过程: 下面进行简单分析: 1、shell不断询问是否有键盘输入,用户以enter结束键盘输入后,shell程序以空格为分隔符,得到”ls”,”-l”,”*.c”,三个字符串。...4、ls程序执行后,会分析argc和argv,”-l”表示这是一个选项开关,表明用户想得到文件的详细信息,并把这个开关量保存,以便最后输出的时候选择信息的格式。...5、ls执行完既定的步骤后,退出并返回退出码,若成功则返回0,否则根据错误的不同返回不同的非零数字。 6、shell在得到成功退出码后,继续等待用户输入。

    4.6K30

    Linux开机执行指定shell

    目的:希望linux在开机或重启后第一时间启动部分服务或者执行特定脚本 1.需要在/etc/init.d/目录下建立对应的shell脚本,示例如下: 开机启动docker-compose中的所有容器 vi...kafka service daemon ### END INIT INFO docker-compose -f /root/docker/docker-compose.yml restart; 2.增加可执行权限...chmod +x /etc/init.d/kafka 3.查看默认执行级别    runlevel N 5  #这里表面本台电脑默认执行级别为 5 Linux有0~6共7个执行级别,不了解的同学赶紧了解下...4.在对应默认级别中建立软连接 ln -s /etc/init.d/kafka /etc/rc5.d/S01kafka 注意:S表示Start  K表示Kill  后面跟两位数字,数字越小越优先执行...另外为了防止出错,其实还有个建议,将需要执行的脚本放在/etc/rc.local中,系统在启动完成后最后会去执行里面的内容

    3K20

    Linux读写执行(RWX)权限

    执行权限(x) 表示该文件具有被系统执行的权限。...Window系统中查看一个文件是否为可执行文件,是通过扩展名(.exe、.bat 等),但在 Linux 系统中,文件是否能被执行,是通过看此文件是否具有 x 权限来决定的。...也就是说,只要文件拥有 x 权限,则此文件就是可执行文件。但是,文件到底能够正确运行,还要看文件中的代码是否正确。 对于文件来说,执行权限是最高权限。...把hh.c文件修改为可写可读可执行 chmod 777 hh.c 要修改某目录下所有的文件属性为可写可读可执行 目录 /tmp/sco修改为可写可读可执行 chmod 777 /tmp/sco...要修改/tmp/sco下所有的文件和文件夹及其子文件夹属性为可写可读可执行 chmod -R 777 /tmp/sco 权限设置 可写 w=4 可读 r=2 可执行 x=1 777就是拥有全权限

    4.7K10

    如何在 Linux X 秒运行一次命令?

    作为 Linux 用户,您经常需要在一段时间后重复运行某些命令,有时,您需要每小时或每隔 X 秒运行一次命令,这通常由系统管理员使用,但即使您是初学者,也可以使用它来自动执行任务、同步文件或安排更新等,...每隔几秒在 Linux 中运行命令 cron 命令不能用于每隔 X 秒运行一次命令,并且使用循环并不精确,watch 命令很容易使用。 在本文中,我们将详细讨论这三种方法。 1....使用 Cron 命令 每个用户都可以有一个 crontab,我们可以在其中创建和修改任务,但是,Cron 只能用于一分钟的最小间隔,即如果您想 X 秒运行一次命令,则不能使用 Cron。...默认情况下,它 2 秒显示一次输出。要设置不同的时间间隔,请输入以下命令: watch -n 30 uptime 这将以 30 秒的间隔运行 uptime 命令。...打开终端并使用 for 循环,执行以下命令: for 循环 for i in {1..8}; do echo -n "running the command $i time"; sleep 3; done

    3.1K20
    领券