首页 > 系统相关 >基于linux下的shell脚本练习

基于linux下的shell脚本练习

时间:2023-01-03 12:35:08浏览次数:49  
标签:shell 练习 mnt westos sh file linux root localhost


shell脚本的简介:

打开文本编辑器(可以使用vi/vim命令来创建文件),新建一个文件test.sh,扩展名为sh(sh代表shell),扩展名并不影响
脚本执行,见名知意就好,如果你用php写shell 脚本,扩展名就用php好了。
输入一些代码,第一行一般是这样:
#!/bin/bash
echo "Hello World !"
"#!" 是一个约定的标记,它告诉系统这个脚本需要什么解释器来执行,即使用哪一种Shell。
echo命令用于向窗口输出文本。

shell脚本与C,java相比的优缺点:

脚本语言是解释性语言,运行效率相对低。
c,java是描述型语言,直接将动作描述给系统,运行效率高,c是一门创造性语言。
shell脚本记录系统命令,可以使命令批量执行。
gcc是编译器,而vim编辑器
#!/bin/bash 幻数,脚本运行时先运行此程序。
以.sh结尾语法是高亮的。

脚本的简单练习:(包括c,shell脚本)

c脚本练习:

[root@localhost ~]# yum install gcc -y  安装gcc编译器

基于linux下的shell脚本练习_IP

[root@localhost ~]# vim hello.c  编辑c语言文件

基于linux下的shell脚本练习_IP_02

[root@localhost ~]# gcc hello.c  默认编译生成a.out文件
[root@localhost ~]# ls
anaconda-ks.cfg Desktop Downloads ip_show.sh Pictures Templates
a.out Documents hello.c Music Public Videos
[root@localhost ~]# ./a.out 执行编译之后的a.out文件
hello world
[root@localhost ~]# gcc hello.c -o hello -o表示编译成为自己想要的文件名字
[root@localhost ~]# ls
anaconda-ks.cfg Desktop Downloads hello.c Music Public Videos
a.out Documents hello ip_show.sh Pictures Templates
[root@localhost ~]# ./hello 运行c脚本
hello world

基于linux下的shell脚本练习_IP_03

shell脚本练习:

[root@localhost ~]# vim ip_show.sh  编辑脚本,直接打印自己的IP,已知自己的IP

基于linux下的shell脚本练习_linux_04

[root@localhost ~]# sh ip_show.sh   用sh方式调用
172.25.254.121
[root@localhost ~]# chmod +x ip_show.sh 赋予执行权限调用
[root@localhost ~]# pwd 查看当前路径
/root
[root@localhost ~]# /root/ip_show.sh 绝对方式调用脚本
172.25.254.121

基于linux下的shell脚本练习_vim_05

[root@localhost ~]# vim ip_show.sh 用命令ifconfig eth0显示ip

基于linux下的shell脚本练习_IP_06

[root@localhost ~]# sh ip_show.sh  调用
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 172.25.254.121 netmask 255.255.255.0 broadcast 172.25.254.255
inet6 fe80::5054:ff:feed:2ec6 prefixlen 64 scopeid 0x20<link>
ether 52:54:00:ed:2e:c6 txqueuelen 1000 (Ethernet)
RX packets 2135 bytes 30343165 (28.9 MiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 1216 bytes 132752 (129.6 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

基于linux下的shell脚本练习_linux_07

[root@localhost ~]# vim ip_show.sh  用命令ifconfig显示ip,避免网卡不一致

基于linux下的shell脚本练习_vim_08

[root@localhost ~]# sh ip_show.sh  sh方式运行脚本

基于linux下的shell脚本练习_linux_09

[root@localhost ~]# cd /mnt
[root@localhost mnt]# ls
[root@localhost mnt]# vim hello.sh 编写shell脚本

基于linux下的shell脚本练习_vim_10

[root@localhost mnt]# sh hello.sh  sh调用
hello world
[root@localhost mnt]# chmod +x hello.sh 赋予权限
[root@localhost mnt]# /mnt/hello.sh 绝对路径调用
hello world

基于linux下的shell脚本练习_linux_11

自动给shell脚本赋予头文件以及解释信息:

[root@localhost mnt]# vim /etc/vimrc 编辑主配置文件

基于linux下的shell脚本练习_linux_12

[root@localhost mnt]# vim aa.sh 进入sh结尾的文件按F7会出来我们所显示的信息,但是每次这样按键特别麻烦

打开文件为空白:

基于linux下的shell脚本练习_vim_13

按一下F7(这里的按键是由我们自己设置的,找一个电脑空着的快捷键):

基于linux下的shell脚本练习_linux_14

[root@localhost mnt]# vim /etc/vimrc  编辑主配置文件,自动给sh结尾的新文件添加信息。
注释按键行只需要在行首一个双引号即可。

基于linux下的shell脚本练习_vim_15

[root@localhost mnt]# vim bb.sh   以sh结尾的新文件才会显示信息
[root@localhost mnt]# cat bb.sh
[root@localhost mnt]# vim bb.sh 再次编辑因为不是新文件,只会生成一次
[root@localhost mnt]# cat bb.sh

基于linux下的shell脚本练习_IP_16

[root@localhost mnt]# vim cc.sh  编辑新文件会再次生成
[root@localhost mnt]# cat cc.sh

基于linux下的shell脚本练习_vim_17

shell的常用命令操作-diff命令:

[root@localhost mnt]# ls
[root@localhost mnt]# vim westos 编辑两个不同的文件
[root@localhost mnt]# cat westos
hello 123
westos
[root@localhost mnt]# vim westos1
[root@localhost mnt]# cat westos1
hello 123
[root@localhost mnt]# diff westos westos1 比较
2d1 意思是将第一个文件的第二行删除就变成第二个文件
< westos

基于linux下的shell脚本练习_linux_18

[root@localhost mnt]# vim westos1 
[root@localhost mnt]# cat westos1
hello 123
linux
[root@localhost mnt]# diff westos westos1 比较
2c2 意思就是将第一个文件的第二行改变就变成第二个文件
< westos
---
> linux

基于linux下的shell脚本练习_vim_19

[root@localhost mnt]# vim westos
[root@localhost mnt]# cat westos
hello 123
[root@localhost mnt]# diff westos westos1 比较
1a2 意思就是第一个文件添加linux就变成第二个文件
> linux

基于linux下的shell脚本练习_vim_20

[root@localhost mnt]# ls
westos westos1
[root@localhost mnt]# diff -u westos westos1 创建补丁文件
--- westos 2018-06-09 22:47:10.397772937 -0400
+++ westos1 2018-06-09 22:46:44.134772937 -0400
@@ -1 +1,2 @@
hello 123
+linux
[root@localhost mnt]# diff -u westos westos1 > westos.path 将补丁文件重定向到westos.path
[root@localhost mnt]# cat westos.path 查看补丁保存文件
--- westos 2018-06-09 22:47:10.397772937 -0400
+++ westos1 2018-06-09 22:46:44.134772937 -0400
@@ -1 +1,2 @@
hello 123
+linux
[root@localhost mnt]# yum install patch -y 安装补丁命令

基于linux下的shell脚本练习_IP_21

[root@localhost mnt]# ls
westos westos1 westos.path
[root@localhost mnt]# patch westos westos.path 执行补丁文件
patching file westos
[root@localhost mnt]# ls
westos westos1 westos.path
[root@localhost mnt]# cat westos 两个文件通过补丁操作变成一样的
hello 123
linux
[root@localhost mnt]# cat westos1
hello 123
linux

基于linux下的shell脚本练习_linux_22

[root@localhost mnt]# vim westos  更改成不一样的两个文件
[root@localhost mnt]# cat westos
hello 123
[root@localhost mnt]# patch -b westos westos.path 保存源文件
patching file westos
[root@localhost mnt]# ls
westos westos1 westos.orig westos.path
[root@localhost mnt]# cat westos.orig 源文件
hello 123
[root@localhost mnt]# cat westos
hello 123
linux
[root@localhost mnt]# ls
westos westos1 westos.orig westos.path
[root@localhost mnt]# mkdir linux unix
[root@localhost mnt]# touch linux/aa
[root@localhost mnt]# touch unix/bb
[root@localhost mnt]# diff -r linux/ unix/ 比较目录
Only in linux/: aa
Only in unix/: bb

基于linux下的shell脚本练习_vim_23

cut命令:多用于字符截取:

cut -d 指定分隔符
cut -f 1,7|1-7 指定截取的列
cut -c 1,4|1-4 指定截取的字符位置

cut命令用法演示:

[root@localhost mnt]# rm -fr *
[root@localhost mnt]# cp /etc/passwd .
[root@localhost mnt]# ls
passwd
[root@localhost mnt]# vim passwd
[root@localhost mnt]# cat passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
[root@localhost mnt]# cut -d : -f 1 passwd -d指定分隔符
root
bin
[root@localhost mnt]# cut -d : -f 1,2 passwd -f指定截取的列
root:x
bin:x
[root@localhost mnt]# cut -d : -f 1-3 passwd
root:x:0
bin:x:1

基于linux下的shell脚本练习_vim_24

[root@localhost mnt]# cut -d : -f 1- passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
[root@localhost mnt]# cut -d : -f 3- passwd
0:0:root:/root:/bin/bash
1:1:bin:/bin:/sbin/nologin
[root@localhost mnt]# cut -c 1,3 passwd -c指定截取的字符位置
ro
bn
[root@localhost mnt]# cut -c 1-3 passwd
roo
bin

基于linux下的shell脚本练习_vim_25

脚本1显示自己电脑的IP:

[root@localhost mnt]# vim ipshow.sh 编辑脚本文件

基于linux下的shell脚本练习_IP_26

[root@localhost mnt]# sh ipshow.sh 直接显示自己的IP
172.25.254.121

基于linux下的shell脚本练习_linux_27

脚本2显示自己电脑的IP:

[root@localhost mnt]# vim ipshow.sh 编辑脚本文件

基于linux下的shell脚本练习_linux_28

[root@localhost mnt]# sh ipshow.sh 直接显示自己的IP
172.25.254.121

基于linux下的shell脚本练习_linux_29

脚本3显示自己电脑的IP:

[root@localhost mnt]# vim ipshow.sh 编辑脚本文件

基于linux下的shell脚本练习_vim_30

[root@localhost mnt]# sh ipshow.sh 直接显示自己的IP
172.25.254.121

基于linux下的shell脚本练习_IP_31

基于linux下的shell脚本练习_linux_29

但是这三个脚本都存在BUG:

脚本4显示自己电脑的IP:(用awk命令呈现)

[root@localhost mnt]# vim ipshow.sh  编辑脚本文件

基于linux下的shell脚本练习_linux_33

[root@localhost mnt]# sh ipshow.sh  调用脚本文件
172.25.254.121

基于linux下的shell脚本练习_IP_34

脚本出错的检测:

[root@localhost mnt]# vim ipshow.sh 
[root@localhost mnt]# sh ipshow.sh 脚本出错的检测
ipshow.sh: line 11: ifconfg: command not found ifconfig命令写错
[root@localhost mnt]# sh -x ipshow.sh -x检测脚本
+ ifconfg eth0
ipshow.sh: line 11: ifconfg: command not found
+ awk -F ' ' '/inet\>/{print $2}'

基于linux下的shell脚本练习_linux_35

[root@localhost mnt]# vim ipshow.sh  修改之后检测
[root@localhost mnt]# sh -x ipshow.sh 已经有了运行结果
+ ifconfig eth0
+ awk -F ' ' '/inet\>/{print $2}'
172.25.254.121

基于linux下的shell脚本练习_linux_36

&&和||命令:

&&用来执行条件成立后执行的命令
||用来执行条件不成立后执行的命令
c次数,w等待时间
[root@localhost mnt]# ping -c1 -w1 172.25.254.121 &> /dev/null 
[root@localhost mnt]# ping -c1 -w1 172.25.254.121 &> /dev/null && echo 172.25.254.121 is up || echo 172.25.254.121 is down 意思就是满足条件输出172.25.254.121 is up,不满足条件输出172.25.254.121 is down
172.25.254.121 is up
[root@localhost mnt]# ping -c1 -w1 172.25.254.333 &> /dev/null && echo 172.25.254.333 is up || echo 172.25.254.333 is down 意思就是满足条件输出172.25.254.333 is up,不满足条件输出172.25.254.333 is down
172.25.254.333 is down

基于linux下的shell脚本练习_IP_37

检测ip是否运行脚本:

[root@localhost mnt]# vim check_ip.sh  编写脚本

基于linux下的shell脚本练习_IP_38

[root@localhost mnt]# sh check_ip.sh 172.25.254.111 调用脚本检测
172.25.254.111 is up
[root@localhost mnt]# sh check_ip.sh 172.25.254.232
172.25.254.232 is down

基于linux下的shell脚本练习_IP_39

sort命令多用于字符排序:

sort -n   纯数字排序
sort -r 倒序
sort -u 去掉重复数字
sort -o 输出到指定文件中
sort -t 指定分隔符
sort -k 指定要排序的列

uniq命令对重复字符做相应的处理

uniq -u  显示唯一的行
uniq -d 显示重复的行
uniq -c 每行显示一次并统计重复次数

sort和uniq命令经常一起使用:

[root@localhost mnt]# rm -fr *
[root@localhost mnt]# ls
[root@localhost mnt]# vim westos

基于linux下的shell脚本练习_vim_40

[root@localhost mnt]# sort westos 只会对第一行排序
[root@localhost mnt]# sort -n westos 纯数字排序

基于linux下的shell脚本练习_IP_41

[root@localhost mnt]# sort -rn westos 纯数字倒序排序
[root@localhost mnt]# sort -rnu westos 纯数字倒序排序去掉重复数字

基于linux下的shell脚本练习_vim_42

[root@localhost mnt]# sort -rnu westos -o file 纯数字倒序排序去掉重复数字重定向到文件中
[root@localhost mnt]# cat file

基于linux下的shell脚本练习_IP_43

[root@localhost mnt]# vim westos   写入分隔符

基于linux下的shell脚本练习_vim_44

[root@localhost mnt]# sort -rn westos  有分隔符单纯无法排列,只对第一行排序
[root@localhost mnt]# sort -rn westos -t : -k 2 指定分隔符为:指定列数为第二列进行排序

基于linux下的shell脚本练习_vim_45

[root@localhost mnt]# vim westos  随即编写一串数字,演示uniq命令和sort命令的结合

基于linux下的shell脚本练习_IP_46

[root@localhost mnt]# sort -n westos | uniq -u  显示唯一的行
[root@localhost mnt]# sort -n westos | uniq -d 显示重复的行
[root@localhost mnt]# sort -n westos | uniq -c 每行显示一次并统计重复次数,前边是字符出现的次数

基于linux下的shell脚本练习_IP_47

编写脚本列出/mnt目录中最大文件的名称:

[root@localhost mnt]# vim check_file.sh   编辑脚本

基于linux下的shell脚本练习_linux_48

[root@localhost mnt]# ls -Sl /mnt     /mnt目录中文件大小不同
total 12
-rw-r--r-- 1 root root 322 Jun 11 08:03 check_file.sh
-rw-r--r-- 1 root root 278 Jun 11 08:03 bb.sh
-rw-r--r-- 1 root root 272 Jun 11 08:02 aa.sh
[root@localhost mnt]# sh check_file.sh 调用脚本可以找到最大的文件
check_file.sh

基于linux下的shell脚本练习_linux_49

test 命令:

test命令和[]等同
test "$A" == "$B" 等同[ "$A" == "$B" ]
[ "$A" -eq "$B" ] 等于
[ "$A" -ne "$B" ] 不等于
[ "$A" -le "$B" ] 小于等于
[ "$A" -lt "$B" ] 小于
[ "$A" -ge "$B" ] 大于等于
[ "$A" -gt "$B" ] 大于
-a代表与操作
-o代表或操作
-z为空[ -z "$A" ]
-n不为空 [ -n "$A" ]

用test命令解决测试ip时不输入IP出现的bug

[root@localhost mnt]# vim ip_show.sh  编写脚本

基于linux下的shell脚本练习_IP_50

[root@localhost mnt]# chmod +x /mnt/ip_show.sh  赋予权限
[root@localhost mnt]# /mnt/ip_show.sh 运行脚本
please input ipaddr!!
[root@localhost mnt]# /mnt/ip_show.sh 172.25.254.111 调用脚本
172.25.254.111 is down

基于linux下的shell脚本练习_linux_51

判断一个数字是否在1到10之间:

[root@localhost mnt]# vim nm_check.sh 编写脚本

基于linux下的shell脚本练习_linux_52

[root@localhost mnt]# chmod +x nm_check.sh  赋予执行权限
[root@localhost mnt]# /mnt/nm_check.sh 调用
please input a number
[root@localhost mnt]# /mnt/nm_check.sh 44
44 is not in range
[root@localhost mnt]# /mnt/nm_check.sh 4
4 is in range

基于linux下的shell脚本练习_IP_53

ef,nt,ot命令:

ef表示互为硬连接
nt表示新的时间
ot表示旧的时间
[root@localhost mnt]# ls
[root@localhost mnt]# touch file
[root@localhost mnt]# ln /mnt/file /mnt/file1 ln命令代表建立同样的链接
[root@localhost mnt]# ll
total 0
-rw-r--r-- 2 root root 0 Jun 10 02:59 file
-rw-r--r-- 2 root root 0 Jun 10 02:59 file1
[root@localhost mnt]# ls -li * 两个文件完全相同
11786435 -rw-r--r-- 2 root root 0 Jun 10 02:59 file
11786435 -rw-r--r-- 2 root root 0 Jun 10 02:59 file1
[root@localhost mnt]# [ "/mnt/file" -ef "/mnt/file1" ]&& echo yes || echo no 文件完全相同互为硬链接返回yes
yes
[root@localhost mnt]# [ "/mnt/file" -ef "/etc/passwd" ]&& echo yes || echo no 文件不相同不为硬链接返回no
no

基于linux下的shell脚本练习_IP_54

[root@localhost mnt]# ls
file file1
[root@localhost mnt]# rm -fr file1
[root@localhost mnt]# ll
total 0
-rw-r--r-- 1 root root 0 Jun 10 02:59 file
[root@localhost mnt]# touch file1 建立文件
[root@localhost mnt]# ll
total 0
-rw-r--r-- 1 root root 0 Jun 10 02:59 file
-rw-r--r-- 1 root root 0 Jun 10 03:02 file1 建立时间晚于file
[root@localhost mnt]# [ "file" -ot "file1" ]&& echo yes || echo no file1建立时间晚于file,用ot返回yes
yes
[root@localhost mnt]# [ "file" -nt "file1" ]&& echo yes || echo no file1建立时间晚于file,用nt返回no
no

基于linux下的shell脚本练习_linux_55

test 命令:

[ -e "file" ]是否存在
[ -f "file" ]是否为普通文件
[ -L "file" ]是否为软链接
[ -S "file" ]是否为套接字
[ -b "file" ]是否为块设备
[ -d "file" ]是否为目录
[ -c "file" ]是否为字符设备
[root@localhost mnt]# vim file.sh  建立脚本方便文件类型的测试

基于linux下的shell脚本练习_IP_56

[root@localhost mnt]# ls
file file1 file.sh
[root@localhost mnt]# rm -fr file file1
[root@localhost mnt]# ls
file.sh
[root@localhost mnt]# sh file.sh -e 文件不存在,为no
no
[root@localhost mnt]# touch file 建立文件
[root@localhost mnt]# sh file.sh -e 文件存在,为yes
yes
[root@localhost mnt]# sh file.sh -f file为普通文件
yes
[root@localhost mnt]# sh file.sh -L 不是软链接
no

基于linux下的shell脚本练习_linux_57

[root@localhost mnt]# ls
file file.sh
[root@localhost mnt]# rm -fr file
[root@localhost mnt]# ln -s /mnt/file.sh /mnt/file 制作软链接
[root@localhost mnt]# ll
total 4
lrwxrwxrwx 1 root root 12 Jun 10 03:31 file -> /mnt/file.sh
-rw-r--r-- 1 root root 300 Jun 10 03:29 file.sh
[root@localhost mnt]# sh file.sh -L file为软链接
yes
[root@localhost mnt]# sh file.sh -S fle不是套接字
no

基于linux下的shell脚本练习_linux_58

[root@localhost mnt]# yum install mariadb-server.x86_64  -y 安装数据库服务
[root@localhost mnt]# systemctl start mariadb 开启数据库服务
[root@localhost mnt]# ll /var/lib/mysql/ mysql.sock就是套接字
srwxrwxrwx 1 mysql mysql 0 Jun 11 08:28 /var/lib/mysql/mysql.sock
[root@localhost mnt]# rsync -D /var/lib/mysql/mysql.sock /mnt/file 远程传输套接字
[root@localhost mnt]# ll
total 4
srwxrwxrwx 1 root root 0 Jun 10 03:35 file
-rw-r--r-- 1 root root 300 Jun 10 03:29 file.sh
[root@localhost mnt]# sh file.sh -S file是套接字
yes
[root@localhost mnt]# sh file.sh -b file不是块设备
no

基于linux下的shell脚本练习_IP_59

[root@localhost mnt]# ls
file file.sh
[root@localhost mnt]# rm -fr file
[root@localhost mnt]# rsync -D /dev/vdb /mnt/file 远程传输块设备
[root@localhost mnt]# ll
total 4
brw-r----- 1 root root 253, 16 Jun 10 03:36 file
-rw-r--r-- 1 root root 300 Jun 10 03:29 file.sh
[root@localhost mnt]# sh file.sh -b file file是块设备
yes

基于linux下的shell脚本练习_IP_60

[root@localhost mnt]# rm -fr file
[root@localhost mnt]# mkdir /mnt/file 建立目录
[root@localhost mnt]# sh file.sh -b file不是块设备
no
[root@localhost mnt]# sh file.sh -d file是目录
yes
[root@localhost mnt]# sh file.sh -c file不是字符设备
no

基于linux下的shell脚本练习_vim_61

[root@localhost mnt]# rm -fr file
[root@localhost mnt]# rsync -D /dev/pts/1 /mnt/file 远程传输字符设备
[root@localhost mnt]# ll
total 4
crw------- 1 root root 136, 1 Jun 10 03:38 file
-rw-r--r-- 1 root root 300 Jun 10 03:29 file.sh
[root@localhost mnt]# sh file.sh -c file为字符设备
yes

基于linux下的shell脚本练习_vim_62

编辑一个脚本检测/mnt/file的文件类型:

[root@localhost mnt]# vim file_check.sh  编写脚本测试文件类型,就相当于把上面的命令依次测试一遍罢了

基于linux下的shell脚本练习_linux_63

[root@localhost mnt]# sh file_check.sh   调用脚本查看类型
please input a file name after script!!
[root@localhost mnt]# sh file_check.sh /var/lib/mysql/mysql.sock
/var/lib/mysql/mysql.sock is a taojiezi
[root@localhost mnt]# sh file_check.sh /dev/vdb
/dev/vdb is a block file
[root@localhost mnt]# sh file_check.sh /dev/pts/1
/dev/pts/1 is a zifushebei

基于linux下的shell脚本练习_vim_64

tr命令转换字符大小写:

[root@localhost mnt]# ls
[root@localhost mnt]# vim test.sh 区分大小写脚本

基于linux下的shell脚本练习_vim_65

[root@localhost mnt]# sh test.sh 
no
[root@localhost mnt]# sh test.sh hello 调用脚本测试
yes
[root@localhost mnt]# sh test.sh HELLO
no

基于linux下的shell脚本练习_vim_66

[root@localhost mnt]# tr 'a-z' 'A-Z' < test.sh  小写转换到大写
[root@localhost mnt]# tr 'A-Z' 'a-z' < test.sh 大写转换到小写

基于linux下的shell脚本练习_IP_67

[root@localhost mnt]# vim test.sh 不区分大小写脚本

基于linux下的shell脚本练习_IP_68

[root@localhost mnt]# sh test.sh hello     调用脚本测试
yes
[root@localhost mnt]# sh test.sh HELLO
yes

基于linux下的shell脚本练习_linux_69

用脚本建立一个用户user1,密码为123,存在的话返回用户已经存在:

脚本1:

[root@localhost mnt]# vim user_create.sh   建立脚本

基于linux下的shell脚本练习_linux_70

[root@localhost mnt]# sh user_create.sh xixi 123  调用脚本测试

基于linux下的shell脚本练习_IP_71

脚本2:

[root@localhost mnt]# vim user1_create.sh  建立脚本
[root@localhost mnt]# cat user1_create.sh
#!/bin/bash 检测是否有两串字符
[ "$#" -eq "2" ]||{
echo "please input username and password"
exit 1
}

check_user=`getent passwd $1` 检测是否为用户
[ -n "$check_user" ]&&{
echo $1 is exist!!
exit 1
}

useradd $1 建立用户赋予密码
echo $2 | passwd --stdin $1

基于linux下的shell脚本练习_IP_72

[root@localhost mnt]# sh user1_create.sh lalla 123  调用脚本
Changing password for user lalla.
passwd: all authentication tokens updated successfully.

基于linux下的shell脚本练习_linux_73

$#的用法,直接写入脚本测试:

[root@localhost mnt]# vim test.sh  写入$#

基于linux下的shell脚本练习_IP_74

[root@localhost mnt]# sh test.sh    调用测试
0
[root@localhost mnt]# sh test.sh 1
1
[root@localhost mnt]# sh test.sh 2
1
[root@localhost mnt]# sh test.sh 2 3
2
[root@localhost mnt]# sh test.sh 2 3 4 由测试可知$#的用法是后面有几个参数返回几
3

基于linux下的shell脚本练习_IP_75


标签:shell,练习,mnt,westos,sh,file,linux,root,localhost
From: https://blog.51cto.com/u_13831562/5985263

相关文章

  • 基于Linux下的yum源的搭建与共享
    yum命令:###yum命令仅仅是对软件进行管理,rpm命令才是真正安装软件的,yum的好处是可以解决软件依赖性。yum源的搭建:mkdir/iso    建立个目录mv/home/kiosk/Desktop/*.is......
  • 基于Linux下的虚拟机安装详解
    首先我们打开一个shell切换到超级用户,输入如下命令:[kiosk@foundation21Desktop]$pwd/home/kiosk/Desktop[kiosk@foundation21Desktop]$su-rootPassword:Lastlogin:F......
  • 利用Barrier使局域网下的Linux(Majaro)和Window10共享同一套键盘鼠标
    项目场景:现有两台电脑:一台笔记本(Win10)连接无线网(DHCP)一台工作站(Linux-Manjaro)连接无线网(DHCP)为了简化桌面、便于操作,打算让笔记本和工作站共用一套键盘鼠标。问题分......
  • Linux下的pip和pip3的冲突问题
    大佬们有啥解决办法还请不吝赐教!前言最近在使用pip命令的时候,总是报如下错误:查询了很多解决方式还是未能解决.但是pip3命令的使用却没任何问题.问题初步解决今天翻看到......
  • 用Xftp给linux虚拟机传输文件时失败:Permission is not allowed!
    一直提示错误:点开发现了传输错误信息 Permissionisnotallowed!意思就是权限不够,那就到虚拟机更改该文件夹的权限。sudochmod777opt ......
  • linux回炉第十三天
    systemdsystemctlis-activenginxsystemctlstatusnginxsystemctlstartnginxsystemctlstopnginxsystemctlenablenginxsystemctldisablenginxsystemctlenable--n......
  • Shell脚本基础
    一、shell脚本1、Shell作用Linux系统中的Shell是一个特殊的应用程序,它介于操作系统内核与用户之间,充当了一个“命令解释器”的角色,负责接收用户输入的操作指令(命令)并......
  • Linux安装node
    说明亲测在Ubuntu环境下安装成功如果包管理器中有合适版本建议使用apt-get或yum等命令直接安装以Ubuntu系统为例,可以使用如下命令查看nodejs版本sudoapt-getupdat......
  • Linux-Shell编程
    1.Shell(1)Shell脚本是什么?一个Shell脚本是一个文本文件,包含一个或多个命令。作为系统管理员,我们经常需要使用多个命令来完成一项任务,我们可以添加这些所有命令在一个文......
  • Linux基础:ssh与scp
    登陆登陆服务器sshuser@hostnameuser:用户名hostname:IP地址或域名第一次登陆会提示Theauthenticityofhost'123.57.47.211(123.57.47.211)'can......