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

测试minio集群的上传下载速度,第1张

本文旨在测试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

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/989833.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存