Day 37 shell并发控制

一:FD文件描述符

1.FD简述

​ FD:文件描述符/文件句柄

​ 进程使用文件描述符用来管理进程打开的文件

为指定文件生成文件描述符:exec 文件描述符<>指定文件

释放文件描述符:exec 文件描述符<&-

shell 复制代码
[root@xingdiancloud ~]# ll /proc/$$/fd
总用量 0
lrwx------. 1 root root 64  4月 16 23:51 0 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 1 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 2 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 255 -> /dev/pts/0
[root@xingdiancloud ~]# touch file1
启用自定义文件描述符打开文件
[root@xingdiancloud ~]# exec 6<> file1
[root@xingdiancloud ~]# ll /proc/$$/fd
总用量 0
lrwx------. 1 root root 64  4月 16 23:51 0 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 1 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 2 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 255 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 6 -> /root/file1
[root@xingdiancloud ~]# echo "xingdian" > /proc/$$/fd/6
[root@xingdiancloud ~]# cat file1
xingdian
[root@xingdiancloud ~]# rm -rf file1
[root@xingdiancloud ~]# ll /proc/$$/fd
总用量 0
lrwx------. 1 root root 64  4月 16 23:51 0 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 1 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 2 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 255 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 6 -> '/root/file1 (deleted)'
[root@xingdiancloud ~]# cat /proc/$$/fd/6
xingdian
释放文件描述符
[root@xingdiancloud ~]# exec 6<&-
[root@xingdiancloud ~]# ll /proc/$$/fd
总用量 0
lrwx------. 1 root root 64  4月 16 23:51 0 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 1 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 2 -> /dev/pts/0
lrwx------. 1 root root 64  4月 16 23:51 255 -> /dev/pts/0

注意:

​ exec打开一个文件

​ exec关闭一个文件(释放文件句柄)

​ 当一个文件FD未被释放,删除源文件也不会影响FD

2.管道简述

匿名管道

shell 复制代码
[root@xingdiancloud ~]# rpm -qa | grep rpm

命令管道

创建命名管道:mkfifo 管道名

shell 复制代码
[root@xingdiancloud ~]# mkfifo /tmp/xingdian
[root@xingdiancloud ~]# file /tmp/xingdian
/tmp/xingdian: fifo (named pipe)
[root@xingdiancloud ~]# tty
/dev/pts/0
[root@xingdiancloud ~]# rpm -qa > /tmp/xingdian

另一个终端
[root@xingdiancloud ~]# grep bash /tmp/xingdian
bash-5.1.8-6.el9.x86_64
bash-completion-2.11-4.el9.noarch
[root@xingdiancloud ~]# tty
/dev/pts/1
3.FD案例
shell 复制代码
[root@xingdiancloud ~]# cat a.sh
#!/bin/bash
exec 7<> /etc/hosts
exec 8<> /etc/hostname

while read -u 7 line
do
        echo $line
done
while read -u 8 line2
do
        echo $line2
done
exec 7<&-
exec 8<&-

[root@xingdiancloud ~]# bash a.sh
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
xingdiancloud

4.并发案例

shell 复制代码
#!/usr/bin/bash
#固定线程
read -p "请输入线程数量:" diange
diangefile=/root/diangefile
mkfifo $diangefile                //虚拟管道
exec 8<>$diangefile               //文件描述
rm -rf $diangefile

for i in `seq $diange`
do
        echo  >&8                   //将内容写入到描述文件中,写如了空行
done

for i in {1..100}
do
        read -u 8                   //read 读取描述文件中的内容
        {
        ip=192.168.101.$i
        ping -c1 $ip &>/dev/null
        if [ $? -eq 0 ];then
                echo "$ip is up"
        else
                echo "$ip is down"

        fi
        echo >&8                   //等到进程执行完之后再往管道里丢内容以支持后面的循环
        }&
done
wait
echo "完成"
exec 8<&-                          //释放描述文件
相关推荐
炘爚5 分钟前
phase1:基础框架——编译 + MySQL + 登录/注册
linux·c++
齐鲁大虾16 分钟前
如何彻底解决从公网HTTP页面请求私有HTTP资源跨域问题
网络·网络协议·http
小蜗子20 分钟前
Windows 11 + RTX 5060 + WSL2 Ubuntu + NVIDIA DGL 容器
linux·运维·ubuntu
g3voip24 分钟前
洁净室IP电话机是什么?无尘车间语音通信设备的功能与部署要点
网络·网络协议·tcp/ip
Yan-英杰29 分钟前
从零玩转搜索引擎 API: 多引擎整合实战
服务器·前端·microsoft
着迷不白44 分钟前
八、shell脚本
linux·运维
韩曙亮1 小时前
【Flutter】Flutter 中的 Android / iOS 特殊配置 ① ( 网络权限配置 | HTTP 明文传输配置 | 应用名称配置 )
android·网络·flutter·http·ios·网络权限
爱装代码的小瓶子1 小时前
3. 设计buffer模块
linux·服务器·开发语言·c++·php
流浪0011 小时前
Linux系统篇(四):一文吃透 Linux 虚拟地址空间:从页表映射到内核结构体全链路拆解
linux·运维·服务器
Jacob程序员1 小时前
WebSSH技术实现全解析
linux·运维·服务器·websocket