crontab
用来提交和管理用户的需要周期性执行的任务
当安装完成操作系统后,默认会安装此服务工具,并且会自动启动crond进程,crond进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务。
-e:编辑该用户的计时器设置;
-l:列出该用户的计时器设置;
-r:删除该用户的计时器设置;
-u<用户名称>:指定要设定计时器的用户名称。
参数:crontab文件:指定包含待执行任务的crontab文件。
系统任务调度
系统周期性所要执行的工作,比如写缓存数据到硬盘、日志清理等
对应文件:/etc/crontab,初始内容
SHELL=/bin/bashPATH=/sbin:/bin:/usr/sbin:/usr/binMAILTO=rootHOME=/# 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
第三行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
实例
* * * * * command //每1分钟执行一次command3,15 * * * * command //每小时的第3和第15分钟执行3,15 8-11 * * * command //在上午8点到11点的第3和第15分钟执行3,15 8-11 */2 * * command //每隔两天的上午8点到11点的第3和第15分钟执行3,15 8-11 * * 1 command //每个星期一的上午8点到11点的第3和第15分钟执行30 21 * * * /etc/init.d/smb restart //每晚的21:30重启smb45 4 1,10,22 * * /etc/init.d/smb restart //每月1、10、22日的4 : 45重启smb10 1 * * 6,0 /etc/init.d/smb restart //每周六、周日的1:10重启smb0,30 18-23 * * * /etc/init.d/smb restart //每天18 : 00至23 : 00之间每隔30分钟重启smb0 23 * * 6 /etc/init.d/smb restart //每星期六的晚上11:00 pm重启smb* */1 * * * /etc/init.d/smb restart //每一小时重启smb* 23-7/1 * * * /etc/init.d/smb restart //晚上11点到早上7点之间,每隔一小时重启smb0 11 4 * mon-wed /etc/init.d/smb restart //每月的4号与每周一到周三的11点重启smb0 4 1 jan * /etc/init.d/smb restart //一月一号的4点重启smb01 * * * * root run-parts /etc/cron.hourly //每小时执行/etc/cron.hourly目录内的脚本
grep
查找一个文件夹下所有文件中是否包含特定字符串:grep -rn “172.16.82.202” #r是递归,-n是显示行号,是文件名
rm
#删除30天前,目录,名称中包含btag-201806sudo 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设置合适的权限。
语法
ssh-copy-id [-i [identity_file]] [user@]machine
选项
-i:指定公钥文件
实例
1、把本地的ssh公钥文件安装到远程主机对应的账户下:
ssh-copy-id user@serverssh-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 {} \;
