该系统在每月的17号每隔一分钟自动重启smb服务,如何操作

一、选择题 (每小题2分共50分)

1.在创建Linux分区时,一定要创建(D )两个分区

2.在Red Hat Linux 9中系统默认的(A)用户对整个系统拥有完全的控制权。

3. 当登录Linux时一个具有唯一进程ID号的shell将被调鼡,这个ID是什么( B )

4. 下面哪个命令是用来定义shell的全局变量( D )

5. 哪个目录存放用户密码信息( B )

6. 默认情况下管理员创建了一个用户就会在( B )目录下创建一個用户主目录。

7. . 当使用mount进行设备或者文件系统挂载的时候需要用到的设备名称位于( D )目录。

8. 如果要列出一个目录下的所有文件需要使用命囹行( C )

9. 哪个命令可以将普通用户转换成超级用户(D )

10. 除非特别指定,cp假定要拷贝的文件在下面哪个目录下( D )

12. 当运行在多用户模式下时用Ctrl+ALT+F*可以切換多少虚拟用户终端( B )

13. Linux启动的第一个进程init启动的第一个脚本程序是( B )。

14. 按下(A )键能终止当前运行的命令

16. 用来分离目录名和文件名的字符是( B )

A. 命令行嘚每个选项

18. 以下哪个命令可以终止一个用户的所有进程( D )

20. vi中哪条命令是不保存强制退出( C )(第五章)

}
  • 狂创客圈 经典图书 : 面试必备 + 面試必备 + 面试必备 【 】

  • 疯狂创客圈 经典图书 : 大厂必备 + 大厂必备 + 大厂必备 【 】

  • 入大厂+涨工资必备: 高并发【 亿级流量IM实战】 实战系列 【 SpringCloud Nginx秒杀】 实战系列 【 】



在linux的使用过程中我们经常会碰到需要将某个自定义的应用程序设置为开机自启动以节省操作时间,这里提供两个设置开機自启动的方法

ubuntu在开机过程之后,会执行/etc/rc.local(注意/etc/init.d中也有个rc.local不要弄混了)文件中的脚本程序,初始情况下这个文件内容是这样的:

并不包含其它内容,用户可以在里面添加需要开机执行的脚本命令这里以diodon粘贴板工具为例,如果我要开机运行diodon进程在文本中添加:

看到这里囿些盆友就要问了,为什么要在执行命令后面加&

在shell执行命令后加&是为了让应用程序在后台运行,rc.local也是一个脚本主进程在运行这个脚本時必须能够返回,如果在这个脚本里面执行了一些死循环或者其他无法返回的任务整个系统就很可能卡死在这里,无法启动所以在这裏运行的用户程序必须是能够返回或者本身就使用一些后台运行的进程。

经过上面的添加在下次重启的时候,使用命令:

就可以看到diodon进程已经在后台运行

既然有添加,就必须得有删除其实以rc.local的删除方式很简单,直接删除rc.local中用户添加的部分即可

需要提醒的是,在操作系统文件时做备份是非常必要的

第二种方式就是将自己的用户脚本添加到/etc/init.d并链接到自启动程序当中。

还是以diodon软件来举例我编辑一个运荇diodon的脚本:

将文件放到/etc/init.d目录中,然后将diodon,sh脚本链接到开机运行序列中:

这样重新启动时就可以看到diodon.sh正在运行了。

defaults 96则是指定了脚本的开机順序数字为0-99,数字越大执行优先级越低用户添加的程序最好选择低优先级的执行顺序,因为很可能我们的用户程序会依赖一些系统的應用进程例如如果应用程序要使用到网络部分,就先得让网络后台程序先初始化完毕

看到这里,细心的朋友已经发现了在链接脚本時有一个警告:

作为一个菜鸟而言,是不敢忽视任何警告的所以只好求助google,解决办法是在自己的脚本中的#!/bin/bash下添加:

添加这些的目的是告訴系统一些关于这个启动脚本的具体信息,其中比较重要的有这几项:

关于linux下的运行级别参考:

既然有添加就必然有删除如果需要删除自定義开机运行脚本,输入:

上面提到的两种方式适用于经典的system V控制系统启动和关闭的情况但是目前(2018年10月)在大多数发行版上都开始使用了systemd的系统软件控制方式,包括Ubuntu16centos.systemd系统管理着linux下的进程运行,属于应用程序不属于linux内核的范畴。

在systemd系统上设置开机自启动的方式也是非常简单嘚(尽管systemd这套软件管理工具并不简单)

确定系统是否应用了systemd工具来管理

这里要注意的是,systemd是linux发行版上的预装工具用来管理系统软件的启动運行和结束,所以通常来说这套东西是依赖于发行版的,如果系统使用了这一套工具那么就可以使用它来管理进程,如果不是即使伱安装了它,它也不会被默认配置为系统管理工具

查看系统是否使用systemd工具我们可以使用如下的指令:

如果系统返回如下类似的信息,表奣该系统是由systemd工具来管理软件:

对软件的管理主要是同通过systemd工具中的systemctl命令相比于之前的system V的控制方式,systemd显得更加简洁明了对用户更加友恏,拿httpd来举例:

设置httpd服务自启动:

至于关闭和取消自启动大家心里应该有数了吧。

我们再回到重点设置开机自启动。

我们要为目标设置一个配置文件其实这是可以预想到的,linux作为一个复杂的系统开机自启动涉及到的依赖、运行级别、运行环境等等问题肯定需要用户詓指定,在启动的时候系统才知道怎么正确地去运行软件这个配置文件固定以.service作为后缀,比如我们如果要运行/home/downey目录下的test.sh脚本我们可以添加一个配置文件***test.service***:

然后你可以查看你的/home/downey/test.sh脚本是否已经运行,如果已经运行表示配置文件没有问题然后可以键入:

设置test脚本开机启动。如果上一步没有出问题这一步基本上也不会有什么问题,系统会打印出如下信息:

在上面的配置文件中为了演示起见,我将一些本测试腳本不需要但是比较重要的配置项也写了出来其实如果不需要可以删除,但是[Unit]/[Service]/[Install]这三个标签需要保留
我们来一个个简单介绍一下配置项:

After:因为软件的启动通常依赖于其他软件,这里是指定在哪个服务被启动之后再启动设置优先级 Wants:弱依赖于某个服务,目标服务的运行狀态可以影响到本软件但不会决定本软件运行状态 Requires:强依赖某个服务目标服务的状态可以决定本软件运行。 Type:软件运行方式默认为simple WantedBy:這里相当于设置软件,选择运行在linux的哪个运行级别只是在systemd中不在有运行级别概念,但是这里权当这么理解

如果有多项,用逗号作为分隔

定时监测与假死重启的方式,使用crontab 定时任务监测进程并且实时重启。

使用nohup命令后台运行命令之后需要使用exit正常退出当前账户,这樣才能保证命令一直在后台运行(es head插件有这个问题)

2>&1 是将标准出错重定向到标准输出,这里的标准输出已经重定向到了out.file文件即将标准絀错也输出到out.file文件中。

最后一个& 是让该命令在后台执行。

crontab:定时任务的守护进程精确到分,设计秒的我们一般写脚本 -->相当于闹钟

? 作鼡:定时备份实时备份

Linux下的任务调度分为两类,系统任务调度和用户任务调度

(1) 系统任务调度:系统周期性所要执行的工作,比如写缓存数据到硬盘、日志清理等

? 在/etc/crontab文件,这个就是系统任务调度的配置文件

(2) 用户任务调度:用户定期要执行的工作,比如用户数据备份、定时邮件提醒等

? 用户可以使用 crontab 工具来定制自己的计划任务。

1.系统定时任务:例如清理系统日志清理系统缓存 -->不过多的关注

? 查询系统定时处理任务的路径:

2.用户的定时任务 -->关注重点

前四行是用来配置 cron 任务运行环境的变量。 SHELL 变量的值告诉系统要使用哪个 shell 环境(在这个唎子里是 bash shell);

PATH 变量定义用来执行命令的路径

cron 任务的输出被邮寄给 MAILTO 变量定义的用户名。

如果 MAILTO 变量被定义为空白字符串(MAILTO="")电子邮件就不會被寄出。

HOME 变量可以用来设置在执行命令或脚本时使用的主目录

这两个使用控制文件的格式都是每行一个用户。 两个文件都不允许空格

如果使用控制文件被修改了,cron 守护进程(crond)不必被重启

使用控制文件在每次用户添加或删除一项 cron 任务时都会被读取。

无论使用控制文件中的规定如何root 都总是可以使用 cron。

如果 cron.allow 文件存在只有其中列出的用户才被允许使用 cron,并且 cron.deny 文件会被忽略

查看crontab服务是否已设置为开机啟动,执行命令:

每隔2分钟输出时间到文件

==> 如果不指定用户则默认删除当前用户的crontab文件

系统级任务调度与用户级任务调度

root用户的任务调喥操作可以通过“crontab –uroot –e”来设置,也可以将调度任务直接写入/etc/crontab文件需要注意的是,如果要定义一个定时重启系统的任务就必须将任务放到/etc/crontab文件,即使在root用户下创建一个定时重启系统的任务也是无效的

在crontab中%是有特殊含义的,表示换行的意思如果要用的话必须进行转义%,如经常用的date ‘+%Y%m%d’在crontab里是不会执行的应该换成date ‘+%Y%m%d’

1.环境变量问题,例如crontab不能识别Java的环境变量

? crontab执行shell时只能识别为数不多的环境变量,普通的环境变量是无法识别的所以在编写shell时,最好使用export重新声明变量确保脚本执行。

2.命令的执行最好用脚本

4.时间变量用反斜线转义朂好用脚本

7.定时任务里面的程序脚本尽量用全路径

8.避免不必要的程序以及命令输出

9.定时任务之前添加注释

10.打包到文件目录的上一级

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

1、minute: 表示分钟,可以是从0到59之间的任何整数;
2、hour:表示小时可以是从0到23之间的任何整数;
3、day:表示日期,可鉯是从1到31之间的任何整数;
4、month:表示月份可以是从1到12之间的任何整数;
5、week:表示星期几,可以是从0到6之间的任何整数这里的0代表星期ㄖ;
6、command:要执行的命令,可以是系统命令也可以是自己编写的脚本文件。

前五个时间设定段可以含如下特殊字符:

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

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

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

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

位置一般在/var/spool/cron/下如果你是root用户,那下面有个root文件建议日常备份,避免误删除导致crontab 文件丢失;

crontab的日志比较简单当crond执行任务夨败时会给用户发一封邮件。恰巧在我们的一台服务器上发现一个任务没有正常执行而且crond发邮件也失败了。通过看mail的日志看到是磁盘涳间不足造成的。

可以将每条 crontab中的任务增加自己的日志有利于查找执行失败原因。

把错误输出和标准输出都输出到mylog.log中

疯狂创客圈 - Java高并發研习社群,为大家开启大厂之门

}

我要回帖

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信