shell脚本编程基础(1)

一.位置变量相关知识

    1.位置变量定义:在脚本代码中调用通过命令行传递给脚本的的参数

    2.位置变量种类:   

            $1 $2 … :对应第一、第二…参数 shift [n]换位置

            $@:传递给脚本的所有参数,每个参数为独立字符串

            $#:传递给脚本的参数的个数

            $*:传递给脚本的所有参数,全部参数合为一个字符串

            $0:命令本身

    注意:$#和$@只有加上“”才会有区别

实例:写脚本argdesc.sh先说明各个变量的作用,脚本内容如下

1.png

实验结果如下

2.png

3.$@和$*的区别

    $@:代表所有参数,每个参数作为独立字符串

    $*:代表所有字符串,把他们作为一个整体

    (1)新建脚本文件1.sh,让其调用2.sh,内容如下

3.png

(2)新建脚本文件2.sh,分别调用“$@”、“$*”,内容如下

4.png

(3)给予执行权限运行,此时把1.sh的参数作为整体

5.png

4.$#的说明

(1)$#指的是脚本调用多少参数

(2)在上边使用过的2.sh中修改,内容如下

6.png

(3)执行2.sh,结果如下

7.png

总结:不论里边是否调用外边参数,$#表示的是外边的参数个数总和

二.作业

1、编写脚本/root/bin/systeminfo.sh,显示当前主机系统信息,包括主机名,IPv4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小。

脚本内容如下:

1.png

执行结果如下

1.1.png

2、编写脚本/root/bin/backup.sh,可实现每日将/etc/目录备份到/root/etcYYYY-mm-dd中

文本内容如下:

2.png

运行结果如下:

2.1.png

3、编写脚本/root/bin/disk.sh,显示当前硬盘分区中空间利用率最大的值

脚本内容如下:

3.png

运行结果如下:

3.1.png

4、编写脚本/root/bin/links.sh,显示正连接本主机的每个远程主机的IPv4地址和连接数,并按连接数从大到小排序

脚本内容如下:

4.png

执行结果:

4.1.png

5、写一个脚本/root/bin/sumid.sh,计算/etc/passwd文件中的第10个用户和第20用户的ID之和

脚本内容如下:

5.png

结果如下:

5.1.png

6、写一个脚本/root/bin/sumspace.sh,传递两个文件路径作为参数给脚本,计算这两个文件中所有空白行之和

脚本内容如下:

6.png

结果如下:

6.1.png

7、写一个脚本/root/bin/sumfile.sh,统计/etc, /var, /usr目录中共有多少个一级子目录和文件

脚本内容如下:

7.png

结果如下:

7.1.png

8、写一个脚本/root/bin/argsnum.sh,接受一个文件路径作为参数;如果参数个数小于1,则提示用户“至少应该给一个参数”,并立即退出;如果参数个数不小于1,则显示第一个参数所指向的文件中的空白行数

脚本内容如下:

8.png

结果如下:

8.1.png

9、写一个脚本/root/bin/hostping.sh,接受一个主机的IPv4地址做为参数,测试是否可连通。如果能ping通,则提示用户“该IP地址可访问”;如果不可ping通,则提示用户“该IP地址不可访问”

脚本内容如下:

9.png

结果如下:

9.1.png

10、chmod -rw /tmp/file1,编写脚本/root/bin/per.sh,判断当前用户对/tmp/fiile1文件是否不可读且不可写

脚本内容如下:

10.png

结果如下:

10.1.png

11、编写脚本/root/bin/nologin.sh和login.sh,实现禁止和充许普通用户登录系统。

脚本内容如下:

5.png

结果如下:

6.png

12、写一个脚本/root/bin/hostping.sh,接受一个主机的IPv4地址做为参数,先判断是否合格IP,否,提示IP格式不合法并退出,是,测试是否可连通。如果能ping通,则提示用户“该IP地址可访问”;如果不可ping通,则提示用户“该IP地址不可访问”

脚本内容如下:

2.png

结果如下:

2.1.png

13、计算1+2+3+…+100的值

脚本内容如下:

3.png

结果如下:

3.1.png

14、计算从脚本第一参数A开始,到第二个参数B的所有数字的总和,判断B是否大于A,否提示错误并退出,是则计算之

脚本内容如下:

3.png

结果如下:

32.png

原创文章,作者:mengzhiqian,如若转载,请注明出处:http://www.178linux.com/34786

(0)
mengzhiqianmengzhiqian
上一篇 2016-08-15
下一篇 2016-08-15

相关推荐

  • Linux的软链接和硬链接区别

    在Linux中,为了方便文件的使用,引入了两种链接,即为软链接和硬链接。 那么什么是硬链接,什么又是软链接呢。 简单来说,硬链接就是一个inode号对应多个文件名,也就是说一个文件使用了多个别名。 首先先来看看我们要创建硬连接的文件信息: [root@localhost ~]# ll -i /root &nb…

    Linux干货 2016-10-20
  • Nginx lnmp环境及https的实现

    一、http事务简明  request: <method> <URL> <VERSION> MHADERS <body> response: <version><status><reason phrase> <HEADERS> … <body&…

    2014-09-25
  • linux 学习总结第二周

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。    常用的文件管理类工具:cp,mv,rm     命令cp用于文件拷贝,分为单源文复制和多源复制 单源复制语法:cp [options]…[-t] source dest 。 注意事项: 1如果dest不存在,则事先创建此文件…

    Linux干货 2016-12-04
  • 计算机的组成以及OS的发展历程

        根据冯诺依曼提出的体系架构,计算机基本上可以分为五大部件。这五大部件分别为运算器,控制器,内存,输入设备与输出设备,其中运算器与控制器是CPU的重要组成部分。下面分别介绍这5大部件:     CPU:运算器、控制器、寄存器、缓存      &…

    Linux干货 2016-10-30
  • rsyslog+mariadb+loganalyzer实现日志采集分析

    一、总述   Linux的日志记录了用户在系统上一切操作,这些日志是使用者了解服务器的情况最好的资料。Rsyslog 是系统的一部分,能够实时的写日志,并且还可以将日志选择性的发送到远程日志服务器。   rsyslog日志服务器的优势:     1、日志统一,集中式管理     &nbsp…

    Linux干货 2017-01-10
  • 8月3日作业

    文件权限相关的课堂练习: 1)当用户xiaoming对/testdir 目录无执行权限时,意味着无法做哪些操作?     用户小明不能进入/testdir,不能删除,不能创建。使用ll能看到有哪些文件,但是看不到具体信息 2)当用户xiaoqiang对/testdir 目录无读权限时,意味着无法做哪些操作? 不能查看文…

    Linux干货 2016-08-07

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-16 16:26

    对位置变量总结的详细,作业完成的也很认真,但是对各个变量之间的差别,更应用场景需要有一个完整的总结哦,