Linux第九周总结

1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现;

#!/bin/bash
#
login_user=0
nologin_user=0
for i in $(cat /etc/passwd | cut -d : -f 7);do
    if [ $i == "/sbin/nologin" ];then
        let nologin_user++
    else
        let login_user++
    fi
done
 
echo "login_user=$login_user, nologin_user=$nologin_user"

2、写一个脚本

(1) 获取当前主机的主机名,保存于hostname变量中;

(2) 判断此变量的值是否为localhost,如果是,则将当前主机名修改www.magedu.com

(3) 否则,则显示当前主机名;

#!/bin/bash
#
hostname=$(/bin/hostname)
if [ $hostname == "localhost" ];then
    hostname www.magedu.com
    echo "111"
else
    hostname
fi

 

3、写一个脚本,完成如下功能

    (1) 传递一个磁盘设备文件路径给脚本,判断此设备是否存在;

(2) 如果存在,则显示此设备上的所有分区信息;

#!/bin/bash
#
if [[ $1 =~ /dev/sd* ]];then
    for i in $1;do
        fdisk -l $i
    done
else
    echo "Not a disk device file"
fi

 

4、写一个脚本,完成如下功能

   脚本能够接受一个参数;

   (1) 如果参数1quit,则显示退出脚本,并执行正常退出;

   (2) 如果参数1yes,则显示继续执行脚本;

   (3) 否则,参数1为其它任意值,均执行非正常退出;

#!/bin/bash
#
cat <<EOF
    1.quit
    2.yes
EOF
 
read -p "Please enter (quit or yes):" name
 
case $name in
quit)
    echo "Sign out"
    exit
    ;;
yes)
    echo "Continue implementation"
    ;;
*)
    exit 2
    ;;
esac

 

5、写一个脚本,完成如下功能

   传递一个参数给脚本,此参数为gzipbzip2或者xz三者之一;

   (1) 如果参数1的值为gzip,则使用targzip归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.gz

   (2) 如果参数1的值为bzip2,则使用tarbzip2归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.bz2

   (3) 如果参数1的值为xz,则使用tarxz归档压缩/etc目录至/backups目录中,并命名为/backups/etc-20160613.tar.xz

   (4) 其它任意值,则显示错误压缩工具,并执行非正常退出;

#!/bin/bash
#
cat <<EOF
    1.gzip
    2.bzip2
    3.xz
EOF
 
read -p "Please enter (gzip or bzip2 or xz):" name
 
cd /
mkdir /backups &> /dev/null
 
case $name in
gzip)
    tar -zcf /backups/etc-20160613.tar.gz etc
    echo "gz is ok"
    exit 1
    ;;
bzip2)
    tar -jcf /backups/etc-20160613.tar.bz2 etc
    echo "bz2 is ok"
    exit 1
    ;;
xz)
    tar -Jcf /backups/etc-20160613.tar.xz etc
    echo "xz is ok"
    exit 1
    ;;
*)
    echo "Error compression tool"
    exit 1
    ;;
esac

 

6、写一个脚本,接受一个路径参数:

   (1) 如果为普通文件,则说明其可被正常访问;

   (2) 如果是目录文件,则说明可对其使用cd命令;

   (3) 如果为符号链接文件,则说明是个访问路径;

   (4) 其它为无法判断;

#!/bin/bash
#
read -p "Please enter the file type : " x
if [ -f $x ];then
        echo "You can access it properly"
exit 1
elif [ -d $x ];then
        echo "You can use the CD command"
exit 1
elif [ -h $x ];then
        echo "Is an access path"
exit 1
else
        echo "Unrecognized"
fi

 

7、写一个脚本,取得当前主机的主机名,判断

   (1) 如果主机名为空或为localhost,或为”(none)”,则将其命名为mail.magedu.com

#!/bin/bash
#
hostname=$(/bin/hostname)
if [ $hostname == "localhost" -o “(none)” ];then
    hostname www.magedu.com
    echo "111"
else
    hostname
fi

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

(0)
N27_yunerN27_yuner
上一篇 2017-08-28 16:53
下一篇 2017-08-28 18:35

相关推荐

  • 马哥教育网络班21期+第2周课程练习

    第二周练习 1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 cp、mv、rm、touch cp:copy,复制    SYNOPSIS        cp [OPTION]… [-T] SOURC…

    Linux干货 2016-07-07
  • tcp socket文件句柄泄漏

    今天发现有台redis机器上出现socket个数告警,这是很奇怪的现象。因为一台redis服务器上就部署了几个redis实例,打开的端口应该是有限。 1、netstat显示的tcp连接数正常 netstat -n | awk '/^tcp/ {++state[$NF]} END …

    Linux干货 2016-04-13
  • KeepAlived实现HAProxy双主并实现资源的动静分离

    KeepAlived实现HAProxy双主并实现资源的动静分离 前言 HAProxy介绍 实验拓扑 实验环境 实验步骤 配置后端httpd服务器 配置HAProxy实现backend负载均衡 测试动静分离效果 配置KeepAlived 测试KeepAlived 配置DNS DNS测试 最终测试 总结 前言 我们这次使用HAProxy作为负载均衡调度器来实现后…

    Linux干货 2016-04-16
  • DNS服务器搭建示例

    DNS服务器搭建示例 负责解析magedu.com域名,能够对一些主机名进行正向解析和逆向解析 配置主配置文件 [root@slave1 etc]# vim /etc/named.conf options { listen-on port 53 { 192.168.91.132; }; // listen-on-v6 port 53 { ::1; }; di…

    2017-09-16
  • Linxu系统的启动过程

    Linxu系统的启动过程 启动流程 1、引导Linux启动是从BIOS中的地址0xFFFF0处开始的,BIOS由两部分组成:POST代码和运行时服务,运行时服务是为操作系统提供一些接口,如温度检测等。 BIOS的第一个步骤是加电自检(POST),完成对硬件的的检测,如某些硬件出现错误无法通过检测就导致系统无法启动,POST完成之后将被清出内存; BIOS的第…

    Linux干货 2016-09-13
  • 学会在命令行中获取帮助

    在命令行中获取帮助是学习Linux必须get的一项技能,学会之后受益多多。  Linux中的命令有内部命令和外部命令之分,通常使用 type 命令来区分 除此之外还可以使用 enable 命令来查看内部命令 enable命令后的许多option可以对这些内部命令了解更多,比如: 想要知道内部命令有多少个 enable -a |wc -l 禁用某个内…

    2017-07-15