crontab

用来提交和管理用户的需要周期性执行的任务
当安装完成操作系统后,默认会安装此服务工具,并且会自动启动crond进程,crond进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务。

-e:编辑该用户的计时器设置;
-l:列出该用户的计时器设置;
-r:删除该用户的计时器设置;
-u<用户名称>:指定要设定计时器的用户名称。

参数:crontab文件:指定包含待执行任务的crontab文件。

系统任务调度

系统周期性所要执行的工作,比如写缓存数据到硬盘、日志清理等
对应文件:/etc/crontab,初始内容

  1. SHELL=/bin/bash
  2. PATH=/sbin:/bin:/usr/sbin:/usr/bin
  3. MAILTO=root
  4. HOME=/
  5. # For details see man 4 crontabs
  6. # Example of job definition:
  7. # .---------------- minute (0 - 59)
  8. # | .------------- hour (0 - 23)
  9. # | | .---------- day of month (1 - 31)
  10. # | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
  11. # | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
  12. # | | | | |
  13. # * * * * * user-name command to be executed

第三行MAILTO变量指定了crond的任务执行信息将通过电子邮件发送给root用户,如果MAILTO变量的值为空,则表示不发送任务执行信息给用户
第四行的HOME变量指定了在执行命令或者脚本时使用的主目录

用户任务调度

用户定期要执行的工作,比如用户数据备份、定时邮件提醒等
文件目录:/var/spool/cron,所有用户定义的crontab文件
其文件名与用户名一致,使用者权限文件如下

  • /etc/cron.deny 该文件中所列用户不允许使用crontab命令

  • /etc/cron.allow 该文件中所列用户允许使用crontab命令

  • /var/spool/cron/ 所有用户crontab文件存放的目录,以用户名命名

crontab文件的含义

用户所建立的crontab文件中,每一行都代表一项任务
每行的每个字段代表一项设置
格式共分为六个字段,前五段是时间设定段,第六段是要执行的命令段

minute hour day month week command 顺序:分 时 日 月 周

  • minute: 表示分钟,可以是从0到59之间的任何整数。

  • hour:表示小时,可以是从0到23之间的任何整数。

  • day:表示日期,可以是从1到31之间的任何整数。

  • month:表示月份,可以是从1到12之间的任何整数。

  • week:表示星期几,可以是从0到7之间的任何整数,这里的0或7代表星期日。

  • command:要执行的命令,可以是系统命令,也可以是自己编写的脚本文件。

可以使用的特殊字符

  • 星号(*):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。

  • 逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9”

  • 中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6”

  • 正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。

crond服务

/sbin/service crond start //启动服务 /sbin/service crond stop //关闭服务 /sbin/service crond restart //重启服务 /sbin/service crond reload //重新载入配置 service crond status //查看服务状态

日志

/var/log/cron.log

实例

  1. * * * * * command //每1分钟执行一次command
  2. 3,15 * * * * command //每小时的第3和第15分钟执行
  3. 3,15 8-11 * * * command //在上午8点到11点的第3和第15分钟执行
  4. 3,15 8-11 */2 * * command //每隔两天的上午8点到11点的第3和第15分钟执行
  5. 3,15 8-11 * * 1 command //每个星期一的上午8点到11点的第3和第15分钟执行
  6. 30 21 * * * /etc/init.d/smb restart //每晚的21:30重启smb
  7. 45 4 1,10,22 * * /etc/init.d/smb restart //每月1、10、22日的4 : 45重启smb
  8. 10 1 * * 6,0 /etc/init.d/smb restart //每周六、周日的1:10重启smb
  9. 0,30 18-23 * * * /etc/init.d/smb restart //每天18 : 00至23 : 00之间每隔30分钟重启smb
  10. 0 23 * * 6 /etc/init.d/smb restart //每星期六的晚上11:00 pm重启smb
  11. * */1 * * * /etc/init.d/smb restart //每一小时重启smb
  12. * 23-7/1 * * * /etc/init.d/smb restart //晚上11点到早上7点之间,每隔一小时重启smb
  13. 0 11 4 * mon-wed /etc/init.d/smb restart //每月的4号与每周一到周三的11点重启smb
  14. 0 4 1 jan * /etc/init.d/smb restart //一月一号的4点重启smb
  15. 01 * * * * root run-parts /etc/cron.hourly //每小时执行/etc/cron.hourly目录内的脚本

grep

查找一个文件夹下所有文件中是否包含特定字符串:grep -rn “172.16.82.202” #r是递归,-n是显示行号,是文件名

rm

  1. #删除30天前,目录,名称中包含btag-201806
  2. sudo find . -mtime +30 -type d -name "btag-201806*" -exec rm -rf {} \;

ssh

ssh-copy-id

ssh-copy-id命令可以把本地主机的公钥复制到远程主机的authorized_keys文件上,ssh-copy-id命令也会给远程主机的用户主目录(home)和~/.ssh, 和~/.ssh/authorized_keys设置合适的权限。

语法

  1. ssh-copy-id [-i [identity_file]] [user@]machine

选项

  1. -i:指定公钥文件

实例

1、把本地的ssh公钥文件安装到远程主机对应的账户下:

  1. ssh-copy-id user@server
  2. ssh-copy-id -i ~/.ssh/id_rsa.pub user@server

sudo

用来以其他身份来执行命令,预设的身份为root。
在/etc/sudoers中设置了可执行sudo指令的用户
若其未经授权的用户企图使用sudo,则会发出警告的邮件给管理员。
使用sudo时,必须先输入密码,之后有5分钟的有效期限,超过期限则必须重新输入密码。

与su的不同之处
sudo仅在需要时授予用户权限,减少了用户因为错误执行命令损坏系统的可能性
sudo也可以用来以其他用户身份执行命令
sudo可以记录用户执行的命令,以及失败的特权获取。

find

查找大文件:find / -xdev -size +100M -exec ls -l {} \;