4 并发控制
- 默认情况下,Shell命令是串行方式自上而下执行的,但如果有大量的命令需要执行,串行就会浪费大量的时间,这就需要采用并发执行。
4.1 利用后台执行实现并发
[root@hdp-1 shell]
for i in {
1..254}
do
{
ip=10.10.10.$i
ping -c1 -w1 $ip &> /dev/null
if [ $? -eq 0 ];then
echo "$ip is up."
else
echo "$ip is down."
fi
}&
done
wait
echo "Mission Completed"
利用管道实现并发控制
- 使用Linux管道文件特性制作队列,可以控制并发数量。
- 管道分为命名管道和匿名管道。
- 创建命名管道文件命令是 mkfifo
- 命名管道可跨终端实现数据交换
[root@hdp-1 shell]
thread=5
tmp_fifofile=/tmp/$$.fifo
mkfifo $tmp_fifofile
exec 8<>$tmp_fifofile
rm $tmp_fifofile
for i in `seq $thread`
do
echo >&8
done
for i in {
1..254}
do
read -u 8
{
ip=10.0.0.$i
ping -c1 -w1 $ip &>/dev/null
if [ $? -eq 0 ];then
echo "$ip is up."
else
echo "$ip is down . "
fi
echo >&8
}&
done
wait
exec 8>&-
echo "misson completed."
5 Shell 数组
5.1 Shell数组的基本概念
- 用于区分不同元素的编号称为数组下标。
- 数组的元素有时也称为下标变量。
- 数组分为普通数组和关联数组
- 普通数组中的索引是整数,关联数组的数组索引可以用文本。
- 关联数组使用之前需要声明
- 关联数组由键值对组成。
5.1.1 普通数组
- 普通数组中:数组元素的索引(下标)从0开始编号,获取数组中的元素要利用索引(下标)。索引(下标)可以是算术表达式,其结果必须是一个整数。
- 普通数组定义。
- 下标从0开始
[root@hdp-1 shell]
[root@hdp-1 shell]
openstack