详解Linux例行性工作

2024-03-10 13:44
文章标签 linux 工作 详解 例行

本文主要是介绍详解Linux例行性工作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

例行性工作(计划任务)

场景:

  • 生活中,我们有太多场景需要使用到闹钟,比如早上7点起床,下午4点开会,晚上8点购物,等等。
  • 再Linux系统里,我们同样也有类似的需求。比如我们想在凌晨1点将文件上传到服务器,或者在晚上10点确认系统状态,等等。
  • 但是我们不可能一直守在电脑前,毕竟我们也需要下班/睡觉,还要陪女朋友。而且即使在上班期间,如果到点了还需要人工操作,未免效率太低了。
  • at命令就是为这个需求而诞生的使用at命令,你可以在特定时间自动完成你所设定的任务,也可以实现自动化,非常方便快捷。

单一执行的例行性任务—at(一次性)

安装

使用yum安装at

[root@server ~]# yum install at
  • at命令一般默认安装在系统中,通过下列命令查看版本号
[root@server ~]# at -V
at version 3.1.23
  • 查看at执行的状态
[root@server ~]# systemctl status atd  # 查看状态
[root@server ~]# systemctl enable --now atd # 设置开机自启动

at命令详解

格式

at   日期时间

实例1

[root@server ~]# at 1:09
warning: commands will be executed using /bin/sh
at> ls /root > at.txt
at> <EOT>        # 按下ctrl+d退出at输入状态
job 2 at Tue Nov 14 01:09:00 2023 # job 1为工作编号
[root@server ~]# at  -l   # 浏览计划任务列表
[root@server ~]# atq    # 浏览计划任务列表[root@server ~]# ls     # 查看结果
公共  模板  视频  图片  文档  下载  音乐  桌面  anaconda-ks.cfg  at.txt
[root@server ~]# cat  at.txt 

参数

[root@server ~]# at -l
atq:等价于at  -l
[root@server ~]# at -c 8    # 列出任务后的命令内容(8为工作编号)
[root@server ~]# at -d 6    # 删除或取消一个任务(6为工作编号)

实例2

  • 不使用交互命令实现at任务
#从当前开始,经过1分钟后执行
[root@server ~]# echo "ls /root > at.txt" | at now +1 minutes
warning: commands will be executed using /bin/sh
job 11 at Tue Nov 14 01:45:00 2023
[root@server ~]# at -l
11      Tue Nov 14 01:45:00 2023 a root
工作编号            执行时的时间[root@server ~]# echo "rm -fr /root/at.txt" | at now +1 minutes
warning: commands will be executed using /bin/sh
job 12 at Tue Nov 14 01:46:00 2023
时间格式
参数说明
HH:MM今天HH小时的MM分钟执行,若时间错过则在明天执行
HH:MM YYYY-MM-DD规定在某年某月某日的特殊时间执行
now +数字 时间单词now +2 minutes
now +3 hours
now +4 days
now +5 weeks
表示从当前开始,经过多长时间后执行

注意

  • at命令只要指定的时间正确,就可以执行对应的命令
  • at命令的输出结果不会显示在屏幕上
  • at命令中执行的命令最好使用绝对路径,不容易报错
  • 过程:输入at 时间—>回车—>输入执行命令—>ctrl+d退出at编辑
  • 按ctrl+Backspace删除at命令行中的错误输入
  • at命令只会执行一次

at命令执行过程分析

  • 第一步:寻找/etc/at.allow(白名单)是否存在,写在该文件中的用户才可执行at命令
  • 第二步:若/etc/at.allow不存在,则寻找/etc/at.deny(黑名单)文件,写在该文件中的用户不能使用at命令
  • 第三步:若两个文件都不存在,则只用root可以使用at命令
  • 注意:若拒绝某用户使用at命令则可以将用户名写入到/etc/at.deny中

实例3

  • 设置某些账户不可使用at命令
[root@server ~]# useradd ce1   # 新建账户
[root@server ~]# passwd ce1   # 设置账户密码
更改用户 ce1 的密码 。
新的密码:
无效的密码: 密码少于 8 个字符
重新输入新的密码:
passwd:所有的身份验证令牌已经成功更新。
[root@server ~]# id ce1    # 查看账户信息
用户id=1001(ce1) 组id=1001(ce1)=1001(ce1)
[root@server ~]# vim /etc/at.deny  # 编辑黑名单
写入ce1
[root@server ~]# su ce1  # 切换账户
[ce1@server root]$ cd
[ce1@server ~]$ at 2:12
You do not have permission to use at.
[ce1@server ~]$ su root
密码:
[root@server ce1]# cd
[root@server ~]# vim /etc/at.deny
删除ce1
[root@server ~]# su -l ce1  # 切换账户(-l回到用户的家目录)
[ce1@server ~]$ at 2:14
warning: commands will be executed using /bin/sh
at> <EOT>
job 13 at Tue Nov 14 02:14:00 2023
[ce1@server ~]$ su -l root
密码:
[root@server ~]#

循环执行的例行性任务—crontab(周期性)

crond服务

  • at命令是在指定的时间只执行一次任务crontab命令可以循环重复的执行定时任务,与Windows中的计划任务有些类似
  • crond是Linux下用来周期地执行某种任务或等待处理某些事件的一个守护进程,在安装完成操作系统后,默认会安装crond服务工具,且crond服务默认就是自启动的,若需要安装则执行若下命令:
[root@server ~]# yum install crontabs
安装包名和服务包名不一样
[root@server ~]# systemctl status crond
  • crond进程每分钟会定期检查是否有要执行的任务,如果有,则会自动执行该任务,crontab命令需要crond服务支持
  • Linux任务调度的工作主要分为以下两类:
    • 系统执行的工作:系统周期性所要执行的工作,如备份系统数据,清理缓存等等
    • 个人执行的工作:某个用户定期要做的工作,例如每隔10分钟检查邮件服务器是否有信息,这些工作可由每个用户自行设置

crontab工作过程

  • 当系统中有 /etc/cron.allow文件时,只有写入此文件的用户可以使用crontab命令没有写入的用户不能使用crontab命令。同样,如果有此文件,/etc/cron.deny文件会被忽略,因为/etc/cron.allow文件的优先级更高
  • 当系统中只有/etc/cron.deny文件时,写入此文件的用户不能使用crontab命令,没有写入文件的用户可以使用crontab命令
  • crontab执行的每一项工作都会被记录到/var/log/cron这个日志文件中
  • 当用户使用crontab新建工作之后,该项工作就会被记录到/var/spool/cron目录里面

crontab命令详解

格式

crontab    [-u user]   [-l | -r | -e]

参数

参数说明
-u指定用户执行该任务
-e编辑crontab工作内容
-l查询crontab任务内容
-r删除crontab任务

编辑crontab

格式

crontab  -e

注意:

  • 写入的命令一行一个命令,每行共6段:前5段为时间,最后一段为命令
  • 时间共5段,意义如下:
表示意义星期
数字范围0-590-231-311-120-7(0和7都表示星期天)
特殊字符
*     表示任意时刻
-     表示范围
,      分割时段
*/数字      指定时间间隔频率,如:每3分钟执行一次:*/3
时间描述示例
1 2 * * *      每天凌晨2点1分执行动作
0 17 * * 1    每周1下午5点整执行动作
0 5 1,15 * *    每月的1日和15日凌晨5点整执行动作
40 4 * * 1-5     每周1到周5凌晨4点40分执行动作
*/10 4 * * *       每天凌晨4点每隔10分钟执行动作
3,15 8-11 */2 * *    每隔2天上午8-11点的第3分钟和第15分钟执行动作
* * * * *      每隔1分钟执行动作

实验1

  • 编写脚本test.sh(脚本必须以.sh为文件扩展名
[root@server ~]# vim test.sh
#!/bin/bash              (指定脚本解释器)while :
doecho  "this is my test sh"$(date)  >>  /root/cro.txtsleep 1
done
  • 设置周期性的计划任务
[root@server ~]# crontab -u redhat -e

默认当前用户

[root@server ~]# crontab  -e
*/1 * * * * /bin/bash  /root/test.sh

注意:crond服务会自动启动,crontab命令只要保存就会生效

  • 查看任务 -l
[root@server ~]# crontab  -l
*/1 * * * * /bin/bash  /root/test.sh
  • 删除任务 -r
[root@server ~]# crontab  -r    # 删除
[root@server ~]# crontab  -l    # 查看
no crontab for root
  • 此实验需要终止循环进程
[root@server ~]# ps -aux | grep test   # 查看已存在的test进程
root        3895  0.0  0.1 221680  2372 pts/0    S+   10:59   0:00 grep --color=auto test
[root@server ~]# kill  -9  进程号
[root@server ~]# kill  -9  3895   # 强制终止

实验2

  • 让系统每周1凌晨6点重启一次
[root@server ~]# crontab -e
0 6 * * 1    /sbin/shutdown -r now
[root@server ~]# crontab -l
0 6 * * 1 /sbin/shutdown -r now
  • 不想执行该任务可以删除
[root@server ~]# crontab -r
[root@server ~]# crontab -l
no crontab for root

实验3(重点)

实验内容:设置邮件发送功能:每1分钟发送1封邮件

  • 首先我们要做的就是QQ邮箱设置

1.使用浏览器打开qq邮箱,点击设置
在这里插入图片描述
2.点击账号
在这里插入图片描述
3.选择POP3/IMAP/SMTP/Exchange/CardDAV/CalDAV服务,然后开启服务,获得授权码
在这里插入图片描述
在这里插入图片描述

  • 安装邮件服务

注:不同发行版本的邮件服务名不一样,RHEL9的邮件服务名为s-nail

[root@server ~]# yum install s-nail -y
  • 配置邮件服务
[root@server ~]# vim /etc/s-nail.rc
set from=123456789@qq.com
set smtp=smtp.qq.com
set smtp-auth-user=123456789@qq.com
set smtp-auth-password=abcdefghijklmnop      # 这里是16位的授权码
set smtp-auth=login

注意:文件配置完毕需要强制保存并退出,末行模式下输入wq!

  • 测试一下邮件服务
[root@server ~]# echo '内容' | mail -s '主题' 123456789@qq.com

敲完这个命令后,在你的qq邮箱就会立刻收到邮件
在这里插入图片描述

  • 测试完成,我们再来设置周期性的任务,每个1分钟发送邮件
[root@server ~]# crontab -e
MAILTO=17674044@qq.com* * * * * echo  "警告,server服务器内存较低,请速处理."  |  mail  -s  "告警邮件"  123456789@qq.com

在这里插入图片描述

  • 实验完成之后,删除循环执行任务,不然你的qq邮箱得爆,哈哈哈
[root@server ~]# crontab -r
[root@server ~]# crontab -l
no crontab for root
书写定时任务得注意事项
  • 6个字段都不能为空,如果不确定则使用*表示任意时间
  • crontab命令任务的最小时间单位为分钟,最大有效时间为月,如:2024年某时执行、3点30分30秒这样的时间日期无法被识别
  • 定义时间时,日期和星期最好不要一起出现,由于都是以天为单位,非常让管理员混淆
  • 在定时任务中不能,不管是写命令还是在脚本中写命令,最好都用绝对路径,相对路径有时会报错

系统级别的计划任务(crontab的另一种计划任务)

crontab -e是每个用户都可以执行的命令,但是有时定时任务必须由系统执行,此时就需要编辑 /etc/crontab配置文件来实现

[root@server ~]# vim /etc/crontab
  • 仅能通过root定义,不可以使用普通账户身份去执行计划任务
  • 方法:在/etc/crontab最后一行新增计划任务即可
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root# For details see man 4 crontabs# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name  command to be executed
  • 分析:
    • SHELL=/bin/bash :指定系统使用哪个shell解释器去执行
    • PATH=/sbin:/bin:/usr/sbin:/usr/bin : 系统执行命令的搜索路径
    • MAILTO=root :表示执行任务的信息通过邮件发送给谁
    • MAILTO=root :表示执行命令的用户是谁
实验4

每天6:00将日志文件/var/log/messages文件进行备份,备份到/backup目录中,备份时需要将logfileYYYY-MM-DD-HH:MM:SS

[root@server ~]# mkdir  /backup[root@server ~]# vim  /etc/crontab
0 6 * * * root  /usr/bin/cp  /var/log/messages /backup/logfile`date  +\%Y-\%m-\%d-\%H:\%M:\%S` # 注意# 反引号``:表示将引起的内容识别为命令# 在crontab中%表示换行,需要增加转义符\进行转义

这篇关于详解Linux例行性工作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/794418

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念