一个简单的shell脚本

一个简单的shell脚本

一个简单的shell脚本

编写

假设我想知道目前系统上有多少人登录,使用who命令可以告诉你现在系统有谁登录:

1.[KANO@kelvin ~]$ who
2.KANO tty1 2016-02-15 01:47 (:0)
3.KANO pts/0 2016-02-15 01:48 (kelvin)

当然在个人电脑上,所列出来的列表可能只有上面这么短。但是在一些大型、多用户的系统上,所列出的列表就可能很长。这个时候我们可以使用自动计算用户总数。wc是一个字数计算程序,它可以计算出行数(line)、字数(word)和字符数(character)。

我们用wc -l用以算出行数,表示已登录的用户数

1.[KANO@kelvin ~]$ who|wc -l
2.2

next,我们将此管道转变成一个独立的命令。

1.[KANO@kelvin ~]$ cat>nusers   #建立文件,使用cat复制终端的输入
2.who|wc -l #程序内容
3.^D #ctrl+D表示end-of-file
4.[KANO@kelvin ~]$ chmod +x nusers #让文件拥有执行的权限
5.[KANO@kelvin ~]$ ./nusers #执行测试
6.2 #输出结果

一个小型化shell脚本的典型代表开发周期:

  1. 直接在命令行(command line)上测试
  2. 找到能够完成工作的适当语法,再将它们放进一个独立的脚本里,并设置执行权限
  3. 直接使用该脚本

完善

我们的nusers shell脚本并非是编译型程序,因此当shell要求内核执行它时,内核将会报错”executable format file”(不是可执行的格式文件)。shell收到此报错信息时,才会启动一个新的/bin/bash副本来执行该程序。系统只有一个shell时,退回机制是非常方便的。但一般来说我们的系统都会有好几个shell,因此需要通过脚本文件中第一行设置#!来告知内核应该以哪个shell来执行所指定的shell脚本。

1.[KANO@kelvin ~]$ cat nusers 
2.#! /bin/bash -
3.
4.who|wc -l

其中选项——表示没有shell选项,这是基于安全上的考虑,可避免某种程度的欺骗式攻击(spoofing attack)。

上一篇:MySQL知识树-查询语句


下一篇:MySQL知识树-支持的数据类型