首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将列表传递到并行

如何将列表传递到并行
EN

Stack Overflow用户
提问于 2015-04-02 15:56:18
回答 1查看 128关注 0票数 1

我试图在下面的脚本中使用并行

代码语言:javascript
复制
#!/bin/bash

declare -a ephemeral_list
for mount in $(lsblk | grep ^x | awk '{ print $1 }')
do
   if ! mount | grep $mount >/dev/null; then
      ephemeral_list+=($mount)
   fi
done

for i in "${!ephemeral_list[@]}"
do
  printf "%s\t%s\n" "$i" "${ephemeral_list[$i]}"
  [ -d /mnt/ephemeral$i ] || mkdir /mnt/ephemeral$i
  mkfs.ext4 -E nodiscard /dev/${ephemeral_list[$i]} &&  mount /dev/${ephemeral_list[$i]} /mnt/ephemeral$i &
done 

我想在这里的每个cpu上运行"mkfs.ext4 -E nodiscard /dev/${ephemeral_list$i} && mount/dev/${ephemeral_list$i}/mnt/短暂$i &“命令。

有什么帮助吗?

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-04-03 10:01:00

做一个函数。就这么说吧。

代码语言:javascript
复制
mymkfs() {
  printf "%s\t%s\n" "$1" "$2"
  [ -d /mnt/ephemeral$1 ] || mkdir /mnt/ephemeral$1
  mkfs.ext4 -E nodiscard /dev/"$2" &&  mount /dev/"$2" /mnt/ephemeral$1
}
export -f mymkfs

parallel mymkfs {#} {} ::: "${ephemeral_list[@]}"
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29417307

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档