06Shell并发控制
并发控制
文件描述
文件句柄
File Descriptors (FD,文件描述符)或 文件句柄:
进程使用文件描述符来管理打开的文件
注意
1.如何通过exec打开一个文件
exec 数字<> 文件名称
数字:/proc/$$/fd中未出现的数字
文件名称:相对路径或者绝对路径
2.如何通过exec关闭一个文件(释放文件句柄)
exec 数字<&-
3.当一个文件FD没有被释放,删除原文件也不会影响FD
示例说明
[root@hadoop04 ~]# ll /proc/$$/fd
total 0
lrwx------. 1 root root 64 Dec 10 09:18 0 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 09:18 1 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 09:18 2 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 15:21 255 -> /dev/pts/4
[root@hadoop04 ~]# touch file1
# 打开文件
# exec 数字<> 文件名称
# 数字:/proc/$$/fd中未出现的数字
# 文件名称:相对路径或者绝对路径
[root@hadoop04 ~]# exec 6<> file1
[root@hadoop04 ~]# ll /proc/$$/fd
total 0
lrwx------. 1 root root 64 Dec 10 09:18 0 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 09:18 1 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 09:18 2 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 15:21 255 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 09:18 6 -> /root/file1
# 编辑文件
[root@hadoop04 ~]# echo "1111" >> /proc/$$/fd/6
[root@hadoop04 ~]# cat /proc/$$/fd/6
1111
[root@hadoop04 ~]# cat /root/file1
1111
# 删除文件、恢复文件
# 注意:即使恢复了file1文件,但是 `6 -> /root/file1 (deleted)`,原因是前后的file1的inode不一样
# 一个文件的句柄/描述符没有被释放,即使删除了文件,文件描述符依然在
[root@hadoop04 ~]# rm -rf /root/file1
[root@hadoop04 ~]# ll /proc/$$/fd
total 0
lrwx------. 1 root root 64 Dec 10 09:18 0 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 09:18 1 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 09:18 2 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 15:21 255 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 09:18 6 -> /root/file1 (deleted)
[root@hadoop04 ~]# cat /proc/$$/fd/6
1111
[root@hadoop04 ~]# cp /proc/$$/fd/6 /root/file1
[root@hadoop04 ~]# cat /root/file1
1111
# 释放文件句柄
# exec 数字<&-
[root@hadoop04 ~]# exec 6<&- // 关闭当前进程的文件句柄6
[root@hadoop04 ~]# ll /proc/$$/fd
total 0
lrwx------. 1 root root 64 Dec 10 09:18 0 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 09:18 1 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 09:18 2 -> /dev/pts/4
lrwx------. 1 root root 64 Dec 10 15:21 255 -> /dev/pts/4
管道
管道本身就是文件

匿名管道
[root@hadoop04 ~]# rpm -qa | grep bash
命名管道
先进先出,取出了就没有了
[root@hadoop04 ~]# mkfifo /tmp/tmpfifo
[root@hadoop04 ~]# file /tmp/tmpfifo
/tmp/tmpfifo: fifo (named pipe)
[root@hadoop04 ~]# tty
/dev/pts/4
#打开两个终端
#终端1
[root@hadoop04 ~]# ll /dev > /tmp/tmpfifo
#终端2
[root@hadoop04 ~]# grep 'sda' /tmp/tmpfifo
brw-rw----. 1 root disk 8, 0 Dec 7 12:23 sda
brw-rw----. 1 root disk 8, 1 Dec 7 12:23 sda1
brw-rw----. 1 root disk 8, 2 Dec 7 12:23 sda2
并发控制案例
并发ping主机:通过命名管道和文件描述符实现多进程

[root@hadoop04 shell_concurrency_control]# vim ping_multi_thread01.sh
#!/usr/bin/bash
##########################################
# ping hosts mutil thread #
# v1.1 by ElegantSmile 10/12/2019 #
##########################################
#进程数量
thread=5
#命名管道
tmp_fifofile=/tmp/$$.fifo
mkfifo ${tmp_fifofile}
exec 8<> ${tmp_fifofile}
rm ${tmp_fifofile}
for i in `seq ${thread}`
do
# 操作文件描述8
# &8表示文件描述8
# 此处给文件描述8输入了5个回车,代表了5行内容
echo >&8
done
for i in {1..254}
do
# read -u fd
# read -u选项可以跟上文件描述符
read -u 8
# 读取文件描述符8中的内容,读到一行就开启一个后台进程
{
ip=172.22.23.${i}
ping -c1 -W1 ${ip} &> /dev/null
if [ $? -eq 0 ] ;then
echo "${ip} is up"
fi
# 每次执行完上面的循环体,就往文件描述8输入了1个回车
# 因为在read -u 8的时候读取一行就少一行,当文件描述符8的内容为空,read -u 8就再也无法读取到内容,循环就会卡在那,所以此处要每次补充一行
echo >&8
}&
done
wait
# 可以通过读或者写的方式关闭文件句柄
#exec 8<&-
exec 8>&-
echo "all ok..."
06Shell并发控制的更多相关文章
- Entity Framework Core 实现MySQL 的TimeStamp/RowVersion 并发控制
将通用的序列号生成器库 从SQL Server迁移到Mysql 遇到的一个问题,就是TimeStamp/RowVersion并发控制类型在非Microsoft SQL Server数据库中的实现.SQ ...
- EntityFramework与TransactionScope事务和并发控制
最近在园子里看到一篇关于TransactionScope的文章,发现事务和并发控制是新接触Entity Framework和Transaction Scope的园友们不易理解的问题,遂组织此文跟大家共 ...
- MySQL MVCC(多版本并发控制)
概述 为了提高并发MySQL加入了多版本并发控制,它把旧版本记录保存在了共享表空间(undolog),当事务提交之后将重做日志写入磁盘(前提innodb_flush_log_at_trx_commit ...
- LINQ to SQL语句(13)之开放式并发控制和事务
Simultaneous Changes开放式并发控制 下表介绍 LINQ to SQL 文档中涉及开放式并发的术语: 术语 说明 并发 两个或更多用户同时尝试更新同一数据库行的情形. 并发冲突 两个 ...
- SQLite剖析之锁和并发控制
在SQLite中,锁和并发控制机制都是由pager.c模块负责处理的,用于实现ACID(Atomic.Consistent.Isolated和Durable)特性.在含有数据修改的事务中,该模块将确保 ...
- [NHibernate]并发控制
目录 写在前面 文档与系列文章 并发控制 乐观并发控制(Optimistic Concurrency) 一个例子 悲观并发控制(Pessimistic Concurrency) 总结 写在前面 上篇文 ...
- Go并发控制之sync.WaitGroup
WaitGroup 会将main goroutine阻塞直到所有的goroutine运行结束,从而达到并发控制的目的.使用方法非常简单,真心佩服创造Golang的大师们! type WaitGroup ...
- MVCC PostgreSQL实现事务和多版本并发控制的精华
原创文章,同步发自作者个人博客,http://www.jasongj.com/sql/mvcc/ PostgreSQL针对ACID的实现机制 事务的实现原理可以解读为RDBMS采取何种技术确保事务的A ...
- mysql事务和并发控制
谈到事务,首先想到的问题是并发控制.比如两个用户同时操作数据库里面的一张表,一个正在读数据,一个正在删除数据,那么读数据的读出的结果究竟是多少?并发可以提高系统的性能,让多个用户同时操作一份数据,但为 ...
随机推荐
- PHP 高级面试题 - 如果没有 mb 系列函数,如何切割多字节字符串
需求 如果需要将可能含有中文的字符串进行拆分成数组,我们下面以 utf-8 编码为例. 解决方案一 我习惯的方法可能是: mb_internal_encoding("UTF-8") ...
- IT兄弟连 HTML5教程 HTML5的靠山 W3C、IETF是什么
无规矩不成方圆,软件开发当然不能例外.Web开发涉及的厂商和技术非常多,所以必须要有参考的标准,而且需要一系列的标准.Web程序都是通过浏览器来解析执行的,通过页面的展示内容与用户互动,所以Web标准 ...
- Java并发编程入门,看这一篇就够了
Java并发编程一直是Java程序员必须懂但又是很难懂的技术内容.这里不仅仅是指使用简单的多线程编程,或者使用juc的某个类.当然这些都是并发编程的基本知识,除了使用这些工具以外,Java并发编程中涉 ...
- 使用Redis实现最近N条数据的决策
前言 很多时候,我们会根据用户最近一段时间的行为,做出一些相应的策略,从而改变系统的运动轨迹. 举个简单的例子来说明一下: 假设A公司现在有两个合作伙伴(B和C),B和C都是提供天气数据的,现在A公司 ...
- 2、Hibernate持久化编写
一.对于hibernate中的PO编写规则: 1. 必须提供一个无参数的public构造方法 2. 所有属性要private ,对外提供public 的get/set方法 3. 在PO类必须提 ...
- 转caffe scale layer
版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/u011681952/article/det ...
- Java自定义注解(1)
Java注解简介 1. Java注解(Annotation) Java注解是附加在代码中的一些元信息,用于一些工具在编译. 运行时进行解析和使用,起到说明.配置的功能. 注解相关类都包含在java.l ...
- C#操作SQLite数据库增、删、改、查 欢迎转载
C#操作SQLite数据库增.删.改.查 欢迎转载 转载记得留下链接地址哦!!! 最近项目上要使用SQLite数据库,不怕大伙笑话毕业四年多了,一直使用Oracle或者MySQL或者SQLServer ...
- 敏捷软件开发_实例1<二>
敏捷软件开发_实例1 这本书的实例非常好,给了我非常多的启发.主要讲了两个实例,咖啡机和薪水支付实例,咖啡机实例比较简单并没有用什么设计模式,薪水支付实例用了很多设计模式,包括后面的打包等. 咖啡机实 ...
- C#如何将DataTable中的列名复制到另一个DataTable
C#如何将DataTable中的列名复制到另一个DataTable? 仅复制列名,不复制列下的数据: var newDt = new DataTable(); newDt = oldDataTable ...