Linux系统优化及定时任务
系统安全优化
关闭 selinux 安全服务
selinux(Security-Enhanced Linux)是美国国家安全局(NSA)对于强制访问控制的实现,这个功能让系统管理员又爱又恨,这里我们还是把它给关闭了吧,至于安全问题,后面通过其他手段来解决,这也是大多数生产环境的做法,如果非要开启也是可以的。
1 | #临时关闭 |
关闭 firewalld 防火墙
关闭防火墙的目的是为了让初学者学习更方便,将来在学了firewalld技术后可再统一开启。 在企业环境中,
一般只有配置外网IP的linux服务器才需要开启防火墙,但即使是有外网IP,对于高并发高流量的业务服务器
仍是不能开的,因为会有较大性能损失,导致网站访问很慢,这种情况下只能在前端加更好的硬件防火墙了。
1 | # 临时关闭 |
防止系统乱码优化
1 | en_US.UTF-8 : 美式英文,utf-8 |
定时任务
计划任务基本概述
1.什么是crond
- crond就是计划任务,类似于我们平时生活中的闹钟。定点执行。
2.为什么要使用crond
- crond主要是做一些周期性的任务,比如: 凌晨3点定时备份数据。比如:11点开启网站抢购接口,12点关闭网站抢购接口。
3.计划任务主要分为以下两种使用情况:
- 1.系统级别的定时任务: 临时文件清理、系统信息采集、日志文件切割
- 2.用户级别的定时任务: 定时向互联网同步时间、定时备份系统配置文件、定时备份数据库的数据
计划任务时间管理
1.Crontab配置文件记录了时间周期的含义
1 | [root@localhost ~]# vim /etc/crontab |
2.了解crontab的时间编写规范
1 | 00 02 * * * ls #每天的凌晨2点整执行 |
3.使用crontab编写cron定时任务
参数 | 含义 |
---|---|
-e | 编辑定时任务 |
-l | 查看定时任务 |
-r | 删除定时任务 |
-u | 指定其他用户 |
计划任务编写实践
1.使用root用户每5分钟执行一次时间同步
1 | #1.如何同步时间 |
2.每天的下午3,5点,每隔半小时执行一次sync命令
1 | [root@localhost ~]# crontab -l |
3.案例:每天凌晨3点做一次备份?备份/etc/目录到/backup下面
\1) 将备份命令写入一个脚本中
\2) 每天备份文件名要求格式: 2019-05-01_hostname_etc.tar.gz
\3) 在执行计划任务时,不要输出任务信息
\4) 存放备份内容的目录要求只保留三天的数据*
1 | #1.实现如上备份需求 |
4.crond注意的事项
\1) 给定时任务注释
\2) 将需要定期执行的任务写入Shell脚本中,避免直接使用命令无法执行的情况tar date
\3) 定时任务的结尾一定要有&>/dev/null或者将结果追加重定向>>/tmp/date.log文件
\4) 注意有些命令是无法成功执行的 echo “123” >>/tmp/test.log &>/dev/null
如果一定要是用命令,命令必须使用绝对路径
5.crond如何备份
\1) 通过查找/var/log/cron中执行的记录,去推算任务执行的时间
\2) 定时的备份/var/spool/cron/{usernmae}*
6.crond如何拒绝某个用户使用
1 | #1.使用root将需要拒绝的用户加入/etc/cron.deny |
计划任务如何调试
1.crond调试
\1) 调整任务每分钟执行的频率, 以便做后续的调试。
\2) 如果使用cron运行脚本,请将脚本执行的结果写入指定日志文件, 观察日志内容是否正常。
\3) 命令使用绝对路径, 防止无法找到命令导致定时任务执行产生故障。
\4) 通过查看/var/log/cron日志,以便检查我们执行的结果,方便进行调试。
2.crond编写思路
- 1.手动执行命令,然后保留执行成功的结果。
- 2.编写脚本
- 脚本需要统一路径/scripts
- 脚本内容复制执行成功的命令(减少每个环节出错几率)
- 脚本内容尽可能的优化, 使用一些变量或使用简单的判断语句
- 脚本执行的输出信息可以重定向至其他位置保留或写入/dev/null
- 3.执行脚本
- 使用bash命令执行, 防止脚本没有增加执行权限(/usr/bin/bash)
- 执行脚本成功后,复制该执行的命令,以便写入cron
- 4.编写计划任务
- 加上必要的注释信息, 人、时间、任务
- 设定计划任务执行的周期
- 粘贴执行脚本的命令(不要手敲)
- 5.调试计划任务
- 增加任务频率测试
- 检查环境变量问题
- 检查crond服务日志