Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

cd: /data/compose/62: No such file or directory #85

Open
lockheed opened this issue Jun 17, 2024 · 11 comments
Open

cd: /data/compose/62: No such file or directory #85

lockheed opened this issue Jun 17, 2024 · 11 comments
Labels
help wanted Extra attention is needed portainer Issues related to containers made with portainer.

Comments

@lockheed
Copy link

lockheed commented Jun 17, 2024

I tried to run this and got the following error on adguardhome. Any idea what can be the cause?

Choose what containers to update.
Enter number(s) separated by comma, [a] for all - [q] to quit: 1,2,3,20,23

Updating containers:
(...)

/root/.local/bin/dockcheck.sh: line 315: cd: /data/compose/62: No such file or directory
Path error - skipping adguardhome
/root/.local/bin/dockcheck.sh: line 315: cd: /data/compose/62: No such file or directory
Path error - skipping adguardhome-sync
/root/.local/bin/dockcheck.sh: line 315: cd: /data/compose/175: No such file or directory
Path error - skipping db-backup
/root/.local/bin/dockcheck.sh: line 315: cd: /data/compose/4: No such file or directory
Path error - skipping deluge
/root/.local/bin/dockcheck.sh: line 315: cd: /data/compose/191: No such file or directory
Path error - skipping jellystat.kv
/root/.local/bin/dockcheck.sh: line 315: cd: /data/compose/172: No such file or directory
Path error - skipping metube
/root/.local/bin/dockcheck.sh: line 315: cd: /data/compose/109: No such file or directory
Path error - skipping plant-it
/root/.local/bin/dockcheck.sh: line 315: cd: /data/compose/5: No such file or directory
Path error - skipping nginx_filmweb
/root/.local/bin/dockcheck.sh: line 315: cd: /data/compose/27: No such file or directory
Path error - skipping paperless
/root/.local/bin/dockcheck.sh: line 315: cd: /data/compose/27: No such file or directory
Path error - skipping paperless-redis
/root/.local/bin/dockcheck.sh: line 315: cd: /data/compose/32: No such file or directory
Path error - skipping pingvin-share
@mag37
Copy link
Owner

mag37 commented Jun 17, 2024

I'm guessing they're all started with portainer?
It's not only adguardhome, all the containers in the list trying to cd to /data/compose/### which looks like portainer structure.

I've tried to look into how I could support containers started with portainer, but no luck yet.

@lockheed - please confirm if they're started with portainer.

@lockheed
Copy link
Author

They are all created as portainer stacks, not sure if they are "being started" by portainer.

@mag37
Copy link
Owner

mag37 commented Jun 17, 2024

Yeah, thats it I'm afraid.
Portainer doesn't handle docker compose the usual way in the backend, which ends up with different labels and setups. So the script cant do its things.

Sorry I can't help you with that, there's a few other issues open about portainer. I'll close this one, as there's nothing new.

@mag37
Copy link
Owner

mag37 commented Jun 17, 2024

Duplicate of #40

@mag37 mag37 marked this as a duplicate of #40 Jun 17, 2024
@mag37 mag37 added wontfix This will not be worked on portainer Issues related to containers made with portainer. labels Jun 17, 2024
@mag37 mag37 closed this as not planned Won't fix, can't repro, duplicate, stale Jun 17, 2024
@lockheed
Copy link
Author

lockheed commented Jun 17, 2024

What are the chances/timeline to get it fixed?
Does this also apply to dockge and dockemon, or just portainer?

@mag37
Copy link
Owner

mag37 commented Jun 17, 2024

No timeline and slim chances.
I'll give it another look if I get time to spare, but last time I spun up a test machine with portainer I didn't find a solution.

Never used either but from what I could tell when reading quickly it seems like it should work.
As long as they dont do anything odd with the compose files etc.

@jermanoid
Copy link

it seems like maybe mapping Portainer's data directory to /data would fix this. or having a parameter in dockcheck.sh that let you provide the path to wherever you have the data directory mapped. I'm sure there is more nuance in there somewhere that is less obvious to me.

@jermanoid
Copy link

jermanoid commented Jun 19, 2024

I set a symbolic link at /data that points to my portainer container's /data map.
ln -s /docker/storage/portainer/data /data
then I ran dockcheck.sh and it at least downloads the images, although it tangles trying to recreate the containers due to a "naming conflict"

@mag37 mag37 removed the wontfix This will not be worked on label Jun 19, 2024
@mag37 mag37 reopened this Jun 19, 2024
@mag37
Copy link
Owner

mag37 commented Jun 19, 2024

I set a symbolic link at /data that points to my portainer container's /data map. ln -s /docker/storage/portainer/data /data then I ran dockcheck.sh and it at least downloads the images, although it tangles trying to recreate the containers due to a "naming conflict"

That's interesting!
Last time I remember some of the labels/info the script needs to extract from the containers didn't work.

I dont have time to check it right now, will try to run a VM and test some stuff when I can.

But maybe you could check errorCheck.sh and paste what it spits out? You dont need to run it on your whole stack, just test some containers and see
For example: ./errorCheck.sh homer

@mag37
Copy link
Owner

mag37 commented Jun 23, 2024

I've been labbing a little with this in a VM now, and while I can write some (ugly, will clean) logic to do a few checks and rewrites the path if a container has the portainer structure /data/compose/### to use the compose-location.. I also hit the issue with recreation breaking.

If I added something to stop+rm the container and then recreate it, it's not managed by Portainer anymore when it gets up.
And I dont know if people uses docker-volumes for the portainer data, then it'll work differently I'm afraid. Have not tested that yet.

My testing modifications have been something like this:

## Added this before line 314, will only work if your portainer container is called exactly "portainer"
      PortPath=$(docker inspect -f '{{ range .Mounts }}{{ if eq .Destination "/data" }}{{ .Source }}{{ end }}{{ end }}' portainer)
      if [[ $ContPath =~ ^/data.* ]] ; then
        ContPath=${ContPath/#\/data/$PortPath} 
      fi

## modified this on line 318 (322 after the addition above)
      if [[ $ContConfigFile = '/'* ]] ; then
        CompleteConfs=$(for conf in ${ContConfigFile//,/ } ; do $conf=${$conf/#\/data/$PortPath} ; printf -- "-f %s " "$conf"; done)
      else

If this is something I'll implement I'll probably clean it some more :) But for testing.
I'll do some more digging if its possible to recreate the container within portainers scope, let me know if you've got any ideas!

Edit:
I tried adding the --force-recreate flag with no luck. Was looking at Portainer web-hooks but that seems to be business only.

@mag37 mag37 added the help wanted Extra attention is needed label Jun 27, 2024
@nsnadell
Copy link

As a workaround, map your files from the docker host into the dockge container, then setup a cron on the host to run it using docker exec.

docker compose volume additions for dockage:

      - /usr/local/bin/dockcheck.sh:/usr/local/bin/dockcheck.sh
      - /usr/local/bin/notify.sh:/usr/local/bin/notify.sh
      - /usr/local/bin/regctl:/usr/local/bin/regctl

Cron job setup on host:

5 0 * * * docker exec -it dockge dockcheck.sh -aip

I didn't try it, but you could alternatively use something like https://github.com/mcuadros/ofelia to run the "cron job" within docker itself.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
help wanted Extra attention is needed portainer Issues related to containers made with portainer.
Projects
None yet
Development

No branches or pull requests

4 participants