2016-07-19 14:56:34 -07:00
# Minio FreeBSD Quickstart Guide [![Gitter](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/minio/minio?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
2016-04-26 22:47:02 +05:30
### Minio with ZFS backend - FreeBSD
This example assumes that you have a FreeBSD 10.x running
2016-07-21 14:58:16 -07:00
#### Step 1.
2016-04-26 22:47:02 +05:30
As root on the FreeBSD edit `/etc/rc.conf`
2016-07-19 19:08:43 -07:00
2016-07-21 14:58:16 -07:00
```sh
2016-04-26 22:47:02 +05:30
zfs_enable="YES"
2016-07-21 14:58:16 -07:00
2016-04-26 22:47:02 +05:30
```
Start ZFS service
2016-07-19 19:08:43 -07:00
2016-07-21 14:58:16 -07:00
```sh
2016-04-26 22:47:02 +05:30
# service zfs start
```
2016-07-21 14:58:16 -07:00
```sh
2016-04-26 22:47:02 +05:30
# dd if=/dev/zero of=/zfs bs=1M count=4000
2016-07-21 14:58:16 -07:00
2016-04-26 22:47:02 +05:30
```
Configure a loopback device on the `/zfs` file.
2016-07-19 19:08:43 -07:00
2016-07-21 14:58:16 -07:00
```sh
2016-04-26 22:47:02 +05:30
# mdconfig -a -t vnode -f /zfs
2016-07-21 14:58:16 -07:00
2016-04-26 22:47:02 +05:30
```
Create zfs pool
2016-07-19 19:08:43 -07:00
2016-07-21 14:58:16 -07:00
```sh
2016-04-26 22:47:02 +05:30
# zpool create minio-example /dev/md0
```
2016-07-21 14:58:16 -07:00
```sh
2016-04-26 22:47:02 +05:30
# df /minio-example
Filesystem 512-blocks Used Avail Capacity Mounted on
minio-example 7872440 38 7872402 0% /minio-example
2016-07-21 14:58:16 -07:00
2016-04-26 22:47:02 +05:30
```
Verify if it is writable
2016-07-19 19:08:43 -07:00
2016-07-21 14:58:16 -07:00
```sh
2016-04-26 22:47:02 +05:30
# touch /minio-example/testfile
# ls -l /minio-example/testfile
-rw-r--r-- 1 root wheel 0 Apr 26 00:51 /minio-example/testfile
2016-07-21 14:58:16 -07:00
2016-04-26 22:47:02 +05:30
```
2016-08-15 02:44:48 -07:00
Now you have successfully created a ZFS pool for further reading please refer to [ZFS Quickstart Guide ](https://www.freebsd.org/doc/handbook/zfs-quickstart.html )
2016-04-26 22:47:02 +05:30
2016-04-29 13:35:20 -07:00
However, this pool is not taking advantage of any ZFS features, so let's create a ZFS filesytem on this pool with compression enabled. ZFS supports many compression algorithms: lzjb, gzip, zle, lz4. LZ4 is often the most performant algorithm in terms of compression of data versus system overhead.
2016-04-26 22:47:02 +05:30
2016-07-21 14:58:16 -07:00
```sh
2016-04-26 22:47:02 +05:30
# zfs create minio-example/compressed-objects
2016-04-29 13:35:20 -07:00
# zfs set compression=lz4 minio-example/compressed-objects
2016-07-21 14:58:16 -07:00
2016-04-26 22:47:02 +05:30
```
To keep monitoring your pool use
2016-07-21 14:58:16 -07:00
```sh
2016-04-26 22:47:02 +05:30
# zpool status
pool: minio-example
state: ONLINE
scan: none requested
config:
NAME STATE READ WRITE CKSUM
minio-example ONLINE 0 0 0
md0 ONLINE 0 0 0
errors: No known data errors
2016-07-21 14:58:16 -07:00
2016-04-26 22:47:02 +05:30
```
2016-07-21 14:58:16 -07:00
#### Step 2.
2016-04-26 22:47:02 +05:30
Now start minio server on the ``/minio-example/compressed-objects` `, change the permissions such that this directory is accessibly by a normal user
2016-07-21 14:58:16 -07:00
```sh
2016-04-26 22:47:02 +05:30
# chown -R minio-user:minio-user /minio-example/compressed-objects
2016-07-21 14:58:16 -07:00
2016-04-26 22:47:02 +05:30
```
Now login as ``minio-user` ` and start minio server.
2016-07-21 14:58:16 -07:00
```sh
2016-04-26 22:47:02 +05:30
$ curl https://dl.minio.io/server/minio/release/freebsd-amd64/minio > minio
$ chmod 755 minio
$ ./minio server /minio-example/compressed-objects
```
Point your browser to http://localhost:9000 and login with the credentials displayed on the command line.
Now you have a S3 compatible server running on top of your ZFS backend which transparently provides disk level compression for your uploaded objects.
Thanks for using Minio, awaiting feedback :-)
2016-07-21 14:58:16 -07:00
2016-04-29 13:35:20 -07:00
#### Building Minio Server From Source
It is possible to build the minio server from source on FreeBSD. To do this we will used the golang distribution provided by the FreeBSD pkg infrastructure.
First we will need to install golang as well as GNU make:
2016-07-21 14:58:16 -07:00
```sh
2016-04-29 13:35:20 -07:00
$ sudo pkg install go gmake
Updating FreeBSD repository catalogue..
FreeBSD repository is up-to-date.
All repositories are up-to-date.
The following 1 package(s) will be affected (of 0 checked):
New packages to be INSTALLED:
go: 1.6.2,1
gmake: 4.1_2
The process will require 261 MiB more space.
40 MiB to be downloaded.
Proceed with this action? [y/N]: y
Fetching go-1.6.2,1.txz: 100% 40 MiB 10.4MB/s 00:04
Fetching gmake-4.1_2.txz: 100% 363 KiB 372.2kB/s 00:01
Checking integrity... done (0 conflicting)
[1/2] Installing go-1.6.2,1...
[1/2] Extracting go-1.6.2,1: 100%
[2/2] Installing gmake-4.1_2...
[2/2] Extracting gmake-4.1_2: 100%
```
Next we need to configure our environment for golang. Insert the following lines into your ~/.profile file, and be sure to source the file before proceeding to the next step:
2016-07-21 14:58:16 -07:00
```sh
2016-04-29 13:35:20 -07:00
GOPATH=$HOME/golang; export GOPATH
GOROOT=/usr/local/go/; export GOROOT
2016-07-21 14:58:16 -07:00
2016-04-29 13:35:20 -07:00
```
Now we can proceed with the normal build process of minio server as found [here ](https://github.com/nomadlogic/minio/blob/master/CONTRIBUTING.md ). The only caveat is we need to specify gmake (GNU make) when building minio server as the current Makefile is not BSD make compatible:
2016-07-21 14:58:16 -07:00
```sh
2016-04-29 13:35:20 -07:00
$ mkdir -p $GOPATH/src/github.com/minio
$ cd $GOPATH/src/github.com/minio
$ git clone < paste saved URL for personal forked minio repo >
$ cd minio
$ gmake
2016-07-21 14:58:16 -07:00
2016-04-29 13:35:20 -07:00
```
From here you can start the server as you would with a precompiled minio server build.