基础知识
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
-
所有命令需要写成绝对路径形式,如: /usr/local/bin/docker。
-
在 shell 脚本开头使用以下代码:
#!/bin/sh
. /etc/profile
. ~/.bash_profile
- 在 /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
- curl cip.cc
- curl icanhazip.com
- 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 免密码
- 修改 sudoers 权限
sudo chmod 744 suoders
- 修改 sudoers 文件
sudo vim /etc/sudoers
# 在文件最后一行 添加 计算机名称(eg:ubuntu) ALL=(ALL) NOPASSWD:ALL