Linux软件安装
Linux排查问题套路
Linux命令详解
说到操作系统,如果读大学的时候是计算机专业,那肯定就会上这门课,我猜测当时的你们想法是这样的
上大学使用的都是Windows系统,界面友好,上手快,习惯性的点点点操作
大部分的课程在windows中操作,比如C++用的Vistual Studio,学数据库的SQL Server
大学中的操作系统更加偏向理论研究,至于到底是怎么运作的可能懵懵懂懂
知道上了研究生到了实验室,我发现实验室的怎么都是对着一个窗口操作,瞬间觉得以前的计算机知识白学了,于是开启了Linux之路。
其实大部分的系统,团购,打车,快递都部署在服务端,其中都包含Linux,什么云计算,虚拟化,大数据等也是基于Linux,那为啥在大学里都是windows?
咦
为什么说了解Linux的生态,会让你学到更多的新技术?
我们要知道很多的大牛通过Linux来开发各种如那件,数据库Mysql,kafka,Spark等技术都会默认提供Linux的安装运维手册,所以尽快的进入Linux的世界对于个人的进步和职业发展都是非常有好处的
每当我们买了手机,买了电脑,上手就可以用,这是因为预装了操作系统。所以呀,那有什么岁月静好,知识有人帮我们负重前行了,操作系统就是这样一个角色。
那么操作系统帮助我们做了哪些事儿呢?
跑几个问题,桌面上的图标是什么,为啥子敲一下键盘就出来了画面
电脑咋个知道我们鼠标点击的那个位置
为什么我一回车,这些字符就飞出去了
这几个任何一个操作,基本上都覆盖了操作系统的所有功能,那我来认识熟悉而默认的操作系统
虚拟机是什么?
虚拟机通过软件来模拟具有完整硬件系统功能的,运行在完全隔离的完整计算机系统。每个虚拟计算机可以独立运行并安装各种软件和应用
首先从官方下载并解压虚拟机安装包,然后双击运行
双击VMVARE
下一步
接受许可进行下一步
选择安装位置,最好不要出现中文
自定义路径
设置用户体验选项,都可以选择
设置用户体验
在桌面和开始菜单程序文件夹创建快捷方式。
创建快捷方式
百度一个许可证ZG1WH-ATY96-H80QP-X7PEX-Y30V4
输入许可证密钥
打开vmvare
打开vmvare
点击新建虚拟机向导 选择文件-新建虚拟机打开
新建虚拟机
选择自定义 下一步
选择自定义
下一步
选择下一步
安装客户机操作系统,选择稍后安装操作系统
选择稍后安装操作系统
命名虚拟机 更改虚拟机名称并选择安装得位置
命名虚拟机
更改主机配置进行处理的分配
处理器核心数分配
虚拟内存分配:注意内存分配不能大于主机内存
虚拟内存分配设置虚拟机网络得类型,这里选择NAT
网络类型暂设为NAT
IO控制器选择,选择LSILogic
磁盘类型选择SCSI即可
创建磁盘选择创建新虚拟磁盘
创建新虚拟磁盘
指定磁盘文件
指定磁盘文件
修改路径
选择自定义硬件
选择自定义硬件
选择centos得ISO镜像文件,先选择CDDVN---ISO镜像文件---浏览找到镜像、
导入镜像
点击完成
完成
开启虚拟机 选择配置好的虚拟机
开启虚拟机
鼠标移动到虚拟机内部,上下键选择install centos7然后回车
install centos7
选择软件选择最小安装,选择语言
选择最小化安装软件安装
软件安装
选择计算节点
选择计算节点
开始安装
开始安装
设置root密码,点击完成配置
现在我们的centos还是个空壳子,如果我们需要访问外网,则需要进一步配置一波
打开配置文件
#vi /etc/sysconfig/network-scripts/ifcfg-eth0
更改相应的配置
DEVICE=eth0 #设备名称,可根据ifcofnig命令查看到。 BOOTPROTO=dhcp #连接方式,dhcp会自动分配地址,此时不需要在下面设置ip和网关 HWADDR=00:0C:29:AD:66:9F #硬件地址,可根据ifcofnig命令查看到。 ONBOOT=yes #yes表示启动就执行该配置,需要改为yes
service restart network完事 ping www.baidu.com
网络检测
我们已经完成了安装vmvare并导入了centos,那么我们如何去玩儿这个看似很牛皮的玩意?直接上手?不习惯吧,那我们用个远程工具连连
Xshell 是一个强大的QQ号码卖号地图安全终端模拟软件,Xshell 可以在 Windows 界面下用来访问远端不同系统下的服务器,从而比较好的达到远程控制终端的目的。除此之外,其还有丰富的外观配色方案以及样式选择。
下载xshell(别去下了,贼慢麻烦)
链接测试(因为使用的ssh,那么确保centos中22端口已经打开了)
文件-----属性进行XHSELL相关的配置,比如配色,字体大小等
命令太多,必须要全部记忆,但是要学会如何查每个命令的参数。我画了个思维导图可以当作小字典查看,下面列出可能我们使用频率会更高的命令
执行命令 | 含义 |
---|---|
cd ~ | 切换到登录用户的主目录即/home/用户名 |
cd / | 进入根目录 |
cd /home/lj | 将/home/LJ作为当前的目录 |
cd .. | 返回到上一层目录 |
cd - | 回到上次所在的目录 |
cd ../../ | 去上上层目录 |
ls | 查看当前目录 |
ls -la | 查看当前目录的文件信息 包含了隐藏文件 |
pwd | 查看当前目录的绝对路径 |
cp /目录/1.txt /目录/ | 复制 |
rm | 删除 |
q! | 不保存文件退出 |
wq! | 保存退出 |
hostname | 查看当前主机名 |
ifconfig | 查看网卡相关信息 |
firewall-cmd --state | centos7查看卡其关闭防火墙状态 |
刚才说了可以创建自己的用户,那么怎么创建自己的用户呢?
添加用户
useradd -d /home/lanj -m lanj
更改密码
passwd lanj
系统有很多的用户,怎么进行用户的切换?
su -lanj
su -root
如果需要
用户之间的切换使用su命令实现。root用户可以无需输入密码切换到lj用户,如果普通用户lj切换到root用户则需要输入密码,我们看看
su -lj
su -root
如何切换路径,绝对路径和相对路径
在Linux安装相关的工具分为三种方式,分别为源码安装,RPM包安装以及YUM安装方式
源码安装方式
开源软件都会提供源码下载的方式,对于源代码安装方式的好处即可以定制软件功能,安装需要的模块,不需要的模块可以屏蔽,方便管理,卸载等。
对于源码安装的步骤如下
下载解压源码
一般下载下来源码以后都会存在一个Readme文件,首先应该仔细阅读这个文件,可能有很多需要修复的以前人家遇见的问题都会在上面做记录,以免入坑不回头
分析平台环境
编译安装软件
这里会使用make工具,make工具就会通过makefile文件来实现。makefile文件是一种按照某种语法来编写且定义了各个文件的依赖关系。
在Linux中,习惯使用Makefile替代makefile,当用户执行configure后,就会在当前目录生成这个makefile文件,然后用户输入make就开始运行。我们看看Makefile是怎么个有样子
edit : main.o kbd.o command.o display.o \ insert.o search.o files.o utils.o /*注释:如果后面这些.o文件比edit可执行文件新,那么才会去执行下面这句命令*/ cc -o edit main.o kbd.o command.o display.o \ insert.o search.o files.o utils.o main.o : main.c defs.h cc -c main.c kbd.o : kbd.c defs.h command.h cc -c kbd.c command.o : command.c defs.h command.h cc -c command.c display.o : display.c defs.h buffer.h cc -c display.c insert.o : insert.c defs.h buffer.h cc -c insert.c search.o : search.c defs.h buffer.h cc -c search.c files.o : files.c defs.h buffer.h command.h cc -c files.c utils.o : utils.c defs.h cc -c utils.c clean : rm edit main.o kbd.o command.o display.o \ insert.o search.o files.o utils.o
make和make install的关系
当我们输入make命令过后即进入了编译阶段,编译时间根据软件的程序规模大小以及硬件配置有关,当输入make install就会开始安装软件,我们可以指定安装目录也可以不指定,系统将给你默认指定目录为/user/local,这样安装完毕。
RPM安装方式
RPM是Red Hat公司开发出来的Linux下的软件包管理工具。这些以.rpm结尾的包包含了已经编译好的二进制可执行文件,一句话即将源代码进行编译,安装,然后封装为RPM包
优点即安装简单,方便,因为已经编译完成,安装只是用来验证和解压过程,缺点也比较明显,过于依赖于操作系统,要求RPM包的安装环境必须和RPM封装时的环境保持一致,
RPM包是怎么个样子?
server-2.1.0-22.I386.rpm
其中:server为如那件的名称
2.1.0:软件的版本号
22:软件更新发行的次数
i386:适合硬件发行的次数
.rpm:rpm软件包的标识
YUM安装方式
查看是否存在yum
rpm -qa | grep yum
没有则安装
rpm -ivh yum-*.noarch.rpm
自定义yum的配置。我们可以通过打开/etc/yum.repos.d/Centos-Base.repo进行源的配置
YUM有哪些特点呢
安装方便
可以同时配置多个源
配置文件简单明了
推荐个不错的yum源
EPEL
是一个针对红帽企业版Linux及衍生发行版的一个高质量附加软件包项目。网址:http://fedoraproject.org/wiki/EPEL/zh-cn
RPMForge
这是一个第三方软件仓库,被centos社区认为是一个最安全最稳定的一个软件仓库
大部分情况都是Linux操作系统,那么熟悉命令的用法以外,熟悉使用shell脚本能介绍不少时间
shell是什么
“ 平时经常在Linux操作系统中使用各种命令,比如查看当前的目录文件,我们会使用"ls"或者"ls -l",这些字符串参数实际上会被"某段程序"执行并启动它。这个负责将用户输入的字符串转换为需要执行程序的东西叫做"shell"。即帮用户更方便使用操作系统接口的“壳”。同样的壳还有当我输入Maven+相关参数的时候是不是就会去执行相应的功能,我们驶入sql语句的时候,数据库引擎是不是也会各种调用,一样的道理
尝试编写第一个shell
vim创建打开一个文件,扩展名为.sh。如下所示
#!/bin/bash #告诉系统使用什么解析器 echo "Hello xiaolan !" # echo进行输出
执行方法1
chmod +x ./hello.sh ./hello.sh
执行方法2
/bin/sh hello.sh
变量
变量名和等号之间不能有空格
定义变量注意事项
命名首个字符不能是数字,只能使用英文字母、数字和下划线
不能使用标点符号
不能使用bash中关键字
变量使用
使用变量(使用变量的过程中,最好加上花括号),只需要在变量前面加上美元符号即可
#!/bin/bash James="小皇帝" echo $James
只读变量
使用readonly将变量定义为只读,只读意味着不能改变
#!/bin/bash James="小皇帝" readonly James James="登哥"
删除变量
使用unset删除变量 变量删除以后不能再次使用,且不能删除只读变量
#!/bin/bash James="小皇帝" unset James echo $James #不会有任何输出
变量类型
局部变量
仅当前shell可用
环境变量
所有程序都能访问环境变量
shell变量
通过一部分环境变量和shell变量保证shell的正常运行
字符串
使用字符串的过程中,既可以用双引号也可以用单引号,也可以不用
单引号
单引号内容原样输出,不能包含变量,且不能出现单独单引号
双引号
可以出现转义字符
#!/bin/bash James="小皇帝" str="\"$ James\"! oh my gad \n " echo -e $str
获取字符串长度
使用#
string="qwert" echo $(#string) # 提取子字符串 echo $(string:1:3) #查找字符串 echo
数组
支持以为数组
定义数组
数组元素使用“空格”隔开
array=(value1,value2,value3)
读取数组
value1=${array[0]}
使用@输出数组所有元素
echo ${array[@]}
获取数组中所有元素以及数组长度
#! /bin/bash # author:xiaolan array[]=a array[1]=b array[3]=c echo “数组的元素为:${array[*]}” echo “数组的元素为:${array[@]}” echo “数组的个数为:${#array[*]}” echo “数组的个数为:${#array[@]}”
执行
./array.sh
结果
result
注释
单行注释
使用#开头的行为注释,会被解释器忽略
多行注释
shell传递参数
在执行shell的时候,命令行指定参数,如下所示
#!/bin/bash James="小皇帝" echo "执行的文件名为:$0" echo "第一个参数为:$1" echo "第二个参数为:$2"
执行
./param.sh 1 2
结果
result
几个特殊字符
result
案例(partionnal.sh)
#!/bin/bash # author:xiaolan echo "-- \$* 演示 ---" for i in "$*"; do echo $i done echo "-- \$@ 演示 ---" for i in "$@"; do echo $i done
执行
./demo2.sh 1 2 3
结果
img
相同点:都是会引用所有参数
不同点:在使用双引号的时候。如果脚本运行时两个参数为a,b,则"*"等价于"ab",而"@"等价于"a","b"
#!/bin/bash # author:xiaolan echo "-- \$* 演示 ---" for i in "$*"; do echo $i done echo "-- \$@ 演示 ---" for i in "$@"; do echo $i done
8 printf
使用printf格式化字符串,同时可以指定字符串宽度和对齐方式,格式如下
printf format-string [arguments...] #!/bin/bash # author:xiaolan printf "%-8s %-8s %-4s\n" 姓名 科目 分数 printf "%-8s %-8s %-4f\n" 小明 数学 97 printf "%-8s %-8s %-4f\n" 小话 语文 89 printf "%-8s %-8s %-4f\n" 王三 英语 93
结果
img
9 test
shell中的test用于检查某个条件是否成立
result
案例
#!/bin/bash # author:xiaolan num1=55 num2=55 if test $[num1] -eq $[num2] then echo '两个数相等!' else echo '两个数不相等!' fi
结果
result
字符串比较
字符串比较
#!/bin/bash # author:xiaolan num1="xiaolan" num2="xiaolna" if test $num1 = $num2 then echo '两个字符串相等!' else echo '两个字符串不相等!' fi
结果
result
流程
if语句语法格式
if condition then exec1 exec2 ... execN fi
如果简化为一行
if [$(ps -ef | grep -c "httpd") -gt 1];then echo "true";fi
if else-if else
if condition1 then exec1 elif condition2 then exec2 else execn fi
案例 判断两数值是否相等
#!/bin/bash # author:xiaolan a=2 b=3 if [ $a == $b ] then echo "a 等于 b" elif [ $a -gt $b ] then echo "a 大于 b" elif [ $a -lt $b ] then echo "a 小于 b" else echo "没有符合的条件" fi
for循环
for loop in 1 2 3 4 5 do echo "The value is: $loop" done
while语句
“ 通常用于从输入文件不断读取数据
while condition do exec done #!/bin/bash # author:xiaolan int=1 while(( $int<=6 )) do echo $int let "int++"# 用于执行一个或者多个 done
无限循环
while true do exec done
case语句
多选择语句。取值后面为单词in,每一个模式以")"结束。匹配发现取值符合某一模式后,其间所有命令开始执行直至 ";;"。
#!/bin/bash # author:xiaolan echo '输入 1 到 3 之间的数字:' echo '你输入的数字为:' read aNum case $aNum in 1) echo '你选择了 1' ;; 2) echo '你选择了 2' ;; 3) echo '你选择了 3' ;; *) echo '你没有输入 1 到 3 之间的数字' ;; esac
输入不同的内容,会有不同的结果,例如:
输入 1 到 4 之间的数字: 你输入的数字为: 你选择了 3
跳出循环
break
break命令允许跳出所有循环
#!/bin/bash # author:xiaolan while : do echo -n "输入 1 到 3 之间的数字:" read aNum case $aNum in 1|2|3) echo "你输入的数字为 $aNum!" ;; *) echo "你输入的数字不是 1 到 3 之间的! 游戏结束" break ;; esac done
continue
跳出当次循环
#!/bin/bash while : do echo -n "输入 1 到 3 之间的数字: " read aNum case $aNum in 1|2|3|4|5) echo "你输入的数字为 $aNum!" ;; *) echo "你输入的数字不是 1 到 3 之间的!" continue echo "游戏结束" ;; esac done
10 shell函数
用户定义函数,然后在shell脚本中随便调用,格式如下
[ function ] funname [()] { action; [return int;] }
例子
#!/bin/bash # author:xiaolan Fun1(){ echo "这是我的第一个 shell 函数!" } echo "-----函数开始执行-----" Fun1 echo "-----函数执行完毕-----"
带return语句
#!/bin/bash # author:xiaolan FunReturn(){ echo "这个函数会对输入的两个数字进行相加运算..." echo "输入第一个数字: " read aNum echo "输入第二个数字: " read anotherNum echo "两个数字分别为 $aNum 和 $anotherNum !" return $(($aNum+$anotherNum)) } FunReturn echo "输入的两个数字之和为 $? !"
函数参数
#!/bin/bash # author:xiaolan funParam(){ echo "第一个参数为 $1 !" echo "第二个参数为 $2 !" echo "参数总数有 $# 个!" echo "作为一个字符串输出所有参数 $* !" } funParam 1 2 3 4
shell重定向
输出重定向
command1 > file # 如果file中存在内容将被清空覆盖。如果追加使用command1 >>file
ls -l > dir.txt
cat dir.txt
img
/dev/null文件
写入到它的内容都会被丢弃,会起到"禁止输出"的效果,如果希望屏蔽stdout和stderr “ command > /dev/null 2>&1
注意:Linux命令行都会打开三个文件
标准输入文件:stdin文件描述符为0
标准输出文件:stdout文件描述符为1
标准错误文件:stderr文件描述符2
12 运算符
下表列出了常用的算术运算符,假定变量 a 为 2,变量 b 为 3:
算术运算符
算术运算符
关系运算符
关系运算符
布尔运算符
布尔运算符
逻辑运算符
逻辑运算符
字符串运算符
12 shell实战
请将当前目录中demo.txt第二行第三列数据输出到demo2.txt中
cat demo.txt|awk ’NR==2{print $3}’ >demo2.txt
日志如下统计访问ip最多的前10个
awk ’{print $1}’ *.log | sort | uniq -c | sort -nr | head -n
uniq - 删除排序文件中的重复行 sort对于文本进行排序 -l 按照当前环境排序. -m 合并已经排序好的文件,不排序. -n 按照字符串的数值顺序比较,暗含-b -r 颠倒比较的结果.
查看占用内存最大的进程的PID和VSZ
ps -aux|sort -k5nr|awk ’BEGIN{print ”PID VSZ”}{print ![2,(https://www.zhihu.com/equation?tex=2%2C)2,5}’|awk ’NR<3′
如何检查文件系统中是否存在某个文件
if [-f /var/log/messages] then echo "File exts" fi
每个脚本开始的 #!/bin/sh 或 #!/bin/bash 表示什么意思 ?
#!/bin/bash 表示脚本使用 /bin/bash。对于 python 脚本,就是 #!/usr/bin/python
&和&&区别
“ “&” 脚本在后台运行时使用它。“&&”当前一个脚本成功完成才执行后面的命令
脚本文件中,如何将其重定向标准输出和标准错误流到 log.txt 文件 ?
./a.sh >log.txt 2>&1
如何计算本地用户的数目
wc -l /etc/passwd | cut -d
shell中进行字符串比较和数字比较
[ $A == $B ] – 用于字符串比较 [ $A -eq $B ] – 用于数字比较
去掉字符串空格
echo $string | tr -d " "
统计内存使用
#! /bin/bash # author:xiaolan sum= for mem in `ps aux |awk '{print $6}' |grep -v 'RSS' ` do sum=$[$sum+$mem] done echo "The total memory is $sum""k"
结果
result
批量更改文件名
批量修改123目录下txt为txt.temp。将temp打包为test.tar.gz
#!/bin/bash ##查找txt文件 find /123 -type f -name "*.txt" > /tmp/txt.list ##批量修改文件名 for f in `cat /tmp/txt.list` do mv $f $f.temp done ##创建一个目录,为了避免目录已经存在,所以要加一个复杂的后缀名 d=`date +%y%m%d%H%M%S` mkdir /tmp/123_$d ##把.temp文件拷贝到/tmp/123_$d for f in `cat /tmp/txt.list` do cp $f.temp /tmp/123_$d done ##打包压缩 cd /tmp/ tar czf 123.tar.gz 123_$d/
awk是一个处理文本文件的应用程序,几乎所有的Linux系统都自带了这个程序
依次处理每一行,并读取里面的每一个字段。对于处理生产环境的日志有着非常高校的作用
基本用法
# 格式 awk 做什么 文件吗 awk 'print $0' lan.txt
上面lan.txt是awk需要处理的文本文件。前面单引号里面有一个大括号,单引号里面就是每一行的处理动作。其中print为打印命令,
上菜
echo 'my name is lanlan' | awk '{print $0}'
上面代码中,print 位当前行,所以执行结果就是把每一行原样打印出来∗∗上菜∗∗¨G56G上面代码中,print0即将标准输入my name is lanlan ,c重新打印一遍
awk根据空格和制表符,将每一行分成若干段,依次为2
echo 'my name is lanlan'| awk '{print $3}'
为了方便,我们直接使用/etc/passwd文件进行操作,
awk -F ':' '{ print $1 }' demo.txt
3 变量
上面我们说了,可以使用符号 “3代表第一个字段,第二个字段,第三个字段¨G57G为了方便,我们直接使用/etc/passwd文件进行操作,¨G58G∗∗3变量∗∗上面我们说了,可以使用符号“+” 数字的方式表示第几个字段,其实还有一些变量可以直接表示相应的字段。比如 “$NFb” 表示最后一个字段
echo 'my name is lanlan'| awk '{print $NF}' awk -F ':' '{print NR ") " $1}' demo.txtshe
这里出现了双引号,表示原样输出
其他常用的内置变量
FILENAME:当前文件名
FS:字段分隔符,默认是空格和制表符。
RS:行分隔符,用于分割每一行,默认是换行符。
OFS:输出字段的分隔符,用于打印时分隔字段,默认为空格。
ORS:输出记录的分隔符,用于打印时分隔记录,默认为换行符。
OFMT:数字输出的格式,默认为%.6g。
4 函数
既然算是一门语言,函数当然少不了,下面看一波常用的函数
函数toupper()用于将字符转为大写
awk -F ':' '{ print toupper($1) }' demo.txt
可以发现第一个字段输出的时候变成了大写
tolower():字符转为小写。
length():返回字符串长度。
substr():返回子字符串。
sin():正弦。
cos():余弦。
sqrt():平方根。
rand():随机数。
5 条件**
通过使用相应的条件,过滤出自己想要的内容
awk '条件 动作' 文件名
上菜
$ awk -F ':' '/usr/ {print $1}' demo.txt root daemon bin sys
这里/usr/表示只输出包含usr的行
这个例子输出奇数行
# 输出奇数行 $ awk -F ':' 'NR % 2 == 1 {print $1}' demo.txt root bin sync # 输出第三行以后的行 $ awk -F ':' 'NR >3 {print $1}' demo.txt sys sync
下面的例子输出第一个字段等于指定值的行。
$ awk -F ':' '$1 == "root" {print $1}' demo.txt root $ awk -F ':' '$1 == "root" || $1 == "bin" {print $1}' demo.txt root bin
5 if语句
通过if语句编写比较复杂的内容
$ awk -F ':' '{if ($1 > "m") print $1}' demo.txt root sys sync
上面代码输出第一个字段的第一个字符大于m
的行。
if结构还可以指定else部分。
crond是什么?
crond是一个可以在指定时间执行一个shell脚本或者一系列的Linux命令。和Windows下的计划任务类似。当安装完操作系统后,默认会安装这个服务工具,并且会自动启动crond进程。
在Linux中任务的调度分为两类
系统任务的调度
系统会周期性的执行一些工作,比如说写缓存的数据到硬盘,清理日志等
用户任务的调度
用户定期也会执行一些任务,比如用户数据的备份,定时的邮件提醒等,这些都是通过crondtab来设置
那么crontab到底怎么用么
首先看看crontab的使用格式:
crontab -u user file
常见的选项
-u user:很明显是需要表明是那个用户的crontab服务,别瞎搞
file:file是命名文件的名字,表示将file作为crontab的任务列表文件并载入到crontab中
-e:e为edit,表示标记某个用户的crontab文件内容
-l:显示用户的crontab文件、
crontab的含义
创建的crontab文件,每一行代表一项任务,每个字段都有对应的设置规则,一共分为6个字段,分别为:
minute hour day month week command
minute:区间 0-59
hour:区间0-23
day:区间0-31
month:区间1-12
week:区间0-7 周日可以是0/7
command
这里的command代表的是需要执行的而命令,通常为脚本文件,
除了上面几个字段,还需要注意几个特殊字段
*:代表所欲呕可能的值
,:通过,来表示区间范围的值
_:整数之间的中杠表示一个证书范围
正斜线:表示时间的间隔频率,比如0-23/2表示每两个小时执行一次
开始放几个例子**
crontab -e * * * /root/bin/backup.sh
这代表的是每天早上5点运行backup.sh
每个工作日11:59pm进行备份作业
59 11 * * 1-5 /root/bin/backup.sh
每五分钟运行一个命令
*/5 * * * * /root/bin/check-status.sh
crontab有哪些选项
crontab -e:修 改crontab文件,如果文件不存在会自动创建
crontab -l:显示crontab文件
crontab -r:删除crontab 文件
crontab -ir:删除crontab文件前提醒用户
用途:不挂断的运行命令
语法:nohup Command [ Arg … ] [&]
无论是否将 nohup 命令的输出重定向到终端,输出都将附加到当前目录的 nohup.out 文件中。
如果当前目录的 "nohup.out" 文件不可写,输出重定向到"home/nohup.out"
如果没有文件能创建或打开以用于追加,那么 Command 参数指定的命令不可调用。
退出状态:该命令返回下列出口值:
126 可以查找但不能调用 Command 参数指定的命令。
127 nohup 命令发生错误或不能查找由 Command 参数指定的命令。
否则,nohup 命令的退出状态是 Command 参数指定命令的退出状态。
使用&
用途:在后台运行,一般两个一起用
nohup command &