MinIO服务器文件复制(Windows环境&Linux环境)

一、下载

Windows环境:https://dl.min.io/server/minio/release/windows-amd64/minio.exe

Linux环境:

bash 复制代码
> curl https://dl.min.io/client/mc/release/linux-amd64/mc \ 
--create-dirs \ 
-o $HOME/minio/mc 

> chmod +x $HOME/minio/mc 

> export PATH=$PATH:$HOME/minio/

二、准备好MinIO服务器需要复制的完整文件路径,以及配置需要复制的目标文件完整路径

(注意:需要指定MinIO连接服务的别名,通过命令:mc alias set myMinio [host] [user] [password] 来指定),此处 别名就是 myMinio

mc 复制文件语法:

bash 复制代码
./mc cp [source full path] [target full path]

示例文件(本文批处理文件如下),如创建文件 /tmp/mini_cp.txt,内容如下:

myMinio/srcBucket/1.png myMinio/targetBucket/1.png

myMinio/srcBucket/2.png myMinio/targetBucket/2.png

myMinio/srcBucket/3.png myMinio/targetBucket/3.png

三、创建MC shell脚本

1.Windows环境

bash 复制代码
@echo off
CHCP 65001
cd /d "%~dp0"
::Local MinIO
::set filename=E:\tmp\localToCopyFileList.txt
::set minioapiurl=http://127.0.0.1:9001
::set user=admin
::set pwd=minioadmin

%cd%\bin\mc.exe alias set myminio %minioapiurl% %user% %pwd%
echo 待复制文件列表路径:%filename%

set /a count=0;

setlocal enabledelayedexpansion
for /f "tokens=*" %%a in (%filename%) do (
	set /a count+=1
	echo Coping No.!count! file:%%a
	%cd%\bin\mc.exe cp %%a
)
echo 本次共复制文件:!count!个!
@echo pause

2.Linux环境

bash 复制代码
chmod +x mccp.sh
bash 复制代码
#!/bin/bash

# minio S3服务地址
minio_host="http://127.0.0.1:9001"
user="admin"
passwd="minioadmin"


filename="${1}"

if [ ! "${filename}" ]; then
        echo "请在命令行后指定完整文件路径!"
        exit 1
fi

if [ ! -f "${filename}" ]; then
        echo "文件路径不存在: ${filename}!"
        exit 1
fi

# 设置minio服务连接别名
./mc alias set cminio ${minio_host} ${user} ${passwd}
while IFS= read -r line; do
        echo "正在读取行: ${line}"
        # 执行复制操作,line的格式必须是:cminio/ + 完整minio服务器文件路径(包含bucket)
        ./mc cp ${line}
done < "${filename}"

执行脚本 mccp.sh 或 mccp.bat

相关推荐
珠海西格21 小时前
光伏电站全景感知体系:数据采集与设备状态监测技术
大数据·运维·服务器·数据库·人工智能
大黄说说1 天前
深入理解 Linux 权限机制:文件、用户与访问控制全解析
linux·运维·服务器
黄昏晓x1 天前
Linux----缓冲区
linux·运维·服务器
2501_901147831 天前
学习笔记:单调递增数字求解的迭代优化与工程实践
linux·服务器·笔记·学习·算法
寄存器漫游者1 天前
Linux 软件编程 命令、内核与 Shell
linux·运维·服务器
TTBIGDATA1 天前
【Atlas】Atlas Hook 消费 Kafka 报错:GroupAuthorizationException
hadoop·分布式·kafka·ambari·hdp·linq·ranger
Kaede61 天前
服务器硬件防火墙和软件防火墙的区别
运维·服务器
qinyia1 天前
通过本地构建解决Cartographer编译中absl依赖缺失问题
linux·运维·服务器·mysql·ubuntu
小草cys1 天前
鲲鹏920服务器安装openEuler后无法联网,但物理网线已连接
运维·服务器·openeuler
野犬寒鸦1 天前
从零起步学习并发编程 || 第五章:悲观锁与乐观锁的思想与实现及实战应用与问题
java·服务器·数据库·学习·语言模型