前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >09_Linux基础-SHELL-标准输入与标准输出-重定向-管道

09_Linux基础-SHELL-标准输入与标准输出-重定向-管道

原创
作者头像
mycpen
发布2022-09-02 18:57:29
2K0
发布2022-09-02 18:57:29
举报
文章被收录于专栏:mycpen笔记

@TOC

09_Linux基础-SHELL-标准输入与标准输出-重定向-管道


作业 编辑文本文件/home/text/file1,分4行输入bbb bbb bbb、 ddd ddd ddd、aaa aaa aaa、ccc ccc ccc。 保存不要退出; 在末行模式下打开一个新文件/text/file2; 在file2中输入内容为eee eee eee在这一行内容之后, 将file1的内容读入到file2中,接着在命令模式下按照 abcde的显示顺序调整每行的位置,最后保存退出; 同时编辑file1和file2,接着从file1切换到file2,然后 再快速切换回来,接着将file2的内容读到file1内容的末尾,显示文件file1内容的行号,复制3到6行到file1 内容的末尾; 利用替换命令将全文的每行第一个ccc都替换为333; 将全文中所有aaa都替换为111,撤销行号,最后不保 存退出;

[root@sanchuang-linux chenpeng]# mkdir /home/text2 [root@sanchuang-linux chenpeng]# cd /home/text2 [root@sanchuang-linux chenpeng]# mkdir /text2 [root@sanchuang-linux text2]# vim file1 :r /text2/file2 aaa aaa aaa bbb bbb bbb ccc ccc ccc ddd ddd ddd eee eee eee [root@sanchuang-linux text2]# vim file1 /text2/file2 :n :N :set nu :%s/ccc/333 :%s/aaa/111/g :set nonu :q!


练习1: 1.进入/lianxi目录 # cd /lianxi 2.复制/etc/passwd文件到当前目录下,然后使用vim编辑当前目录下的passwd # cp /etc/passwd . # vim passwd 3.显示一下行号 :set nu 4.复制第5到10行的内容,粘贴到末尾,删除最后一行的最后一个单词 :5 ; 6yy ; G ; p ; dw 5.删除第9行和第10行 :9 ; 2dd 6.将root改为gen :%s/root/gen/g 7.删除部分bash字符串 :%s/bash//gc 8.快速到达第5行,然后再跳到第1行,再跳到最后一行 :5 ; :1 ; G 9.剪切第6-7行,粘贴到末尾 :6 ; 2dd ; G ; p 10.退出并且保存 :wq 11.复制/etc/hosts文件到当前目录下,将第1列的ip地址复制,然后粘贴到文件的末尾 # /etc/hosts . ; # vim hosts ; ctrl+v ; y ; G ;p


一. SHELL-标准输入与标准输出

学习内容:重定向和文件目录高级操作

知识要点 输入输出重定向 管道及相关配套命令 数据提取及过滤 文件差异对比和补丁生成及打补丁

标准输入和标准输出

知识点1 标准输入和标准输出

--------------------------- 输入输出及重定向 每个进程基本都会打开三个文件描述符 0: 标准输入(从键盘) 1: 标准输出 (输出到屏幕) 2: 标准错误输出 (输出到屏幕) 类型 设备文件 文件描述符(fd) 默认设备 标准输入 /dev/stdin 0 键盘 标准正确输出 /dev/stdout 1 显示器 标准错误输出 /dev/stderr 2 显示器 ------------------------------------------------------- 标准输入(stdin)和标准输出(stdout) ------------------------------------ python中 >>>help(print) file=sys.stdout 默认输出到屏幕(标准输出) ------------------------------------------------------------------ 进程:正在进行的程序 --------------------- 键盘 =》 标准输入 =》 终端程序 =》 标准输出 =》显示器 标准错误输出 =》显示器 ---------------------------------------------------------- https://blog.csdn.net/xiaofei0859/article/details/78448493?utm_source=blogxgwz9 每个进程基本都会打开三个文件描述符 0:标准输入 (从键盘、语音、人脸识别……) 1:标准输出 (输出到屏幕) 2:标准错误输入(输出到屏幕) --------------------------- 文件描述符:fd 就是每个进程打开的文件

文件描述符

知识点1.1 文件描述符

文件描述符: linux内核给每个进程都创造一个文件描述符,这个表里记载了这个进程所打开的所有文件,为了方便进程知道自己打开了哪些文件呢,就给每个文件都进行了标号,这个编号就是文件描述符。 此后,所有对文件的操作,就是用该编号。

linux下面一切皆文件

知识点1.2 linux下面一切皆文件

linux下面一切皆文件

disk磁盘

/dev目录下面基本都是块设备文件

[root@sanchuang-linux ~]# cd /dev [root@sanchuang-linux dev]# cd disk [root@sanchuang-linux disk]# ls by-id by-label by-partuuid by-path by-uuid [root@sanchuang-linux disk]# cd .. [root@sanchuang-linux dev]# ls -ld sda1 brw-rw----. 1 root disk 8, 1 10月 6 17:16 sda1 [root@sanchuang-linux dev]# ls -ld sda2 brw-rw----. 1 root disk 8, 2 10月 6 17:16 sda2 ------------------------------------------------ [root@sanchuang-linux dev]# cd net [root@sanchuang-linux net]# ls tun [root@sanchuang-linux net]# ---------------------------- 对文件的操作就是对设备的操作 ---------------------------- [root@sanchuang-linux ~]# cd /dev [root@sanchuang-linux dev]# ls stderr stdin Stdout fd …… --------------------------------- [root@sanchuang-linux ~]# cd /dev [root@sanchuang-linux dev]# cd fd [root@sanchuang-linux fd]# ls 0 1 2 255 [root@sanchuang-linux fd]# ls -al 总用量 0 dr-x------. 2 root root 0 10月 16 10:40 . dr-xr-xr-x. 9 root root 0 10月 16 10:40 .. lrwx------. 1 root root 64 10月 16 10:40 0 -> /dev/pts/6 #(注:链接的意思,快捷方式 指向 /dev/pts/6,标准输入到虚拟终端6) lrwx------. 1 root root 64 10月 16 10:40 1 -> /dev/pts/6 #(注:标准输出到虚拟终端6) lrwx------. 1 root root 64 10月 16 10:40 2 -> /dev/pts/6 #(注:标准错误输出到虚拟终端6) lrwx------. 1 root root 64 10月 16 11:24 255 -> /dev/pts/6 [root@sanchuang-linux fd]# ---------------------------------------

虚拟终端pts 真实终端tty

知识点1.3 虚拟终端pts 真实终端tty

root@sanchuang-linux dev# cd /dev/pts root@sanchuang-linux pts# ls 0 1 2 3 4 5 6 ptmx root@sanchuang-linux pts#

pts是别人连接到服务器的虚拟终端(远程控制)。别人远程连接会创建虚拟终端

pts虚拟终端

----------------------------------------------------- Linux centos登录——》本地的终端shell环境 真实终端 xshell连接 ——》虚拟终端 -------------------------------- tty 本地真实终端 [root@sanchuang-linux dev]# cd /dev [root@sanchuang-linux dev]# ls tty

查看当前linux登陆的用户情况

知识点1.4 查看当前linux登陆的用户情况

查看当前linux登陆的用户情况 # w

root@sanchuang-linux dev# w 11:32:52 up 16:23, 4 users, load average: 0.00, 0.00, 0.00 USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT root tty1 - 0610月20 1:32m 0.60s 0.60s -bash (注:bash环境) root pts/1 192.168.0.26 10:03 25:40 0.21s 0.21s -bash (注:bash环境) root pts/2 10.122.155.164 08:52 2:29m 0.16s 0.13s vim -r a (注:删除环境) root pts/6 192.168.0.26 10:40 4.00s 0.09s 0.01s w (注:输入w命令环境)

----------↓解释----------------------------------------------------------------------------

USER:登录用户

TTY:终端类型 terminal type 面向用户使用的接口

`tty1:真实终端` tty1==>`直接登录进去 操纵的第一个终端`(真实终端) Linux里最多允许`6个`可以直接登录的终端(即`真实终端tty`) tty2~tty6 需要的时候使用 `Alt+F1` tty1 回到第一个终端 `Alt+F2` tty2 回到第二个终端 `pts/1:虚拟终端`,给别人用的。数量可以有很多个。有远程登录过来的时候,就会创建1个终端

FROM:从哪里来

WHAT:做什么事

load average机器的拼接负载

------------------------------

root@sanchuang-linux dev# w 11:39:04 up 16:29, 4 users, load average: 0.00, 0.00, 0.00 USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT root tty1 - 0610月20 1:38m 0.60s 0.60s -bash root pts/1 192.168.0.26 10:03 31:52 0.21s 0.21s -bash root pts/2 10.122.155.164 08:52 2:35m 0.16s 0.13s vim -r a root pts/6 192.168.0.26 10:40 0.00s 0.09s 0.00s w root@sanchuang-linux dev# date 2020年 10月 16日 星期五 11:39:06 CST

load average机器的平均负载

---------------------------

本地终端(真实终端)的创建、切换

知识点1.5 本地终端(真实终端)的创建、切换

Alt+F2

本地最多能登录6个终端

Alt+F1~F6 切换本地登录的终端(真实终端)

-----------------------------------------

Alt+F2、Alt+F6

root@sanchuang-linux dev# w 11:42:06 up 16:32, 6 users, load average: 0.00, 0.00, 0.00 USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT root tty1 - 0610月20 1:41m 0.60s 0.60s -bash root pts/1 192.168.0.26 10:03 34:54 0.21s 0.21s -bash root pts/2 10.122.155.164 08:52 2:38m 0.16s 0.13s vim -r a root pts/6 192.168.0.26 10:40 3.00s 0.09s 0.00s w root tty2 - 11:40 1:50 0.01s 0.01s -bash root tty6 - 11:41 13.00s 0.01s 0.01s -bash

如何拦截虚拟终端

知识点1.6 如何拦截虚拟终端

如何拦截虚拟终端 # kill -9 pid

----------------------------------- [root@sanchuang-linux dev]# ps aux USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND root 1 0.0 0.7 179304 13536 ? Ss 10月15 0:07 /usr/lib/systemd/systemd --switched-root --system --dese root 1450 0.0 0.2 25588 3996 tty1 Ss+ 10月15 0:00 -bash root 12692 0.0 0.2 34480 4444 ? Ss 04:49 0:00 tmux …………………………………………………… root 13025 0.0 0.2 25588 4048 pts/14 Ss+ 05:14 0:00 -bash root 13046 0.0 0.2 25588 4032 pts/15 Ss+ 05:14 0:00 -bash root 13286 0.0 0.2 25588 3940 pts/0 Ss+ 05:28 0:00 -bash root 13614 0.0 0.2 25588 4016 pts/3 Ss+ 06:23 0:00 -bash root 13635 0.0 0.2 25588 3956 pts/4 Ss 06:23 0:00 -bash root 13657 0.0 0.4 48860 8596 pts/4 S+ 06:24 0:00 vim /home/text/file2 [root@sanchuang-linux dev]# kill -9 13046 (注:杀死pid号13046的进程) ------------------------------------------------------------------------ ssh服务 22号端口 有端口肯定有服务 起服务一定要有端口 端口跟服务挂钩 Mysql默认端口3306

查看服务的默认端口

知识点1.7 查看服务的默认端口

怎样查看服务的默认端口 # less /etc/services

查看服务的默认端口

# less /etc/services tcpmux 1/tcp # TCP port service multiplexer tcpmux 1/udp # TCP port service multiplexer rje 5/tcp # Remote Job Entry rje 5/udp # Remote Job Entry …………


知识点1.8 传输层协议 TCP、UDP

传输层协议 TCP、UDP

杀死连接 限制连接

知识点1.9 杀死连接 限制连接

杀死连接:

ps aux 查看pts的连接pid

然后使用: kill -9 xxx

-------------------------

限制连接:

iptables 防火墙

或使用其他ssh相关的限制

-------------------------

/proc目录

知识点2.0 /proc目录

/Proc目录 放一些正在运行的程序

# ls /proc 正在运行的程序

[root@sanchuang-linux ssh]# ls /proc ………………………………………………(删了很多) 11 13657 1450 158 171 186 29 508 632 906 999 fb loadavg self zoneinfo 13025 14438 15 168 182 23 40 6 859 982 diskstats kmsg partitions tty ………………………………………………(删了很多)

查看进程打开了哪些文件描述符

知识点2.1 查看进程打开了哪些文件描述符 proc/1450/fd

查看进程打开了哪些文件描述符

root@mysql-binary fd# ls

0 1 2 255

root@mysql-binary fd# pwd

/proc/1680/fd

----------------------------------------- [root@sanchuang-linux ssh]# cd /proc/1450 [root@sanchuang-linux 1450]# ls attr comm fd map_files net pagemap schedstat ………………………………(删了很多) [root@sanchuang-linux 1450]# cd fd [root@sanchuang-linux fd]# ls 0 1 2 255 3 4 [root@sanchuang-linux fd]# pwd /proc/1450/fd


二. 重定向

重定向:改变标准输入、标准输出的方向就是重定向

--------------------------------------------------------------------------------------------

类型 操作符 用途

重定向标准输出 > 将命令的执行结果输出到指定的文件中,而不是直接显示在屏幕上

\>> 将命令执行的结果`追加输出到指定文件`

重定向标准输入 < 将命令中接收输入的途径由默认的键盘更改 为指定的文件

echo

知识点3.1 echo

echo -n 不接换行

echo -e 转义字符输出

代码语言:shell
复制
[root@sanchuang-linux redirect]# echo "xxx"
xxx
[root@sanchuang-linux redirect]# echo -n "xxx"
xxx[root@sanchuang-linux redirect]#
[root@sanchuang-linux redirect]# echo "xx \n x1x1"
xx \n x1x1
[root@sanchuang-linux redirect]# echo -e "xx \n x1x1"
xx 
 x1x1
[root@sanchuang-linux redirect]# 
---------------------------------
echo -n 不接换行
echo -e 转义字符输出

重定向(改变原来的输出方式)

知识点3.2 重定向(改变原来的输出方式)

重定向(改变原来的输出方式)

root@sanchuang-linux redirect# echo "xxx" >file.txt root@sanchuang-linux redirect# cat file.txt xxx

脚本运行 标准错误输出、标准正确输出 (显示)

知识点3.3 脚本运行 标准错误输出、标准正确输出 (显示)

脚本一行一行 从上到下执行

root@sanchuang-linux redirect# vim test.sh root@sanchuang-linux redirect# cat test.sh t date root@sanchuang-linux redirect# sh test.sh test.sh:行1: t: 未找到命令 2020年 10月 16日 星期五 14:49:40 CST

--------------------------------------------

注↑:标注错误输出 、正常输出

重定向

知识点3 重定向

重定向:改变标准输入、标准输出的方向就是重定向

--------------------------------------------------------------------------------------------

类型 操作符 用途

重定向标准输出 > 将命令的执行结果输出到指定的文件中,而不是直接显示在屏幕上

\>> 将命令执行的结果`追加输出到指定文件`

重定向标准输入 < 将命令中接收输入的途径由默认的键盘更改 为指定的文件

--------------------------------------------------------------------------------------------

操作如下

知识点3.4 # sh test.sh > test_result.txt

标准错误输出不会重定向到文件,正确输出会重定向到文件

root@sanchuang-linux redirect# vim test.sh root@sanchuang-linux redirect# cat test.sh t date root@sanchuang-linux redirect# sh test.sh test.sh:行1: t: 未找到命令 2020年 10月 16日 星期五 14:49:40 CST root@sanchuang-linux redirect# sh test.sh > test_result.txt test.sh:行1: t: 未找到命令 (注:标准错误输出显示在屏幕上,不重定向到文件) root@sanchuang-linux redirect# cat test_result.txt 2020年 10月 16日 星期五 14:50:32 CST(注:正确输出会重定向到文件)

\=\=\=\=\=\=\==\=\=\=\=\=\=\==\=\=\=\=\=\=\==\=\=\=\=\=\=\=\==\=\=\=\=\=\=\=\==\=\=\=\=\=\=\==\=\=\=\=\=\=\=

重定向 > 默认只会重定向标准输出

重定向 标准错误

知识点3 重定向 标准错误

标准错误:通过该设备报告执行出错信息

--------------------------------------------------------------------------------------------

类型 操作符

重定向标准错误 2>

2>>

重定向标准输出和标准错误同一个文件 2>&1 或者>&或者 &>

重定向标准输出和标准错误不同文件 > 文件1 2 >文件2 (没教)

--------------------------------------------------------------------------------------------

操作如下

知识点3.5.1 # sh test.sh 2> test_result.txt

# sh test.sh 2> test_result.txt 重定向标准错误 (注:与>效果相反)

正确输出显示在屏幕上,标准错误输出重定向到文件

只输出了错误的

root@sanchuang-linux redirect# sh test.sh 2> test_result.txt 2020年 10月 16日 星期五 14:52:33 CST (注:正确输出显示在屏幕上) root@sanchuang-linux redirect# cat test_result.txt test.sh:行1: t: 未找到命令 (注:标准错误输出重定向到文件)


知识点3.5.2 # sh test.sh &> test_result.txt

# sh test.sh &> test_result.txt

把正确的错误的都重定向到 文件

root@sanchuang-linux redirect# sh test.sh &> test_result.txt root@sanchuang-linux redirect# cat test_result.txt test.sh:行1: t: 未找到命令 2020年 10月 16日 星期五 14:54:05 CST

与下面效果相同


知识点3.5.3 # sh test.sh > test_result.txt 2>&1

# sh test.sh > test_result.txt 2>&1

把错误输出重定向向到标准输出

root@sanchuang-linux redirect# sh test.sh > test_result.txt 2>&1 root@sanchuang-linux redirect# cat test_result.txt test.sh:行1: t: 未找到命令 2020年 10月 16日 星期五 14:55:16 CST

两者效果等同


知识点3.5.4 # sh test.sh > test_result.txt 1>&2

# sh test.sh > test_result.txt 1>&2

把标准输出重定向错误输出

*输出到屏幕上 (*注:不重定向到文件)

root@sanchuang-linux redirect# sh test.sh > test_result.txt 1>&2 test.sh:行1: t: 未找到命令 (注:输出到屏幕上) 2020年 10月 16日 星期五 14:56:19 CST (注:输出到屏幕上)

root@sanchuang-linux redirect# cat test_result.txt root@sanchuang-linux redirect#

使用重定向清空文件的几种方式

知识点3.6 使用重定向清空文件的几种方式

使用重定向清空文件的几种方式:

# >stdout_test.txt

# echo >stdout_test.txt (注:有空格)

# echo "">stdout_test.txt (注:有空格)

# :>stdout_test.txt

# echo -n "" > stdout_test.txt

代码如下

--------------------------------------------------------------------------------------------

root@sanchuang-linux redirect# vim stdout_test.txt root@sanchuang-linux redirect# >stdout_test.txt (注:清空) root@sanchuang-linux redirect# cat stdout_test.txt root@sanchuang-linux redirect# echo "aaa"> stdout_test.txt root@sanchuang-linux redirect# cat stdout_test.txt aaa root@sanchuang-linux redirect# echo >stdout_test.txt (注:有空格) root@sanchuang-linux redirect# cat stdout_test.txt

root@sanchuang-linux redirect# echo "aaa">stdout_test.txt root@sanchuang-linux redirect# echo "">stdout_test.txt (注:有空格) root@sanchuang-linux redirect# cat stdout_test.txt

root@sanchuang-linux redirect# echo "aaa">stdout_test.txt root@sanchuang-linux redirect# :>stdout_test.txt (注:清空) root@sanchuang-linux redirect# cat stdout_test.txt

root@sanchuang-linux chenpeng# echo -n "" > stdout_test.txt (注:清空) root@sanchuang-linux chenpeng# cat stdout_test.txt root@sanchuang-linux chenpeng#


知识点3.6.1 # echo -n "">stdout_test.txt

# echo -n "">stdout_test.txt

echo默认情况会接一个换行符 不想换行 接-n

root@sanchuang-linux redirect# echo "aaa">stdout_test.txt root@sanchuang-linux redirect# cat stdout_test.txt aaa root@sanchuang-linux redirect# echo "">stdout_test.txt root@sanchuang-linux redirect# cat stdout_test.txt (注:有空格)

root@sanchuang-linux redirect# echo -n "">stdout_test.txt (注:清空,没有空格) root@sanchuang-linux redirect#

重定向 > 与 >>

知识点3.7 重定向 > 与 >>

重定向> 与 >>

> 是以覆盖的方式写入

>> 是以追加的方式写入

代码如下

--------------------------------------------------------------------------------------------

root@sanchuang-linux redirect# echo "aaa" > stdout_test.txt

root@sanchuang-linux redirect# cat stdout_test.txt aaa root@sanchuang-linux redirect# echo "bb" >> stdout_test.txt root@sanchuang-linux redirect# cat stdout_test.txt aaa bb root@sanchuang-linux redirect#

重定向标准输入 read输入

知识点3.8 重定向标准输入 read输入

重定向标准输入 read输入

(注:用到了tmux)

While 循环

echo "$a $b $c"

代码语言:shell
复制
脚本1 3个参数 3个参数
[root@sanchuang-linux redirect]# cat abc.sh
while read a b c
do
    echo "$a    $b    $c"
done < f1.txt
[root@sanchuang-linux redirect]# 

(注:窗口1)
──────────────────────────────────────────────
[root@sanchuang-linux redirect]# vim f1.txt
[root@sanchuang-linux redirect]# cat f1.txt
xx yy zz
aa bb cc

(注:窗口2)
──────────────────────────────────────────────
[root@sanchuang-linux redirect]# sh abc.sh
xx    yy    zz
aa    bb    cc

[root@sanchuang-linux redirect]# 

(注:窗口3)

echo "$a -- $b"

代码语言:shell
复制
脚本2 2个参数 3个参数
[root@sanchuang-linux redirect]# vim abc.sh
[root@sanchuang-linux redirect]# cat abc.sh
while read a b
do
    echo "$a -- $b"
done < f1.txt
[root@sanchuang-linux redirect]#

(注:窗口1)
──────────────────────────────────────────────
[root@sanchuang-linux redirect]# vim f1.txt
[root@sanchuang-linux redirect]# cat f1.txt 
xx yy zz
aa bb cc
[root@sanchuang-linux redirect]# 

(注:窗口2)
──────────────────────────────────────────────
(注:默认空格分割参数,xx 和yy zz)
[root@sanchuang-linux redirect]# sh abc.sh 
xx -- yy zz
aa -- bb cc
[root@sanchuang-linux redirect]# 

(注:窗口3)

echo "line:$line"

代码语言:shell
复制
脚本3 1个参数 3个参数
[root@sanchuang-linux redirect]# vim abc.sh
[root@sanchuang-linux redirect]# cat abc.sh 
while read line 
do
    echo "line:$line"
done < f1.txt
[root@sanchuang-linux redirect]# 

(注:窗口1)
──────────────────────────────────────────────
[root@sanchuang-linux redirect]# vim f1.txt
[root@sanchuang-linux redirect]# cat f1.txt 
xx yy zz
aa bb cc
[root@sanchuang-linux redirect]# 

(注:窗口2)
──────────────────────────────────────────────
[root@sanchuang-linux redirect]# sh abc.sh 
line:xx yy zz
line:aa bb cc
[root@sanchuang-linux redirect]# 

(注:窗口3)

echo "$a -- $b -- $c -- $d -- $e"

代码语言:shell
复制
脚本4 5个参数 3个参数
[root@sanchuang-linux redirect]# vim abc.sh
[root@sanchuang-linux redirect]# cat abc.sh 
while read a b c d e 
do
    echo "$a -- $b -- $c -- $d -- $e"
done < f1.txt
[root@sanchuang-linux redirect]# 

(注:窗口1)
──────────────────────────────────────────────
[root@sanchuang-linux redirect]# vim f1.txt
[root@sanchuang-linux redirect]# cat f1.txt 
xx yy zz
aa bb cc
[root@sanchuang-linux redirect]# 

(注:窗口2)
──────────────────────────────────────────────
[root@sanchuang-linux redirect]# sh abc.sh 
xx -- yy -- zz --  -- 
aa -- bb -- cc --  -- 
[root@sanchuang-linux redirect]# 

(注:窗口3)
=================================

知识点3.9 上课练习 重定向标准输入 read输入

代码语言:shell
复制
[root@sanchuang-linux redirect]# vim student_information.sh
[root@sanchuang-linux redirect]# cat student_information.sh 
echo "========学生信息管理系统==============="
while read name sex age
do
    echo "==姓名:$name, 性别:$sex, 年龄:$age=="
done < stu_info.txt
echo "========================================"
[root@sanchuang-linux redirect]# 

(注:窗口1 tmux)
──────────────────────────────────────────────
[root@sanchuang-linux redirect]# cat stu_info.txt
wenyao 18 f
fengcheng 78 m
chenpeng 80 m
[root@sanchuang-linux redirect]# 

(注:窗口2 tmux)
──────────────────────────────────────────────
[root@sanchuang-linux redirect]# sh student_information.sh 
========学生信息管理系统===============
==姓名:wenyao, 性别:18, 年龄:f==
==姓名:fengcheng, 性别:78, 年龄:m==
==姓名:chenpeng, 性别:80, 年龄:m==
========================================
[root@sanchuang-linux redirect]#

(注:窗口3 tmux)

三. SHELL-脚本练习及管道

知识点4.0 接受从键盘的输入 管道符号

脚本 接受从键盘的输入

要求:输入用户名和密码 创建相应的用户

需求分析:接受用户输入

创建用户 设置密码

-----相关知识点----------------------------------

管道符号 | :上一条命令的输出作为下一条命令的输入

yum list 默认输出到屏幕

yum list | grep tmux yumlist的输出 作为grep tmux命令的输入


创建用户 useradd wy [root@sanchuang-linux ~]# useradd wy [root@sanchuang-linux ~]# passwd wy 更改用户 wy 的密码 。 新的 密码: 无效的密码: 密码少于 8 个字符 重新输入新的 密码: passwd:所有的身份验证令牌已经成功更新。 ============================================================== 重新给用户wy设置密码 [root@sanchuang-linux ~]# echo "yyyzzz123" |passwd wy --stdin stdin 标准输入


*4.1 初始脚本1

(注:# passwd在bash中执行时会在中间停止,让用户进行输入密码

\# `为了防止shell停止使用参数--stdin`,让passwd介绍标准输入,echo是标准输出 来自:https://blog.csdn.net/qq_31820885/article/details/78100587)

代码语言:shell
复制
[root@sanchuang-linux chenpeng]# vim test.sh
read -p "请输入用户名:" username
read -p "请设置密码:" password

useradd $username
echo $password | passwd $username --stdin
echo $username
echo $password

[root@sanchuang-linux chenpeng]# sh test.sh
请输入用户名:cp1
请设置密码:123456
更改用户 cp1 的密码 。
passwd:所有的身份验证令牌已经成功更新。
cp1
123456
[root@sanchuang-linux chenpeng]# id cp1
uid=1009(cp1) gid=1009(cp1) 组=1009(cp1)
[root@sanchuang-linux chenpeng]# less /etc/passwd
root:x:0:0:root:/root:/bin/bash
………………
wy:x:1008:1008::/home/wy:/bin/bash
cp1:x:1009:1009::/home/cp1:/bin/bash

\=\=\=\=\=\=\=\=\==\=\=\=\=\=\=\==\=\=\=\=\=\==\=\=\=\=\=\=\=\==\=\=\=\=\=\==\=\=\=\=\=\=\==\=\=\=\=\=\=\==\=\=\=\==\=\=\=\=\==\=\=\=\=\=\=\=\=\=\=\=\=\=\=\=\=\=\=\=\=\=\=\=\=

*4.2 python 与 shell 程序运行出错

python中如果程序运行中出现错误,后续操作会终止

shell 中如果出现错误,操作会继续向下执行

*4.3 优化脚本2

用户创建脚本优化:

1.让命令的标准输出和标准错误输出都输出到黑洞文件

echo $password | passwd $username --stdin &>/dev/null

2.密码隐藏 -s

read -s -p "请设置密码:" password

3.判断用户是否存在

条件语句:

if 条件 then

`语句体1`

else

`语句体2`

fi

*4.3 优化脚本2

代码语言:shell
复制
[root@sanchuang-linux chenpeng]# vim test.sh
read -p "请输入用户名:" username

if cat /etc/passwd |grep $username &>/dev/null
then
    echo "$username is exist!"
else
    read -s -p "请设置密码:" password
    useradd $username &>/dev/null
    echo $password | passwd $username --stdin &>/dev/null
    echo -e "\n create $username ok!"
fi

----------------------------------------------------------
[root@sanchuang-linux chenpeng]# sh test.sh 
请输入用户名:cp1
cp1 is exist!
[root@sanchuang-linux chenpeng]# sh test.sh 
请输入用户名:cp8
请设置密码:
 create cp8 ok!
[root@sanchuang-linux chenpeng]# 

4.3.2 脚本优化3

代码语言:shell
复制
[root@sanchuang-linux chenpeng]# vim test.sh
read -p "请输入用户名:" username

if cat /etc/passwd |grep $username &>/dev/null
then
    echo "$username is exist!"
else
    read -s -p "请设置密码:" password
    useradd $username &>/dev/null
    echo $password | passwd $username --stdin &>/dev/null
    echo -e "\n create $username ok!"
fi
          
(tmux 窗口1)                                                                                                       
──────────────────────────────────────────────
[root@sanchuang-linux chenpeng]# sh test.sh 
请输入用户名:chen5556
chen5556 is exist!
[root@sanchuang-linux chenpeng]# sh test.sh 
请输入用户名:chen7778
请设置密码:
 create chen7778 ok!
[root@sanchuang-linux chenpeng]# 

(tmux 窗口2)

4.3.4 脚本改善 最终版

root@sanchuang-linux chenpeng# id chen5557 uid=1019(chen5557) gid=1019(chen5557) 组=1019(chen5557)

--------------------------------------------------------

代码语言:shell
复制
[root@sanchuang-linux chenpeng]# vim test.sh
read -p "请输入用户名:" username

if id $username &>/dev/null
then
   echo "$username is exist!"
else
   read -s -p "请设置密码:" password
   useradd $username &>/dev/null
   echo $password | passwd $username --stdin &>/dev/null
   echo -e "\n create $username ok!"
fi

(tmux 窗口1)
──────────────────────────────────────────────
[root@sanchuang-linux chenpeng]# sh test.sh 
请输入用户名:chen5556
chen5556 is exist!
[root@sanchuang-linux chenpeng]# sh test.sh 
请输入用户名:chen7777
请设置密码:
 create chen7777 ok!
[root@sanchuang-linux chenpeng]# 

(tmux 窗口2)

查看用户是否存在

*4.4 查看用户是否存在

root@sanchuang-linux ~# cat /etc/passwd |grep cp1 cp1: x:1009:1009::/home/cp1:/bin/bash

上一条命令返回值 $?

*4.5 上一条命令返回值 $?

$? 上一个命令的返回值

上一条命令返回值: 保存在 -->$?

为0是成功

为1是失败

命令返回值为0 表示执行成功

`1 执行失败` `227 没有这条命令`

命令返回值 $?


*4.6 命令返回值 不精确的判断用户是否存在

不精确地判断用户是否存在

root@sanchuang-linux ~# cat /etc/passwd |grep cp1 (注:不精确地判断用户是否存在) cp1: x:1009:1009::/home/cp1:/bin/bash root@sanchuang-linux ~# echo $? (注:为0是成功) 0 root@sanchuang-linux ~# cat /etc/passwd |grep cp9 root@sanchuang-linux ~# echo $? (注:为1是失败) 1

\=\=\=\=\=\==\=\=\=\=\==\=\=\=\=\==\=\=\=\=\=\=\=\=\==\=\=\=\=\=\==\=\=\=\=\=\=\=\=\=\==\=\=\=\=\=\=\==

命令返回值 id

root@sanchuang-linux ~# id cp1 uid=1009(cp1) gid=1009(cp1) =1009(cp1) root@sanchuang-linux ~# echo $? 0 root@sanchuang-linux ~# id cp9 id: “cp9”:无此用户 root@sanchuang-linux ~# echo $? 1 root@sanchuang-linux ~#

上一条命令返回值: 保存在 ——>$?

--------------------------------------------------------

命令返回值为0 表示执行成功

`1 执行失败` `227 没有这条命令`


*4.7 精确的判断用户是否存在 (完善脚本)

想要精确匹配的话,就把过滤的范围缩小一点:

^wy: 以wy: 开头

^…:以什么开头,整行以什么开头

…$:以什么结尾,整行以什么结尾

root@sanchuang-linux ~# cat /etc/passwd |grep "^wy:" wy: x:1008:1008::/home/wy:/bin/bash

root@sanchuang-linux ~# useradd wy: useradd:无效的用户名“wy:”

wc命令 <重定向标准输入

知识点5.1 wc命令 <重定向标准输入

wc(字数统计)命令

格式:wc [选项]... 目标文件...

-l:统计行数

-w:统计字数 (前后都是空白的一组字符)

-c:统计字符数(可见和不可见的字符)

例:

# wc /etc/hosts

4 23 185 /etc/hosts

(* 注:4行,23个单词,185个字节)

代码如下

---------------------------------------------------------------

root@sanchuang-linux ~# wc -l backup_log.sh (注:查看文件有多少行) 0 backup_log.sh root@sanchuang-linux ~# wc < backup_log.sh (输入重定向) 0 0 0 root@sanchuang-linux ~# wc backup_log.sh 0 0 0 backup_log.sh

root@sanchuang-linux lianxi# wc -l sshd_config2 (注:查看文件有多少行) 148 sshd_config2 root@sanchuang-linux lianxi# wc < sshd_config2 (注:标准输入 输入重定向) 148 559 4425 root@sanchuang-linux lianxi# wc sshd_config2 (注:wc(字数统计)命令) 148 559 4425 sshd_config2


知识点5.2 重定向 发信息 echo "hello brother" > /dev/pts/22

root@sanchuang-linux ~# w 17:20:37 up 19:51, 7 users, load average: 0.00, 0.00, 0.02 USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT root tty1 - 0610月20 7:20m 0.60s 0.60s -bash root pts/7 192.168.0.30 14:30 42:37 0.09s 0.00s tmux root pts/21 192.168.0.30 16:48 21.00s 0.14s 0.14s -bash root pts/22 192.168.0.30 17:20 0.00s 0.02s 0.01s w

----------------------------------------------------------------------

# echo "hello brother" > /dev/pts/22

重定向 发信息

xargs 管道符号

知识点5.3 xargs 管道符号

xargs 将前面命令的输出送给后面的命令作为参数使用

xargs 和 管道符号 一般配套使用

-------------------------------------------------

在当前路径查看.txt结尾的文件

find . -name "*.txt"

------------------------------------

管道 与 xargs

将管道前的输出作为参数赋给后面的命令

find . -name "*.txt" | xargs rm -rf

--------------------------------------------------------------------------------------

管道与xargs

xargs 可以将管道或标准输入(stdin)数据转换成命令行参数,也能够从文件的输出中读取数据。

root@mysql-binary vim_test# find . -name "*.sh" |xargs ls -al

root@mysql-binary vim_test# find . -name "*.txt" | xargs rm -rf

(注:ls -al 看文件详细信息)

代码如下

------------------------------------------------------------------

root@sanchuang-linux chenpeng# find . -name "*.sh" |xargs ls -al -rw-r--r--. 1 root root 77 10月 16 15:30 ./redirect/abc.sh -rw-r--r--. 1 root root 206 10月 16 15:45 ./redirect/student_information.sh -rw-r--r--. 1 root root 300 10月 16 17:15 ./test.sh root@sanchuang-linux chenpeng# ls -al test.sh -rw-r--r--. 1 root root 300 10月 16 17:15 test.sh


原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 09_Linux基础-SHELL-标准输入与标准输出-重定向-管道
    • 一. SHELL-标准输入与标准输出
      • 标准输入和标准输出
      • 文件描述符
      • linux下面一切皆文件
      • 虚拟终端pts 真实终端tty
      • 查看当前linux登陆的用户情况
      • 本地终端(真实终端)的创建、切换
      • 如何拦截虚拟终端
      • 查看服务的默认端口
      • 杀死连接 限制连接
      • /proc目录
      • 查看进程打开了哪些文件描述符
    • 二. 重定向
      • echo
      • 重定向(改变原来的输出方式)
      • 脚本运行 标准错误输出、标准正确输出 (显示)
      • 重定向
      • 重定向 标准错误
      • 使用重定向清空文件的几种方式
      • 重定向 > 与 >>
      • 重定向标准输入 read输入
    • 三. SHELL-脚本练习及管道
      • 查看用户是否存在
      • 上一条命令返回值 $?
      • wc命令 <重定向标准输入
      • xargs 管道符号
相关产品与服务
多因子身份认证
多因子身份认证(Multi-factor Authentication Service,MFAS)的目的是建立一个多层次的防御体系,通过结合两种或三种认证因子(基于记忆的/基于持有物的/基于生物特征的认证因子)验证访问者的身份,使系统或资源更加安全。攻击者即使破解单一因子(如口令、人脸),应用的安全依然可以得到保障。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档