跳到主要内容

基础知识

crontab 详解

Linux crontab 是用来定期执行程序的命令。

信息

1、系统执行的工作:系统周期性所要执行的工作,如备份系统数据、清理缓存 2、个人执行的工作:某个用户定期要做的工作,例如每隔 10 分钟检查邮件服务器是否有新信,这些工作可由每个用户自行设置

语法

crontab [ -u user ] file
crontab [ -u user ] { -l | -r | -e }

说明:

crontab 是用来让使用者在固定时间或固定间隔执行程序之用,换句话说,也就是类似使用者的时程表。

-u user 是指设定指定 user 的时程表,这个前提是你必须要有其权限(比如说是 root)才能够指定他人的时程表。如果不使用 -u user 的话,就是表示设定自己的时程表。

参数说明:

  • -e : 执行文字编辑器来设定时程表,内定的文字编辑器是 VI,如果你想用别的文字编辑器,则请先设定 VISUAL 环境变数来指定使用那个文字编辑器(比如说 setenv VISUAL joe)
  • -r : 删除目前的时程表
  • -l : 列出目前的时程表
信息

f1 f2 f3 f4 f5 program

  • 其中 f1 是表示分钟,f2 表示小时,f3 表示一个月份中的第几日,f4 表示月份,f5 表示一个星期中的第几天。program 表示要执行的程序。
  • 当 f1 为 *时表示每分钟都要执行 program,f2 为* 时表示每小时都要执行程序,其馀类推
  • 当 f1 为 a-b 时表示从第 a 分钟到第 b 分钟这段时间内要执行,f2 为 a-b 时表示从第 a 到第 b 小时都要执行,其馀类推
  • 当 f1 为 */n 时表示每 n 分钟个时间间隔执行一次,f2 为*/n 表示每 n 小时个时间间隔执行一次,其馀类推
  • 当 f1 为 a, b, c,... 时表示第 a, b, c,... 分钟要执行,f2 为 a, b, c,... 时表示第 a, b, c...个小时要执行,其馀类推
执行时间格式
每分钟定时执行一次* * * * *
每小时定时执行一次0 * * * *
每天定时执行一次0 0 * * *
每月定时执行一次0 0 1 * *
每月最后一天定时执行一次0 0 L * *
每年定时执行一次0 0 1 1 *

每一分钟执行一次 /bin/ls:

* * * * * /bin/ls

在 12 月内, 每天的早上 6 点到 12 点,每隔 3 个小时 0 分钟执行一次 /usr/bin/backup:

0 6-12/3 * 12 * /usr/bin/backup

周一到周五每天下午 5:00 寄一封信给 alex@domain.name

0 17 * * 1-5 mail -s "hi" alex@domain.name < /tmp/maildata

每月每天的午夜 0 点 20 分, 2 点 20 分, 4 点 20 分....执行 echo "haha":

20 0-23/2 * * * echo "haha"

0 */2 * * * /sbin/service httpd restart  意思是每两个小时重启一次apache 

50 7 * * * /sbin/service sshd start 意思是每天7:50开启ssh服务

50 22 * * * /sbin/service sshd stop 意思是每天22:50关闭ssh服务

0 0 1,15 * * fsck /home 每月1号和15号检查/home 磁盘

1 * * * * /home/bruce/backup 每小时的第一分执行 /home/bruce/backup这个文件

00 03 * * 1-5 find /home "*.xxx" -mtime +4 -exec rm {} \; 每周一至周五3点钟,在目录/home中,查找文件名为*.xxx的文件,并删除4天前的文件。

30 6 */10 * * ls 意思是每月的1、11、21、31日是的6:30执行一次ls命令
备注

注意:当程序在你所指定的时间执行后,系统会发一封邮件给当前的用户,显示该程序执行的内容,若是你不希望收到这样的邮件,请在每一行空一格之后加上 > /dev/null 2>&1 即可,如:

20 03 * * * . /etc/profile;/bin/sh /var/www/test.sh > /dev/null 2>&1 

信息
  1. 所有命令需要写成绝对路径形式,如: /usr/local/bin/docker。

  2. 在 shell 脚本开头使用以下代码:

#!/bin/sh

. /etc/profile
. ~/.bash_profile
  1. 在 /etc/crontab 中添加环境变量,在可执行命令之前添加命令 . /etc/profile;/bin/sh,使得环境变量生效,例如:
20 03 * * * . /etc/profile;/bin/sh /var/www/runoob/test.sh

修改ubuntu 固定ip

查看网卡信息

信息
ifconfig 

docker0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
inet 172.17.0.1 netmask 255.255.0.0 broadcast 172.17.255.255
inet6 fe80::42:37ff:fe89:cb48 prefixlen 64 scopeid 0x20<link>
ether 02:42:37:89:cb:48 txqueuelen 0 (以太网)
RX packets 482 bytes 1234106 (1.2 MB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 760 bytes 68055 (68.0 KB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

enp3s0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.8.118 netmask 255.255.255.0 broadcast 192.168.8.255
inet6 fe80::da97:baff:feee:1033 prefixlen 64 scopeid 0x20<link>
ether d8:97:ba:ee:10:33 txqueuelen 1000 (以太网)
RX packets 1539 bytes 152198 (152.1 KB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 1159 bytes 1303682 (1.3 MB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
inet6 ::1 prefixlen 128 scopeid 0x10<host>
loop txqueuelen 1000 (本地环回)
RX packets 606 bytes 44407 (44.4 KB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 606 bytes 44407 (44.4 KB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

veth4c0a8ec: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet6 fe80::6861:1eff:fe8d:a550 prefixlen 64 scopeid 0x20<link>
ether 6a:61:1e:8d:a5:50 txqueuelen 0 (以太网)
RX packets 482 bytes 1240854 (1.2 MB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 777 bytes 70214 (70.2 KB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

vethaff9d97: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet6 fe80::40e9:d9ff:fe7d:a31c prefixlen 64 scopeid 0x20<link>
ether 42:e9:d9:7d:a3:1c txqueuelen 0 (以太网)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 62 bytes 7849 (7.8 KB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

临时修改

当重启电脑后,ip地址将恢复为原来的ip地址,此方法适合临时测试使用

修改ip和子网掩码

sudo ifconfig 网卡名 ip信息 netmask 掩码

sudo ifconfig enp3s0 192.168.8.118 netmask 255.255.255.0

# 确认是否修改完成
ifconfig


修改网关的方法

信息
route -n
内核 IP 路由表
目标 网关 子网掩码 标志 跃点 引用 使用 接口
0.0.0.0 192.168.43.1 0.0.0.0 UG 0 0 0 enp3s0
169.254.0.0 0.0.0.0 255.255.0.0 U 1000 0 0 enp3s0
172.17.0.0 0.0.0.0 255.255.0.0 U 0 0 0 docker0
192.168.8.0 0.0.0.0 255.255.255.0 U 0 0 0 enp3s0
sudo route add default gw 网关信息 网卡名

# 查看是否修改完成
route -n

永久修改

永久修改需要对配置文件进行修改,然后重启网络服务即可

信息
sudo vim /etc/network/interfaces

# interfaces(5) file used by ifup(8) and ifdown(8)
auto lo
iface lo inet loopback

#static ip

auto enp3s0
iface enp3s0 inet static
address 192.168.8.114
netmask 255.255.255.0
gateway 192.168.43.1
dns-nameservers 8.8.8.8

# 重启服务
sudo /etc/init.d/networking restart
# 或
sudo service networking restart


查看外网ip

  1. curl cip.cc
  2. curl icanhazip.com
  3. curl ifconfig.me

linux 系统自动挂载

查看硬盘信息

    sudo fdisk -l

格式化新硬盘

    sudo mkfs.ext4 /dev/sdb1
  • ext4 :格式化硬盘格式
  • /dev/sdb 磁盘盘符

创建挂载目录

sudo mkdir data

挂载分区

sudo mount /dev/sdb1 /data

查看磁盘分区 id

sudo blkid

配置开机硬盘自动挂载

sudo vim /etc/fstab

在末尾加入

UUID=11263962-9715-473f-9421-0b604e895aaa /data ext4 defaults 0 1

参数说明:

[fs spec] [fs file] [fs vfstype] [fs mntops] [fs freq [fs passno]

  • [fs spec]:分区定位,可以给 UUID 或 LABEL,例如:UUID=6E9ADAC29ADA85CD 或 LABEL=software
  • [fs file]:具体挂载点的位置,例如:/data
  • [ fs vfstype]:挂载磁盘类型,linux 分区一般为 ext4,windows 分区一般为 ntfs
  • [fs mntops]:挂载参数,一般为 defaults
  • [fs freq]:磁盘检查,默认为 0
  • [fs passno]:磁盘检查,默认为 0,不需要检查

验证

sudo mount -a

如果修改这个文件导致系统挂了,可以使用 Ubuntu 的 Live CD 功能(即 Try Ubuntu...)进入系统来修改回这个文件。

Ubuntu 设置 sudo 免密码

  1. 修改 sudoers 权限
   sudo chmod 744 suoders
  1. 修改 sudoers 文件
    sudo vim /etc/sudoers
# 在文件最后一行 添加 计算机名称(eg:ubuntu) ALL=(ALL) NOPASSWD:ALL