MinIO deployments come in all shapes and sizes. We support bare metal installs on any version of Linux, containerized installs on any version of Kubernetes (including Red Hat OpenShift), and installs just about anywhere you can deploy a small lightweight single binary. But with flexibility comes the inevitability that edge case issues will require debugging.
In this blog post, we’ll show you how to debug a MinIO install running in Kubernetes and also some of the common issues you might encounter when doing bare metal installation and how to rectify them.
There are a few ways to access the MinIO API running inside a Kubernetes cluster. We can use kubectl port-forwarding
or set up a Service
listening on NodePort
to be able to access the API. Both of these methods offer a way to access the service from outside the network, but they do come with one major downside: You can only access the Service that the NodePort or Port Forwarding references on an available port (not the usual configuration for the application). For example, you have to access the MinIO API, usually found on port 9000
, via a randomly assigned 3xxxx
port.
What if I told you there was a better way – and it's not novel? When debugging applications you want to have full access to the native run-time environment so you can use various tools to troubleshoot and debug the cluster. One way to do that is launching a “busybox” style pod and installing all the required tools needed to debug the application.
First launch a Pod
into the same namespace as your MinIO install. In order to do this create a yaml file called debugger-pod.yaml
with the following yaml.
apiVersion: v1
kind: Pod
metadata:
name: mc
labels:
app: mc
spec:
containers:
- image: minio/mc:latest
command:
- "sleep"
- "604800"
imagePullPolicy: IfNotPresent
name: mc
restartPolicy: Always
The above Pod configuration is pulling the image for MinIO mc
utility. In order to ensure the pod doesn’t just launch and then exit, we’ve added a sleep
command.
Once the yaml is saved apply the configuration to the Kubernetes namespace where the MinIO cluster is running
kubectl apply -f debugger-pod.yaml
Once the pod is up and running access it via shell
$ kubectl exec -i -t -n default mc -c mc -- sh -c "(bash || ash || sh)"
[root@mc /]#
Then with mc
you can access the MinIO cluster
[root@mc /]# mc alias set myminio --insecure
Added `myminio` successfully.
Now that we have a debugger pod up and running, you can perform action on the cluster directly within the same network. For example, if the replication was broken due to an site going offline or a hardware failure, you can resync any pending objects to be replicated using the following command
[root@mc /]# mc admin replicate resync start minio1 minio2
[root@mc /]# mc admin replicate resync status minio1 minio2
✔ ✔ ✔
ResyncID: 2248d1d1-633f-4d61-b938-d8ea0b9b2d31
Status: Completed
Objects: 2225
Versions: 2225
FailedObjects: 0
Throughput: 5.3 MiB/s
IOPs: 124.23 objs/s
Transferred: 94 MiB
Elapsed: 17.909833202s
CurrObjName: testbucket/web-app/tsconfig.json
Another reason you would run the debugger pod is if there are some file system permissions or invalid groups configurations in your pod, you can update them using the debugger pod
[root@mc /]# chgrp -R 1000780050 .minio.sys/
The above debugging method can also be used in bare metal environments. For instance you can launch a busybox or bastion node with mc
installed and follow the same instructions as above.
Bare metal Linux installs are the most straightforward. In fact it just takes a few commands to get MinIO installed and running with SystemD. For details, please see
Once in a great while, bare metal installs go awry. Here are some of the (not-so-common) pitfalls that we are asked about in
One of the most common pitfalls is the file permissions of the MinIO binary and the configuration file. If this occurs, when you start MinIO using SystemD you will see
Assertion failed for MinIO.
and here is the full stack trace
# systemctl status minio.service
● minio.service - MinIO
Loaded: loaded (/etc/systemd/system/minio.service; enabled; vendor preset: enabled)
Active: inactive (dead)
Assert: start assertion failed at Tue 2023-12-26 18:21:38 PST; 8s ago
AssertFileIsExecutable=/usr/local/bin/minio was not met
Docs: https://docs.min.io
Dec 26 18:13:37 minio1 systemd[1]: minio.service: Starting requested but asserts failed.
Dec 26 18:17:50 minio1 systemd[1]: Assertion failed for MinIO.
Dec 26 18:21:38 minio1 systemd[1]: minio.service: Starting requested but asserts failed.
Dec 26 18:21:38 minio1 systemd[1]: Assertion failed for MinIO.
This could be caused by a number of reasons, let's go down the list and check for each of them.
MinIO Binary: The binary, in this example located at /usr/local/bin/minio
needs to have root:root
permission for user and group, respectively.
# ll /usr/local/bin/minio
total 93804
-rwxr-xr-x 1 root root 96018432 Nov 15 16:35 minio*
MinIO Service User and Group: The MinIO service needs to run under a unique Linux user and group for security purposes, never run as a root
user. By default we use minio-user
for the user and group names. In the SystemD service config file you should see something like this
User=minio-user
Group=minio-user
MinIO Data Dir: The directory where MinIO data will be stored needs to be owned by minio-user:minio-user
or whichever user you decide to run the MinIO service as above.
# ls -l /mnt
total 4
drwxrwxr-x 2 minio-user minio-user 4096 Dec 27 09:58 data
SystemD and MinIO config: Both the config files should have permissions root:root
for user and group like so
# ls -l /etc/default/minio
-rw-r--r-- 1 root root 1330 Dec 27 09:52 /etc/default/minio
# ls -l /etc/systemd/system/minio.service
-rw-r--r-- 1 root root 941 Dec 26 17:13 /etc/systemd/system/minio.service
Run as Root: The entire install process should be run as root
. You can also try sudo
if your user has permissions but the recommendation is to run as root as the install needs to place files in a bunch of places that only the root
user can access. Your bash prompt should have a #
and not a $
like so
#
vs $
If none of the above work, the best approach is to remove the app, directories and configs and start a fresh install as a root user.
Another common issue related to deleted files which still hold on to the process, which causes port conflicts. Even when a service is not running, you may be unable to start a new service on the existing port or the service that is running will misbehave (such as not allowing you to login).
# lsof -n | grep (deleted)
COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME
nginx 13423 root 5u REG 253,3 42949672960 17 (deleted)
minio 13423 minio 6u REG 253,3 0 18 (deleted)
minio 13423 minio 7u REG 253,3 0 19 (deleted)
You might see errors such as those below on a MinIO install
net::ERR_FAILED
The screenshot above shows an internal server error and an unauthorized error. While looking at the surface it looks unclear what has caused this error, we can debug with a little linux knowledge what to look for that could cause this, let's take a gander.
There are several ways to debug this issue, first lets check to see if multiple MinIO processes are running on the same node
# ps aux | grep -i minio
minio-u+ 5048 0.3 1.7 1594008 144384 ? Ssl 11:03 0:01 /usr/local/bin/minio server --console-address :9001 /mnt/data/disk1/minio
minio-u+ 9276 0.3 1.7 1594208 144301 ? Ssl 11:25 0:01 /usr/local/bin/minio server --console-address :9001 /mnt/data/disk1/minio
As we can see above there are 2 MinIO processes running. Start by killing the process that is older or has been running the longest, in this case it seems to be the process ID 5048
.
kill -9 5048
Sometimes even after killing the process the service might still not start or might still get hung up because it has reserved a process number but not let it go. This can be caused by files that have been deleted but are still being tracked by the operating system. You can find the deleted files via LSOF
lsof -n | grep '(deleted)'
Last but not least, if there are no deleted files left over or hung processes and if everything looks absolutely clean, the last resort is to quickly restart the node. This is a no-nonsense method that shuts down and clears any pending files and processes so you start a fresh install.
Although rare, installation edge cases will always exist. MinIO customers know that they have nothing to worry about because they can quickly message our engineers – who have written the code – via the
If you have any questions on troubleshooting and debugging