这里说的并行执行命令,是指同步某个文件这类涉及多个节点,且命令体单一,需要一起执行来提升效率的命令操作,操作时可以用linux自带的xargs命令完成
#!/bin/bash
LOCAL_FILE="/path/to/local/file"
REMOTE_DIR="/path/to/remote/dir"
USER="your_username"
# 使用xargs并行执行scp命令,-P 10指定并行度为10,大写I 指定循环识别的内容,以行为单位,I 后面的花括号表示管道前一个命令的输出,其他的花括号表示每行值的占位符
cat servers.txt | xargs -P 10 -I {} scp -r "${LOCAL_FILE}" "${USER}@{}:${REMOTE_DIR}"
需要注意的是xargs -P 10 -I {}
后面直接跟命令,需要字符串的时候可以写双单引号包一下,否则不要写整体的双单引,会导致xargs命令不识别命令体,多个命令就用 ;
分开即可,或者同步一个脚本过去