一、 实验准备(预防抄袭,此步必做)

1. 请将提示符设为:学号加波浪号。输入PS1=学号~,如PS1=110015~, 回车执行

2. 如发现提示符、学号不匹配, 视为抄袭或无效

二、 实验项目

1. for循环控制命令

执行命令:

host www.****.edu.cn

可以得到它的ip地址: 222.175.157.209

假如现在我们要测试222.175.157.1到222.175.157.254这个范围内哪些ip处于活跃状态,那些处于非活跃状态,需要重复ping这些ip地址。可以采用for循环,下面做个实验:

执行命令

touch test41

打开test41,输入:

存盘退出,执行命令

chmod +x test41

输入 ./test41 执行:

(下面粘贴执行截图Ê)

$ 这里有几点需要注意:

  • 使用了输出追加重定向操作>>
  • alive=$(命令)的意思是命令替换,即把命令的执行结果保存在变量alive中,因为默认情况下,命令的输出是标准输出,即屏幕,而不是变量。
  • 关于命令替换,见教材207页
  • 命令wc –l alive.data统计文件中的行数,但命令共输出两个域,通过cut –f1命令把第一个域截取出来。-d指定域之间的分隔符是空白,注意单引号之间要有一个空格
  • 关于ping命令中-w 、-c选项的含义,参考man ping,请自学
  • {1..254}是一个集合,意思是从1到254

执行命令

ls –lh | grep data

可以看到两个文件:

(下面粘贴执行截图Ê)

执行命令

cat alive.data not_alive.data | more

可以看到:

(下面粘贴执行截图Ê)

思考题

如果每次执行这个脚本,文件alive.data、 not_alive.data都保存了上次执行的结果,这是不正确的。ping之前,需要把文件alive.data、not_alive.data清空,应该在程序中如何处理?请重新改写上面的脚本,并测试你的程序。

(下面粘贴你的程序,以及执行截图Ê)提示:参考 man truncate

下面再做过一个批量生成空白文件的实验

执行命令 touch test42,在文件test42中,键入:

然后键入bash test42, 可以看到

(下面粘贴执行截图Ê)

最后执行命令rm *.log 删除这些临时文件

2. break语句

请同学们自己做,教材241页,程序break01.sh

(下面粘贴执行截图Ê)

3. select循环

教材238页,程序select01.sh

(下面粘贴执行截图Ê)

4. until循环控制

until的语法是

until condition

do

……

done

只要条件condition不满足,就反复循环,直到条件满足为止

下面做个实验,如果你有事要找root先生,那么当root登陆后,立即响铃一声,并提示你

执行命令 touch test43, 在文件test43中键入:

然后执行命令

chmod +x test43

./test43 root

接下来,按ctrl + alt + F2, 以root身份登陆。再按ctrl + alt + F7返回,

可以看到:

(下面粘贴执行截图Ê)

$ 这里有几点注意:

  • 为了保持脚本安静运行,输出被扔掉了
  • $1就是第一个参数,也就是命令行传进来的root
  • \a的意思是让铃铛alarm一声
  • sleep 50 的意思是暂停50秒,否则反复测试会消耗CPU资源

5. while循环

教材235页,程序while03.sh

(下面粘贴执行截图Ê)

Linux的Shell练习--个人笔记的更多相关文章

  1. Linux shell 菜鸟学习笔记....

    20171123 Linux shell 基础学习笔记1. shell 的开始 一般是 #!/bin/bash 通过 #! 来唯一指定使用的shell路径 其他的 # 都表示注释.2. shell 的 ...

  2. 《The Linux Command Line》 读书笔记02 关于命令的命令

    <The Linux Command Line> 读书笔记02 关于命令的命令 命令的四种类型 type type—Indicate how a command name is inter ...

  3. 《The Linux Command Line》 读书笔记01 基本命令介绍

    <The Linux Command Line> 读书笔记01 基本命令介绍 1. What is the Shell? The Shell is a program that takes ...

  4. loadrunner调用plink,远程linux执行shell命令

    loadrunner调用plink,远程linux执行shell命令   脚本: Action() {   char* cmd; cmd = lr_eval_string("C:\\\&qu ...

  5. Linux及Arm-Linux程序开发笔记(零基础入门篇)

    Linux及Arm-Linux程序开发笔记(零基础入门篇)  作者:一点一滴的Beer http://beer.cnblogs.com/ 本文地址:http://www.cnblogs.com/bee ...

  6. Linux——帮助命令简单学习笔记

    Linux帮助命令简单学习笔记: 一: 命令名称:man 命令英文原意:manual 命令所在路径:/usr/bin/man 执行权限:所有用户 语法:man [命令或配置文件] 功能描述:获得帮助信 ...

  7. Linux操作系统及应用课程笔记 索引

    第0部分  软件的安装与配置 Linux下软件的安装与配置 第1部分*   绪论 第2部分*  Linux的安装过程 第3部分   系统Shell和经常使用命令 Shell文件相关经常使用命令及參数总 ...

  8. Linux内核设计与实现笔记_1_基本概念

    Linux内核设计与实现笔记_1_基本概念 操作系统 系统这个词包含了操作系统和所有运行在它上面的应用程序.操作系统是指在整个系统中负责完成分最基本功能和系统管理的那些部分,这些部分应该包括: 内核, ...

  9. 【Linux开发】Linux及Arm-Linux程序开发笔记(零基础入门篇)

    Linux及Arm-Linux程序开发笔记(零基础入门篇) 作者:一点一滴的Beer http://beer.cnblogs.com/ 本文地址:http://www.cnblogs.com/beer ...

随机推荐

  1. WPF仿网易云音乐系列(序)

    1.简介 由于之前做了一个播放器,苦于不懂界面设计,只得去借鉴借鉴一些成功的作品,网易云音乐就甚合朕心,哈哈,最后做出来的效果如下: 本系列文章就来和大家讨论以下,如何用WPF去仿制一个网易云音乐来: ...

  2. OO博客作业2:第5-7周作业总结

    (1)从多线程的协同和同步控制方面,分析和总结自己三次作业来的设计策略及其变化. 第5次作业:多线程电梯 基本照搬了课件上“生产者-消费者”模型的设计策略,将InputHandler设计为生产者线程, ...

  3. Appium-实现手势密码登陆

    前言: 前几天有人问我,手势登陆如何做?于是我找了一个APP试了试,所以本文来总结使用Python+Appium来实现手势密码登陆APP. 环境: MacOS:10.13.4 Appium-deskt ...

  4. python-入门的第一个爬虫例子

    前言: 此文为大家入门爬虫来做一次简单的例子,让大家更直观的来了解爬虫. 本次我们利用 Requests 和正则表达式来抓取豆瓣电影的相关内容. 一.本次目标: 我们要提取出豆瓣电影-正在上映电影名称 ...

  5. Python_服务器与多客户端通信、UDP协议、pycharm打印带颜色输出、时间同步的机制

    1.服务器与多客户端通信 import socket # 创建tcp socket的套接字 sk = socket.socket() # bind sk.bind(('127.0.0.1',8080) ...

  6. CodeForces Round #548 Div2

    http://codeforces.com/contest/1139 A. Even Substrings You are given a string s=s1s2…sns=s1s2…sn of l ...

  7. 正则校验:微信号,qq号,邮箱

    java判断微信号.手机.名字的正则表达 - willgos - 博客园https://www.cnblogs.com/solossl/p/5813106.html 微信号正则校验,qq正则,邮箱正则 ...

  8. 简要了解 MySql 5.5/5.6/5.7/8 出现的新特性

    MySQL的开发周期 在比较之前,首先提一下MySQL的开发周期. MySQL一个大版本的开发,大致经历如下几个阶段: Feature Development Feature Testing Perf ...

  9. css3新属性box-orient

    前言 box-orient属性经常与display:box属性结合使用 div { width:350px; height:100px; border:1px solid black; /* Fire ...

  10. 4 Past progressive VS simple past

    1 一般过去时用来谈论过去开始和结束的活动.过去进行时用来谈论过去正在进行或者发生的活动. Why were you at office so later yesterday? I was worki ...