测试minio集群的上传下载速度

本文旨在测试minio集群部署的情况下,上传和下载文件的速度。

1.环境部署

机器IP配置配置
minio服务器192.168.35.111linux系统,内存4G,cpu核数2个,硬盘1000G
minio服务器192.168.35.112linux系统,内存4G,cpu核数2个,硬盘1000G
minio服务器192.168.35.113linux系统,内存4G,cpu核数2个,硬盘1000G
minio服务器192.168.35.114linux系统,内存4G,cpu核数2个,硬盘1000G
客户端192.168.32.184windows系统,

2.下载minio

wget https://dl.min.io/server/minio/release/darwin-amd64/minio
chmod +x minio

3.启动minio

./minio server   -address ":9051"  --console-address ":9050" --config-dir ./config  http://192.168.35.111/
home/lyz/data  http://192.168.35.112/home/lyz/data   http://192.168.35.113/home/lyz/data  http://192.168.35.114/home/lyz/data

4.上传测试脚本

package main

import (
	"context"
	"fmt"
	"log"
	"time"

	"github.com/minio/minio-go/v7"
	"github.com/minio/minio-go/v7/pkg/credentials"
)

func main() {
	ctx := context.Background()
	endpoint := "192.168.35.111:9051"
	accessKeyID := "minioadmin"
	secretAccessKey := "minioadmin"
	useSSL := false

	// Initialize minio client object.
	minioClient, err := minio.New(endpoint, &minio.Options{
		Creds:  credentials.NewStaticV4(accessKeyID, secretAccessKey, ""),
		Secure: useSSL,
	})
	if err != nil {
		log.Fatalln(err)
	}

	// Make a new bucket called mymusic.
	bucketName := "mymusic"
	location := "us-east-1"

	err = minioClient.MakeBucket(ctx, bucketName, minio.MakeBucketOptions{Region: location})
	if err != nil {
		// Check to see if we already own this bucket (which happens if you run this twice)
		exists, errBucketExists := minioClient.BucketExists(ctx, bucketName)
		if errBucketExists == nil && exists {
			log.Printf("We already own %s\n", bucketName)
		} else {
			log.Fatalln(err)
		}
	} else {
		log.Printf("Successfully created %s\n", bucketName)
	}

	// Upload the zip file
	objectName := "/extern.rar"
	filePath := "E:/Model/extern.rar"
	contentType := "application/rar"

	t1 := time.Now()
	info, err := minioClient.FPutObject(ctx, bucketName, objectName, filePath, minio.PutObjectOptions{ContentType: contentType})
	if err != nil {
		log.Fatalln(err)
	}
	t2 := time.Now()
	fmt.Println("diff : " + t2.Sub(t1).String())

	log.Printf("Successfully uploaded %s of size %d\n", objectName, info.Size)
}

5.上传测试结果

文件名文件大小平均上传耗时平均上传速度
114.4M 621ms23.1884M/s

2

163M6.5056045s25.124M/s
3931M20.8479114s44.657M/s
42.03G1m14.6236129s27.856M/s
5  
 
10.7G  5m40.7467879s32.155M/s

6.下载测试脚本

package main

import (
	"context"
	"fmt"
	"io"
	"log"
	"os"
	"time"

	"github.com/minio/minio-go/v7"
	"github.com/minio/minio-go/v7/pkg/credentials"
)

func main() {
	ctx := context.Background()
	endpoint := "192.168.35.111:9051"
	accessKeyID := "minioadmin"
	secretAccessKey := "minioadmin"
	useSSL := false

	// Initialize minio client object.
	minioClient, err := minio.New(endpoint, &minio.Options{
		Creds:  credentials.NewStaticV4(accessKeyID, secretAccessKey, ""),
		Secure: useSSL,
	})
	if err != nil {
		log.Fatalln(err)
	}

	bucketName := "mymusic"
	// download the zip file
	objectName := "extern.rar"

	t1 := time.Now()
	object, err := minioClient.GetObject(ctx, bucketName, objectName, minio.GetObjectOptions{})
	if err != nil {
		fmt.Println(err)
		return
	}

	localFile, err := os.Create("D:/testminio/" + objectName)
	if err != nil {
		fmt.Println(err)
		return
	}
	if _, err = io.Copy(localFile, object); err != nil {
		fmt.Println(err)
		return
	}

	t2 := time.Now()
	fmt.Println("diff : " + t2.Sub(t1).String())

	log.Printf("Successfully download %s of size %d\n", objectName, 0)
}

7.下载测试结果

文件名文件大小平均下载耗时平均下载速度
114.4M212.7193ms67.695M/s
2163M1.8019099s90.455M/s
3931M9.3173644s99.921M/s
42.03G21.9392096s94.750M/s
510.7G2m5.2534976s87.477M/s

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值