一、服务器部署minio

第一步:拉取镜像

docker pull minio/minio

第二步:创建容器

你可以通过INIO_ACCESS_KEY,MINIO_SECRET_KEY来设置账号密码,请记住这个账号密码,因为后面还要使用这个账号密码登录。并设置对应的端口,通过--console-address ":9001"这条指令设置对应的静态端口。网页访问是使用9001端口,但是java代码访问是使用9000端口。

docker run -p 9000:9000 -p 9001:9001 --name minio -d --restart=always -e "MINIO_ACCESS_KEY=admin" -e "MINIO_SECRET_KEY=12345678" -v /data/minio/data:/data -v /data/minio/config:/root/.minio minio/minio server /data --console-address ":9001"

运行以下命令,当出现下图提示时这表示创建成功。

docker ps

docker pwn 部署 docker部署minio_配置信息

第三步:网页连接minio

输入ip:端口即可访问你的minio ,在下图中输入你的账号密码即可登录。

第四步:创建储存桶

docker pwn 部署 docker部署minio_docker pwn 部署_02

docker pwn 部署 docker部署minio_配置信息_03

docker pwn 部署 docker部署minio_docker pwn 部署_04

这样就创建好了我们的存储桶。

第五步:设置存储桶权限

在创建好存储桶之后,我们为了使用远程连接来访问使用。所以有必要去修改一下存储桶的权限。

docker pwn 部署 docker部署minio_上传_05

我们点击最下面的那个Rules,然后点击右上角创建一个访问规则。可以使用精准匹配,也可以使用通配符。前缀我们使用* 这样可以匹配全部访问用户,下面的权限我们使用读写。

docker pwn 部署 docker部署minio_大数据_06

第六步:控制台实现文件的上传与下载

我们点到左边的功能栏,然后选择右边我们刚创建的存储桶。然后,,我觉得接下来的操作我都不用细说你们应该都会玩了。

docker pwn 部署 docker部署minio_大数据_07

同样,在上传成功后,也提供下载与预览功能。

docker pwn 部署 docker部署minio_docker pwn 部署_08

二、java整合minio

第一步:添加依赖

<dependency>
   <groupId>io.minio</groupId>
   <artifactId>minio</artifactId>
   <version>7.0.0</version>
</dependency>

第二步:添加配置信息

(1)application.yml配置文件

在 application.yml 文件中加入 MinIO 服务器的相关信息。注意:这里填写的端口号不是9001这个端口而是9000这个端口。 写错的话会提示报错:io.minio.errors.InvalidResponseException: Non-XML response from server。

# minio 文件存储配置信息
minio:
  endpoint: http://127.0.0.1:9000
  accesskey: minioadmin
  secretKey: minioadmin

(2)配置类 

@Data
@Component
public class MinioProp {


    @Value("${minio.endpoint}")
    private String endpoint;
    @Value("${minio.accesskey}")
    private String accesskey;
    @Value("${minio.secretKey}")
    private String secretKey;


}
@Configuration
public class MinioConfiguration {

    @Autowired
    private MinioProp minioProp;

    @Bean
    public MinioClient minioClient() throws InvalidPortException, InvalidEndpointException {
        MinioClient client = new MinioClient(minioProp.getEndpoint(), minioProp.getAccesskey(), minioProp.getSecretKey());
        return client;
    }


}

第三步:添加controller进行测试

@Slf4j
@RestController
public class MinioController {

    @Autowired
    private MinioClient minioClient;

    private static final String MINIO_BUCKET = "nie-1";

    @GetMapping("/list")
    public String list() throws IOException, InvalidKeyException, NoSuchAlgorithmException, InsufficientDataException, InvalidResponseException, InternalException, XmlParserException, InvalidBucketNameException, ErrorResponseException {
        List<Bucket> buckets = minioClient.listBuckets();

        for (Bucket bucket : buckets) {
            System.out.println("bucket.name() = " + bucket.name());
        }

        return buckets.toString();
    }
}

控制台显示了我的桶的名字,表示我测试成功了。

docker pwn 部署 docker部署minio_docker pwn 部署_09

三、常见错误与解决方法

1、Error response from daemon: driver failed programming external connectivity on endpoint minio 

完整提示:

Error response from daemon: driver failed programming external connectivity on endpoint minio (871a6f4cbf45fc8458713b41f733fd135a6e8ec1d67dedfe5ea3982f81739aaa):  (iptables failed: iptables --wait -t nat -A DOCKER -p tcp -d 0/0 --dport 9001 -j DNAT --to-destination 172.17.0.2:9001 ! -i docker0: iptables: No chain/target/match by that name.
 (exit status 1))