38.分布式文件系统 - Minio

news/2024/5/20 3:51:44

文章目录

    • 分布式文件系统
      • MinIO
        • 安装和启动
        • docker中MinIO的使用
          • podman
        • 虚拟机里使用Docker启minio
          • ==配置(成功访问)==
      • Java连接minio

分布式文件系统

MinIO

官网:[https://min.io]

中文:[https://www.minio.org.cn/] [http://docs.minio.org.cn/docs/]

安装和启动

https://min.io/docs/minio/windows/index.html#procedure

  1. 下载:
https://dl.min.io/server/minio/release/windows-amd64/minio.exe
  1. 可以把下载好的minio.exe(minio server)添加到环境变量中。

启动minio server

.\minio.exe server C:\minio --console-address :9090

其中,C:\minio是文件保存路径。

  1. 应用连接MinIO server

浏览器连接:http://127.0.0.1:9090

  1. 安装minio client(可选)
https://dl.min.io/client/mc/release/windows-amd64/mc.exe
docker中MinIO的使用

https://min.io/docs/minio/container/index.html#procedure

https://min.io/download#/docker

  1. 在容器中启动minio server
podman run -p 9000:9000 -p 9001:9001 minio/minio server /data --console-address ":9001"

或者

sudo docker run -p 9000:9000 -p 9001:9001 minio/minio server /data --console-address ":9001"

这个命令使用 podman(一个没有守护进程的Docker的替代方案)来运行MinIO服务器。让我们逐步分析这个命令的各个部分:

  1. podman run: podmanrun 命令用于创建并运行一个新的容器实例。
  2. -p 9000:9000: 这是端口映射参数。它将容器的 9000 端口映射到宿主机的 9000 端口。MinIO默认在 9000 端口上运行,这允许你通过宿主机的 9000 端口访问它。
  3. -p 9001:9001: 与上面的参数类似,但这是为MinIO的新控制台界面(Console)进行的端口映射,该控制台在版本 RELEASE.2021-04-22T15-44-28Z 之后被引入。
  4. minio/minio: 这是要运行的Docker镜像的名称,它包含MinIO的代码。
  5. server /data: 这告诉MinIO以服务器模式运行,并将其数据目录设置为容器内的 /data 路径。
  6. –console-address “:9001”: 这是一个新的参数,它告诉MinIO在哪个地址和端口上启动其控制台服务。在这种情况下,它将在容器的 9001 端口上启动,这与我们之前为它映射的端口匹配。
podman

总之,这个命令使用 podman 在容器中运行MinIO服务,并同时为MinIO的主服务和新的控制台服务设置了端口映射。

Podman(Pod Manager tool)是一个开源的容器运行时工具,它可以在没有守护进程的情况下管理和运行OCI(Open Container Initiative)兼容的容器和容器镜像。这与Docker不同,Docker依赖于一个守护进程来管理和运行容器。

以下是关于Podman的一些关键点:

  1. 无守护进程:与Docker不同,Podman不需要长时间运行的守护进程。这减少了复杂性并提高了安全性。

  2. 兼容Docker CLI:Podman的命令行接口(CLI)是与Docker兼容的,这意味着对于许多常见的操作,你可以使用与Docker相同的命令,只需将docker替换为podman

  3. Rootless运行:Podman允许普通用户(非root用户)运行容器,而不需要特殊的权限或附加的守护进程。这增强了安全性。

  4. Pod的概念:虽然你可以使用Podman来运行单个的容器,但它也引入了"Pod"的概念,其中可以运行多个容器,这与Kubernetes中的Pod概念类似。

  5. 兼容性:Podman容器和镜像是与Docker容器和镜像兼容的,因为它们都遵循OCI规范。

  6. 与其他工具集成:Podman与其他工具,如Buildah(用于构建容器镜像)和Skopeo(用于容器镜像的远程检索和存储),非常好地集成在一起。

  7. 没有中央服务器:由于Podman没有守护进程,因此它不需要中央服务器来运行或管理容器。每个Podman命令都是独立运行的。

  8. 迁移到Kubernetes:Podman可以生成Kubernetes的YAML定义,这有助于将容器化的应用程序从单机迁移到Kubernetes集群。

Podman提供了一种更简洁、更安全的方式来运行和管理容器,特别是对于那些希望避免Docker守护进程或在没有root权限的环境中运行容器的用户。

虚拟机里使用Docker启minio

https://blog.csdn.net/BThinker/article/details/125412751

要在虚拟机中使用Docker启动MinIO服务并让主机可以访问它,您需要执行以下步骤:

  1. 设置虚拟机:

    根据您使用的虚拟化软件(如VirtualBox、VMware等),请确保虚拟机的网络设置是桥接模式或NAT模式,并确保您可以从主机ping通虚拟机。

  2. 安装Docker:

    在虚拟机中,首先安装Docker。您可以按照Docker的官方安装指南来进行安装。

  3. 启动MinIO服务:

    在虚拟机的Docker中启动MinIO服务:

    docker run -p 9000:9000 --name minio-instance \-e "MINIO_ROOT_USER=myaccesskey" \-e "MINIO_ROOT_PASSWORD=mysecretkey" \minio/minio server /data
    

    这将启动一个MinIO实例,并将其9000端口映射到虚拟机的9000端口。

  4. 允许外部访问:

    根据您的虚拟机操作系统,确保其防火墙允许从外部访问9000端口。例如,在使用firewalld的Linux系统上,您可以执行以下命令:

    sudo firewall-cmd --zone=public --add-port=9000/tcp --permanent
    sudo firewall-cmd --reload
    
  5. 从主机访问MinIO服务:

    打开浏览器或使用任何客户端,并向虚拟机的IP地址和9000端口发出请求。例如,如果虚拟机的IP地址是192.168.1.100,则访问:

    http://192.168.1.100:9000
    

    使用您为MinIO设置的访问密钥和秘密密钥登录。

  6. 注意事项:

    • 确保虚拟机的网络设置正确,并且您的主机和虚拟机之间没有任何阻止通信的网络策略或防火墙。
    • 如果您使用的是NAT模式,您可能需要进行端口转发,以便从主机访问虚拟机上的服务。

按照上述步骤,您应该可以从主机成功地访问虚拟机中的MinIO服务。

配置(成功访问)
sudo docker run -p 9000:9000 -p 9090:9090 \--net=host \--name minio \-d --restart=always \-e "MINIO_ACCESS_KEY=minioadmin" \-e "MINIO_SECRET_KEY=minioadmin" \-v /home/mkid/software/minio/data:/data \-v /home/mkid/software/minio/config:/root/.minio \minio/minio server \/data --console-address ":9090" -address ":9000"

这个命令使用Docker来启动一个MinIO的实例。让我们逐步分析这个命令:

  1. sudo: 使用超级用户权限来执行后面的命令。

  2. docker run: 使用Docker运行一个新的容器。

  3. -p 9000:9000 -p 9090:9090: 端口映射。这两个参数告诉Docker将容器内的9000和9090端口分别映射到主机的9000和9090端口。

  4. –net=host: 使用主机的网络堆栈。这意味着容器将共享主机的网络名称空间。

  5. –name minio: 为容器指定一个名称,即“minio”。

  6. -d: 以分离模式运行容器,这意味着容器在后台运行。

  7. –restart=always: 如果容器由于任何原因停止,Docker将总是尝试重新启动它。

  8. -e “MINIO_ACCESS_KEY=minioadmin” -e “MINIO_SECRET_KEY=minioadmin”: 设置MinIO的访问和密钥环境变量。

  9. -v /home/mkid/software/minio/data:/data -v /home/mkid/software/minio/config:/root/.minio: 这两个参数定义了卷挂载。它们告诉Docker将主机上的指定目录挂载到容器内的指定路径。这样,数据和配置将在主机上持久化。

  10. minio/minio server: 指定使用的镜像并告诉容器以MinIO服务器模式运行。

  11. /data: 告诉MinIO服务器将数据存储在容器内的/data目录中。

  12. –console-address “:9090”: 指定MinIO控制台应绑定到容器内的9090端口。

  13. -address “:9000”: 指定MinIO服务器应绑定到容器内的9000端口。

总的来说,这个命令启动了一个MinIO服务器的Docker容器实例,并设置了相应的访问密钥、密钥、网络设置和持久化存储。这个实例将使用主机网络,同时也映射了9000和9090这两个端口。

Java连接minio

https://min.io/docs/minio/linux/developers/java/minio-java.html#minio-java-quickstart

上传文件示例FileUploader.java

import io.minio.BucketExistsArgs;
import io.minio.MakeBucketArgs;
import io.minio.MinioClient;
import io.minio.UploadObjectArgs;
import io.minio.errors.MinioException;
import java.io.IOException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;public class FileUploader {public static void main(String[] args)throws IOException, NoSuchAlgorithmException, InvalidKeyException {try {// Create a minioClient with the MinIO server playground, its access key and secret key.MinioClient minioClient =MinioClient.builder().endpoint("https://play.min.io").credentials("Q3AM3UQ867SPQQA43P2F", "zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG").build();// Make 'asiatrip' bucket if not exist.boolean found =minioClient.bucketExists(BucketExistsArgs.builder().bucket("asiatrip").build());if (!found) {// Make a new bucket called 'asiatrip'.minioClient.makeBucket(MakeBucketArgs.builder().bucket("asiatrip").build());} else {System.out.println("Bucket 'asiatrip' already exists.");}// Upload '/home/user/Photos/asiaphotos.zip' as object name 'asiaphotos-2015.zip' to bucket// 'asiatrip'.minioClient.uploadObject(UploadObjectArgs.builder().bucket("asiatrip").object("asiaphotos-2015.zip").filename("/home/user/Photos/asiaphotos.zip").build());System.out.println("'/home/user/Photos/asiaphotos.zip' is successfully uploaded as "+ "object 'asiaphotos-2015.zip' to bucket 'asiatrip'.");} catch (MinioException e) {System.out.println("Error occurred: " + e);System.out.println("HTTP trace: " + e.httpTrace());}}
}

http://www.mrgr.cn/p/03351234

相关文章

细说夜莺监控系统告警自愈机制

虽说监控系统最侧重的功能是指标采集、存储、分析、告警,为了能够快速恢复故障,告警自愈机制也是需要重点投入建设的,所有可以固化为脚本的应急预案都可以使用告警自愈机制来快速驱动。夜莺开源项目从 v7 版本开始内置了告警自愈模块,本文将详细介绍告警自愈的原理和实现。…

掌握Android Fragment开发之魂:Fragment的深度解析(上)

Fragment是Android开发中用于构建动态和灵活界面的基石。它不仅提升了应用的模块化程度,还增强了用户界面的动态性和交互性,允许开发者将应用界面划分为多个独立、可重用的部分,每个部分都可以独立于其他部分进行操作。本文将从以下几个方面深…

【web网页制作】html+css旅游家乡河南开封主题网页制作(4页面)【附源码】

HTMLCSS家乡河南主题网页目录 🍔涉及知识🥤写在前面🍧一、网页主题🌳二、页面效果Page1 首页Page2 开封游玩Page 3 开封美食Page4 留言 🌈 三、网页架构与技术3.1 脑海构思3.2 整体布局3.3 技术说明书 🐋四…

程序员副业创富:业余时间解锁首笔财富里程碑

在这个充满机遇的数字时代,我,一个普通的程序猿,编程爱好者,终于在云端源想这个平台上收获了属于我的第一桶金。这是一个关于兼职、学习与成长的故事,希望能激发同在编程路上的你,勇敢迈出那一步。 先晒晒我的首笔收入:一个普通的周末,我像往常一样,泡上一杯咖啡,坐在…

(一)文本分类经典模型之CNN篇

这篇blog对NLP领域的基本任务文本分类的CNN经典模型做了梳理CNN源于计算机视觉研究,后来诸多学者将其应用于短文本分类,其基本结构如下图所示:由上图可知,基于CNN的短文本分类模型,通常包括输入层、卷积层、池化层、全连接层和输出层五部分,其中卷积层和池化层是最为关键…

抖音小店是什么?它和直播带货有什么区别和联系?一篇详解!

大家好,我是电商糖果 在网上大家都说抖音的流量大,在抖音做电商比较赚钱。 可是有很多人对抖音电商并不了解。 甚至搞不懂抖音小店是什么?它和直播带货的区别和联系也不清楚。 下面,糖果就来给大家好好解答一下这个问题。 抖音…

Django 4.x 智能分页get_elided_page_range

Django智能分页 分页效果 第1页的效果 第10页的效果 带输入框的效果 主要函数 # 参数解释 # number: 当前页码,默认:1 # on_each_side:当前页码前后显示几页,默认:3 # on_ends:首尾固定显示几页&#…

Apache DolphinScheduler 3.3.0 版本重磅更新提前看!

Apache DolphinScheduler 3.3.0版本终于要在万众期待中发布啦!本次发版将有重大功能更新,包括架构上的调整。 为了让广大用户提前尝鲜,社区特别准备了直播活动提前揭秘3.3.0版本中的重要更新,到时候你将会了解到这些信息:3.3.0版本的工作流引擎改进 任务执行流程的优化 架…

激光雕刻优化:利用RLE压缩技术提高雕刻效率与节省能源成本

什么是 RLE ?RLE 在激光雕刻应用实现代码:总结 什么是 RLE ? RLE 是 Run-Length Encoding(游程长度编码)的缩写。这是一种数据压缩技术,它通过减少连续重复的数据来减小文件的大小。RLE 在图像处理、无损…

【重塑世界的火种】制造业:从匠人之心到智能未来之旅

在人类文明的宏伟乐章中,有一段旋律始终激昂,它既古老又现代,既是力量的象征,也是智慧的结晶——这就是制造业,一个将梦想变为现实,将创意铸就为生活的神奇领域。今天,让我们一起走进这个塑造世…

【触想智能】工业级平板电脑五大特征与应用领域分析

工业级平板电脑是专供工业环境使用的工业控制计算机,也被称为工控一体机。工业级平板电脑基本性能及兼容性与商用平板电脑几乎相同,但是工业级平板电脑更注重在不同环境下的稳定性能,因此,工业级平板电脑与普通的商用平板电脑存在一定的区别。一、工业级平板电脑的五大特征…

2024软件测试自动化面试题(含答案)

1.如何把自动化测试在公司中实施并推广起来的? 选择长期的有稳定模块的项目 项目组调研选择自动化工具并开会演示demo案例,我们主要是演示selenium和robot framework两种。 搭建自动化测试框架,在项目中逐步开展自动化。 把该项目的自动化…

58微聊消息自动回复 – 58微聊自动回复机器人 – 浏览器插件

58同城上发布了产品,有咨询客户通过微聊联系我们,我们插件可以实现自动回复消息效果演示 58微聊消息自动回复,浏览器插件实现 #自动回复 #58同城 #58 – 抖音 (douyin.com) 功能列表关键词自动回复AI知识库自动回复下载插件 请联系微信:llike620 付费获取浏览器插件 原文地…

企业网站从传统服务器迁移到弹性云有什么优势呢?

现代企业对于网站和应用程序的可用性和性能要求越来越高,传统基础设施可能无法满足这些需求。弹性云作为一种新兴的云计算服务模式,对于企业网站的运行和管理带来了许多优势。下面是企业网站从传统服务器迁移到弹性云的五大优势: 灵活弹性&a…

黑马点评项目总结

登录 基于session登录 短信验证码登录 配置登录拦截器 向 Spring MVC 框架中添加拦截器,LoginInterceptor 是一个自定义的拦截器,用于拦截用户的登录请求。 excludePathPatterns这一句是设置拦截器需要放行的请求路径列表。 "/user/code", …

新版宝塔加密数据解密

宝塔更新了数据存储的方式,PanelForensics会尽快支持最近啊,fic中出现了宝塔,结果PanelForensics居然没有梭哈,这怎么行?? 于是我就一通分析,发现这个版本更新了架构,并且对密码的加解密是通过调用二进制依赖进行实现的 我这里就以mysql的密码为例,在新版本中,mysql的…

【挑战30天首通《谷粒商城》】-【第一天】03、简介-分布式基础概念

文章目录 课程介绍 ( 本章了解即可,可以略过)1、微服务简而言之: 2、集群&分布式&节点2.1、定义2.2、示例 3、远程调用4、负载均衡常见的负裁均衡算法: 5、服务注册/发现&注册中心6、配置中心7、服务熔断&服务降级7.1、服务熔断7.2、服务降级 8、AP…

数据库(MySQL)—— DML语句

数据库(MySQL)—— DML语句 什么是DML语句添加数据给全部字段添加数据批量添加数据 修改数据删除数据 什么是DML语句 在MySQL中,DML(Data Manipulation Language,数据操纵语言)语句主要用于对数据库中的数…

MongoDB索引

MongoDB索引 概述 索引支持在MongoDB中高效地执行查询。如果没有索引,MongoDB必须执行全集合扫描,即扫描集合中的每个文档,以选择与查询语句匹配的文档。这种扫描全集合的查询效率是非常低的,特别在处理大量的数据时,查询可以要花费几十秒甚至几分钟,这对网站的性能是非常…

Vue2工程化介绍

Vue2项目[基于vue-cli]工程化 【一】环境搭建06-Vue-cli - 刘清政 - 博客园 (cnblogs.com)安装node 使用npm/cnpm npm换源:npm config set registry https://registry.npmmirror.com 安装vue-cli cnpm install -g @vue/cli# 安装脚手架 cnpm install -g @vue/cli # 切换目录,…