2o_TwoTips
∮Linux 使用的两个小技巧 开启启动脚本 和 环境变量问题
§1.开机启动脚本 && 周期任务
环境 CentOS7:3.10.0-327.el7.x86_64
# head /etc/init.d/network
其中有一行是 # chkconfig: 2345 10 90
这行太重要了,不要被他 开头的 # 键骗了... 如果没有这行,此脚本就不能作为开机自动启动的脚本
这样的意思是 在 运行级别切换到 2345时自动运行一次. 开始次序是 S10 关闭次序是 K90 (开始的比较早,关闭也比较早)
其他的 # 开头的行,好像就都是瞎鬼了...是 真正的注释了
现在写一个自己的脚本,在一些 集群服务中,时间同步很重要~ 这里就写一个 开机自动同步时间的脚本
# vim /etc/init.d/ntp.sh#!/bin/bash
# chkconfig: 2345 80 90
# discription: 这行根本不重要,别想骗到我...
ntpdate time.nist.gov
# chmod +x /etc/init.d/ntp.sh
下面将这个脚本添加为开机自动运行的脚本
其实方法有挺多种,比如 #chkconfig ntp.sh on # chkconfig ntp.sh off,但是我一般不用,因为 off 的不彻底...
再比如 #chkconfig --level 35 ntp.sh on #chkconfig --level 35 ntp.sh off,但是我也不用
因为我已经在文件中定义了启动级别,虽然他是以命令中 --levelv ### 为准,但总有 混淆视听的感觉...
嗯嗯,我自己写的脚本不用这种方法,但是如果是 安装的其他软件,这样操作还是挺方便的,比如 mariadb,ngx,sshd,crond 什么的
操作方法是 # chkconfig --level 2345 mariadb {on|off}
# chkconfig --level 2345 nginx {on|off}
对,以上方法我都不用....
我使用的是下面的方法
# chkconfig --add ntp.sh这里看起来像一的东西不是两个杆,就是中文字符 一...
# ls /etc/rc.d/rc3.d/你会发现一个叫 S80ntp.sh 的文件
# chkconfig --del ntp.sh这样操作比较 "彻底"
# ls /etc/rc.d/rc3.d/比较彻底
OK, 无论你以那种方式 添加了 开机自动启动的脚本,你都可以把 这个脚本当成一个服务进行控制了
# systemctl start ntp这里就别加 .sh 了,实际上,脚本的第一行已经标明了程序的执行路径,
就是 /bin/bash 连文件本身的后缀名都根本不需要~
# systemctl status ntp查看一下这个"服务"的状态,...执行成功,现在是 exited 状态...
其实 硬件时钟,偶尔会失准... 这里搞一个周期任务,每小时 来 想 时间服务器同步时间嗯嗯
实际上 crontab 的环境变量问题是 十分坑爹的,所以,我一般给定全 路径.
# whereis ntpdate
# crontab -e-l查看 -r删除 -...想不起来了 man是查看帮助文档#* * * * * ntpdate time.nist.gov > /dev/null 2>&1
# 上面这行是没法执行的,至少在我的机器上
1 * * * * /usr/sbin/ntpdate time.nist.gov > /dev/null 2>&1上面的 五个星号是五个时间周期, # cat /etc/crontab 已经说的很清楚了 聪明的你,一看就能懂
唯一需要注意的就是, 星期几 和 日期可能会出现矛盾,所以,这俩只定义一个就好了,我上面定义的是一个小时任务
意思是每小时的 第一分钟执行一次时间同步,无论是否成功都别 TMD 的别发邮件烦我.. 当然我之前测试过,是可以成功的.
* * * * * 每分钟执行一次
3 * * * * 每小时的第三分钟
4 5 * * 5 每周五 的 5:40
7 8 9 10 * 10月9日 8:07
9 8 * * 3,0 周三和周日的 8:09
0 9-18 * * * 9点 - 18点 每小时执行一次
* */5 * * * 每 5小时 执行一次
§2.环境变量
我和我对象说,孔乙己知道 回 字有四种写法.你不该把时间浪费在 回字四种写法的知识上.
你也不要炫耀你知道回字有四种写法. 如果已经知道了,应该以此为耻:我曾花费精力去了解了回字的四种写法...
# echo $PATH查看当前系统的环境变量
现在我想加入自己的环境变量 我 # vim /etc/profile
It's NOT a good idea to change this file unless you know what you
are doing. It's much better to create a custom.sh shell script in
/etc/profile.d/ to make custom changes to your environment, as this
will prevent the need for merging in future updates.
听人劝,吃饱饭...
# vim /etc/profile.d/myPath
export PATH="/root/funcShell:$PATH"意思就是把 /root/funcShell 加入环境变量
如果没写 export你会后悔很长时间的,嗯,足够长的时间...
这样配置完只能重启生效,想要立即生效怎么办... 执行如下指令
# source /etc/profile
# echo $PATH发现 /root/funcShell 已经作为环境变量添加进来了
本来到这里就该结束了.... 但是 ... 想删除怎么办? # rm -f /etc/profile.d/myPath # source /etc/profile
很遗憾之前的操作是无效的.当然你 reboot 可以,但是我不想 reboot 就想恢复怎么办~ 也许有更高明的做法,但是我蠢蠢的写了一个脚本
# vim xxx.sh原谅我单词量的匮乏...
再见...
好吧,还有点事要说一下, 以上内容就是 脚本的全部内容了,不需要在第一行加入 #!/bin/bash 因为我要用 source 调用.
我要用 source 调用因为脚本中有一句 source /etc/profile 而 source 又是 bulitin 命令,是无法用 bash 调用的
这是一个 不小的话题....总之,按照以下 命令调用脚本,可以把 PATH 恢复的 没有被 "祸害" 之前的样子
# source xxx.sh
再见....
2o_TwoTips的更多相关文章
随机推荐
- 跟我学Windows Azure 三 使用vs2013创建windows azure web site
首先我们需要登陆我们的windows azure上,然后访问 https://manage.windowsazure.cn/publishsettings/index 他会让我们下载我们的订阅证书文件 ...
- 命令模式(Command Pattern)
命令模式的本质是对命令进行封装,将发出命令的责任和执行命令的责任分割开.命令模式是为了解决命令的请求者和命令的实现者之间的耦合关系. 将来自客户端的请求传入一个对象,从而使你可用不同的请求对客户进行参 ...
- 手写json
json的意思是JavaScript 对象表示法 '{"0":0,"b":[3,4,5],"c":"0","d ...
- android 获取SD卡相关信息
Object localOb; String str1 = null; try { localOb = new FileReader("/sys/block/mmcblk0/device/t ...
- 有关vue的总结
1:使用v-for进行循环渲染: <div v-for="(value, key, index) in object"> {{ index }}. {{ key }} ...
- Mysql-cluster7.5
Data nodes: shell> rpm -Uhv mysql-cluster-community-data-node-7.5.5-1.1.el7.x86_64.rpm SQL nodes: ...
- Inno Setup怎样创建一个自动申请管理员身份运行的快捷
如果你使用的是 Unicode 版本的 Inno Setup,那么以下是更为专业的解决方法. 这是 mlaan 提及的再一种方法. QUOTE( CodeAutomation3.iss) ...
- Svg path画线(不管是直线还是曲线)在一定情况下线条的宽度不一的情况(记录)
在项目中涉及到svg: 使用path划线实现图表功能. 记录在实现的过程中发现的问题:path在小像素的情况下画出的线条宽度不一样.这是为什么呢? 以下是我做的猜想: 可以看图 在宽度给的很足的时候没 ...
- 黄聪:关闭Win2003开机提示“上次意外关机”对话框
很多人在使用win2003服务器(特别是vps)的时候,都会意外关机,然后出现开机提示“上次意外关机”对话框,如果不及时发现,会影响到使用该服务器的网站,所以必须把这提示关闭,方法如下: 1.开始菜单 ...
- oracle 导库建立测试库
由于客户要定制的关系,需要对产品的数据进行相关的修改,所以需要复制原来的库出来,然后在此基础上再进行修改.步骤如下: 在PL/SQL下操作: /*分为四步 *//*第1步:创建临时表空间 */cre ...
