摘要
crontab 是一个用于设置周期性执行任务的工具。目前服务器端的运行环境大多数为 Linux,在日常的运营和维护中会有很多需要定期执行的操作,其中有些操作是可以机械的定期执行的操作,所以我们可以使用 crontab 定时服务来设置定时任务,从而减少手动操作的任务,帮助提高工作效率。
# 清除yum缓存
yum clean all
# 更新系统的安装包到最新版本
yum update
# 安装cron服务和crontab工具[-y表示yes,没有的话需要手动输入yes]
yum install -y cronie crontabs
# 检查cond服务是否安装及启动:
yum list cronie && systemctl status crond
# 检查crontab工具是否安装:
yum list crontabs && which crontab && crontab -l
# 1.新建|编辑定时任务
crontab -e
# 2.查看定时任务列表[当前用户(root)保存的计划任务]
crontab -l
#或
cat /var/spool/cron/root
# 3.重启crond进程
systemctl restart crond
# 4.查看crond状态
systemctl status crond
* * * * * [username] my command
分 时 日 月 周 [执行用户名] 要运行的命令
0-59 0-23 1-31 1-12 0-6
* 取值范围内的所有数字
/ 每
- 某个区间
, 几个数的集合
/etc/crontab
/var/spllo/cron/[目录]
root:/var/spppl/cron/root[文件]
user01:/var/spppl/cron/user01[文件]
# 创建用户
useradd user01
# 使用指定用户登陆系统
su - user01
PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/jdk1.8.0_111/bin
# 可以直接在定时任务文件使用java程序
# [系统级别环境变量]
30 2 * * * source /etc/profile;sh /root/test.sh
# [用户级别环境变量]
30 2 * * * source ~/.bash_profile;sh /root/test.sh
# /etc/profile 或者 /root/.bash_profile
PATH=$PATH:/usr/local/jdk1.8.0_111/bin
export PATH
# /root/test.sh
java -version 2> /root/script.out
# 先使/etc/profile生效[添加环境变量],后使用sh执行脚本文件
* * * * * source /etc/profile;sh /root/test.sh
* * * * * source /root/.bash_profile;sh /root/test.sh
/var/log/cron
文件中# 查看最近的两条cron日志
tail -n 2 /var/log/cron
/var/log/messages
# /var/log目录下日志[平时主要用到的日志文件]
cron -- 定时任务日志
secure -- 相关ssh服务日志
messages -- 系统总日志
firewalld -- 系统防火墙日志
lastlog -- 登录日志
# 查看当前目录下所有文件的大小
du -sh .
# 清空系统日志 [/dev/null代表一个空文件]
* 1 * * * cat /dev/null > /var/log/messages
/root/log_clean.sh
#!/bin/sh
cat /dev/null > /var/log/messages
cat /dev/null > /var/log/secure
# 定时执行日志清理脚本
* * * * * sh /root/log_clean.sh
backup -- 备份文件存放目录
script -- 脚本文件目录
www --- 网站根目录
#!/bin/bash
basedir = /data/backup
www_src = $basedir/www_src/$(date +%F_%H%M)
[ ! -d "$www_src" ] && mkdir -p $www_src
cd /data
tar -jpcf $www_src/www.tar.bz2 www
basedir = /data/backup
定义一个变量,名称为basedir
,值为/data/backup
$(date +%F_%H%M)
获取系统的日期时间,并拼上日期(%F),再拼上小时(%H)和分钟(%M) =》 [2018-03-16_0715]
www_src = $basedir/www_src/$(date +%F_%H%M)
使用变量 basedir 的值,再拼接出多层目录,赋值给 www_src[值为/data/backup/www_src/{当前日期时间的目录(动态)}]
[ ! -d "$www_src" ]
相当于 if 的判断,判断$www_src 是否不是一个目录
tar -jpcf $www_src/www.tar.bz2 www
打包/data/www 目录为 www.tar.bz2,并放置到$www_src 目录下[/data/backup/www_src/{当前日期时间的目录(动态)}/]
* * * * * sh /data/script/www_backup.sh
systemctl restart crond
# /data/backup/www_src/2018-03-16_0715/
8.4M www.tar.bz2
DDOS 攻击或匿名暴力破解导致系统无法正常访问
使用 crontab 集成 iptables,实时监控系统的网络状态,及时将可疑的 ip 地址加入到网络黑名单
iptables 作为 Linux 下的内核防火墙,能够通过添加相应的规则,检测、修改、重定向、转发和丢弃 ip 数据包,从而过滤网络数据,实现保护系统网络的功能
CentOS7 默认使用 firewalld 服务维护内核防火墙,我们需要禁用 firewalld 服务,并安装 iptables 作为系统默认防火墙。
# 查看当前firewalld进程状态
systemctl status firewalld
# 关闭并禁用firewalld
systemctl disable firewalld
systemctl stop firewalld
# 安装iptables服务
yum install iptables-services
[yes]
# 开启iptables服务
systemctl enable iptables
# 启动iptables服务
systemctl start iptables
# 验证iptables是否安装成功
iptables -V
#!/bin/bash
iptables -F
list = /data/script/blacklist.txt
for line in `cat $list`;do
iptables -I INPUT -s$line -j DROP
echo "$line is dropped into blacklist"
done
iptables -F
清空 iptables 的所有记录
cat $list
;do对/data/script/blacklist.txt 循环输出每一行
iptables -I INPUT -s$line -j DROP
添加一个 input 链 -s 相当于 source,将每一行的数据,传递给 iptables -j DROP 相当于一个 drop 操作,将当前主机接收到的数据包进行一个丢弃操作 =》将 blacklist.txt 中的 ip 地址做一个拒绝访问的操作,使黑名单中的 ip 地址无法访问主机
echo "$line is dropped into blacklist"
对每一行的 ip 地址拒绝访问后,输出一条信息提示
* * * * * source /etc/profile; sh /data/script/firewall.sh
iptables -nvL
java编写的开源、持续、集成工具,最大优势就是将开发人员和运维人员完美的结合在一起。
# 安装
yum install jenkins
[y]
# 查看系统java路径
which java
# 查看系统java版本
java -version
[jenkins 要求的最低版本要求配置>1.8.0_111]
[=>搜索 candidates 关键词] 默认调用的 java 目录是/usr/bin/java 和/usr/lib/jvm/***/bin/java
添加 java 的路径
/usr/local/jdk1.8.0_111/bin/java
#启动jenkins服务
systemctl start jenkins
# 查看jenkins服务是否正常启动,并查看jenkins服务是否打开8080端口监听服务
lsof -i:8080
# 1.访问jenkins的后台地址
10.110.16.5:8080
# 2.登录密码保存在系统的目录下
/var/lib/jenkins/secrets/initialAdminPassword文件中
# 3.自定义jenkins=》安装插件
# 4.创建第一个管理员用户
# 5.创建新任务
1)构建自由风格的软件项目
2)构建触发器 => Build Periodically => 日程表[相当于crontab定时任务的时间表单] => * * * * *
3)构建 => 增加构建步骤 => Execute shell => Command[执行定时任务时执行的操作] => echo "this is a test build"
【学习参考】:慕课网-Crontab 不知疲倦的时间表