I'm testing Prometheus, with a cTor Storage Class with OpenEBS, in a Rancher 2.1 Cluster (1 node) with RancherOS running in Hyper-v. The cStor volume is not mounting, and the pod is launching a event:
Unable to mount volumes for pod "prometheus-server-595746cc5-7xrmt_prometheus(46f03eb4-630f-11e9-b3e5-00155daf3d1f)": timeout expired
waiting for volumes to attach or mount for pod "prometheus"/"prometheus-server-595746cc5-7xrmt". list of unmounted volumes=[storage-volume]. list of
unattached volumes=[config-volume storage-volume prometheus-server-token-2w8ng] a minute ago
I'm thinking that this is related with the output from command:
sudo ros s up open-iscsi
That is:
[rancher@kub-master ~]$ sudo ros s up open-iscsi
ERRO[0002] non-200 http response: 404
ERRO[0002] Failed to load rancher.docker.engine=(docker-18.09.5-ce): non-200
http response: 404
INFO[0002] Project [os]: Starting project
INFO[0002] [0/21] [open-iscsi]: Starting
INFO[0092] [1/21] [open-iscsi]: Started
INFO[0092] Project [os]: Project started
So, the question is...the ERRO[0002] is important? where is documented how can i fix that?
I can't find how to fix that, and I tried:
- Reinstalling the open-iscsi service.
- As i'm unsure if the container cannot mount the volume because this error, then i have tried recreating the Pool, the Storage class, ..., and the error persists.
The error from the pod (unable to mount) is not enough information. Check the logs and events for the OpenEBS provisioner or any pod that starts with
pvc
in theopenebs
namespace. That should tell you the actual problem.If you're running a 1-node cluster, did you tell OpenEBS not to make 3 replicas? It might be waiting for the other 2 replicas to come online and thus is not able to make the volume available for the prometheus Pod to use.
These are just thoughts off the top of my head.
The 404 error is strange, but it seems to have loaded the open-iscsi drivers without error. It might not matter. Check Github for an issue about it, and if there isn't one, please open one and document how to reproduce the error.