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

dockerd.json not updated #3

Closed
hirenshah opened this issue Jun 11, 2020 · 26 comments · Fixed by #7
Closed

dockerd.json not updated #3

hirenshah opened this issue Jun 11, 2020 · 26 comments · Fixed by #7
Assignees
Labels
bug Something isn't working

Comments

@hirenshah
Copy link

Just did the full update process and found that my containers wouldn't start due to the "db" log driver not being found.

After a little digging, I noticed that the:
/var/packages/Docker/etc/dockerd.json

Still contains:

{
   "data-root" : "/var/packages/Docker/target/docker",
   "log-driver" : "db",
   "registry-mirrors" : [],
   "storage-driver" : "aufs"
}

The last time this file was changed was a month ago... guess that is when I installed a DSM update.

@markdumay markdumay added the bug Something isn't working label Jun 11, 2020
@markdumay markdumay self-assigned this Jun 11, 2020
@markdumay
Copy link
Owner

Thanks for catching this issue, it confirms my suspicion for issue #1. The log driver should be "json-file" instead of "db", as the db driver is specific to Synology's Docker package. It looks like "execute_update_log()" in the script does not work as expected, I'll look into it.

@hirenshah
Copy link
Author

hirenshah commented Jun 11, 2020

@markdumay

Line 394:

if [ ! -f "$SYNO_DOCKER_JSON" ] || grep "json-file" "$SYNO_DOCKER_JSON" -q ; then

Is the second half right? If it found a match, it would return 0, which is true. The return code you are looking for should be anything other than 0 right?

if [ ! -f "$SYNO_DOCKER_JSON" ] || [ ! grep "json-file" "$SYNO_DOCKER_JSON" -q] ; then

@markdumay
Copy link
Owner

You're right, the second half is incorrect. I updated the function as follows:

# Configure log driver
execute_update_log() {
    print_status "Configuring log driver"
    if [ "$STAGE" == 'false' ] ; then
        LOG_DRIVER=$(grep "json-file" "$SYNO_DOCKER_JSON")
        if [ ! -f "$SYNO_DOCKER_JSON" ] || [ -z "$LOG_DRIVER" ] ; then
            mkdir -p "$SYNO_DOCKER_JSON_PATH"
            printf "$SYNO_DOCKER_JSON_CONFIG" > "$SYNO_DOCKER_JSON"
        fi
    else
        echo "Skipping configuration in STAGE mode"
    fi
}

A new branch 'logdriver' is available, care to try it?

@hirenshah
Copy link
Author

Sure :)

I'm just restoring everything and then will attempt the update again :)

@hirenshah
Copy link
Author

hirenshah commented Jun 11, 2020

/Edit: Ignore Me :p

@markdumay
Copy link
Owner

OK, I did a rerun on my NAS too, and it looks like $SYNO_DOCKER_JSON_CONFIG is not parsed correctly yet... I'll update the variable and will push it to the branch

@hirenshah
Copy link
Author

So, I couldn't restore the backup... I got this:

root@DiskStation:/volume1/docker/synology-docker# sudo ./syno_docker_update.sh -b /volume1/docker/synology-docker/docker_backup_200611115000.tgz restore
Update Docker Engine and Docker Compose on Synology to target version

Current DSM version: 6.2.3
Current Docker version: 19.03.11
Current Docker Compose version: 1.26.0
Step 1 from 5: Stopping Docker service
pkgctl-Docker stoped.
Step 2 from 5: Extracting Docker backup (/volume1/docker/synology-docker//volume1/docker/synology-docker/docker_backup_200611115000.tgz)
bin/
bin/containerd
bin/auplink
bin/runc
bin/containerd-shim
bin/ctr
bin/dockerd
bin/docker-init
bin/docker
bin/docker-compose
bin/docker-proxy
dockerd.json
ERROR: Docker compose binary could not be extracted from archive

So I extracted it myself and restored the files manually.

Just noticed the "Step 2 from 5" path... guessing the two variables shouldn't be put together?

@hirenshah
Copy link
Author

OK, I did a rerun on my NAS too, and it looks like $SYNO_DOCKER_JSON_CONFIG is not parsed correctly yet... I'll update the variable and will push it to the branch

Ahh yes, I just noticed that :)

At least it is a step in the right direction :)

@markdumay
Copy link
Owner

ok, $SYNO_DOCKER_JSON_CONFIG is working on my NAS now. I had to manually delete /var/packages/Docker/etc/dockerd.json first, because the script detected the json-file driver, whilst the file itself had an incorrect syntax. :-/

@markdumay
Copy link
Owner

markdumay commented Jun 11, 2020

/volume1/docker/synology-docker//volume1/docker/synology-docker/docker_backup_200611115000.tgz looks like another bug indeed, the -b flag should in theory override the working directory. I'll create a new issue.

@hirenshah
Copy link
Author

Weird... the restore process worked perfectly this time round. I ran the same command as the one I mentioned here:
#3 (comment)

@markdumay
Copy link
Owner

That's weird indeed. I checked the code and noticed an issue here:

execute_extract_backup() {
    print_status "Extracting Docker backup ($WORKING_DIR/$DOCKER_BACKUP_FILENAME)"
    BASEPATH=$(dirname "$DOCKER_BACKUP_FILENAME")
    FILENAME=$(basename "$DOCKER_BACKUP_FILENAME") 
    cd "$BASEPATH"
    tar -zxvf "$FILENAME"

    [ ... ]
}

Print_status incorrectly prepends $WORKING_DIR/ as this is already present in $DOCKER_BACKUP_FILENAME. However, that should not have impact on the tar command as it uses $FILENAME instead.

@markdumay markdumay mentioned this issue Jun 12, 2020
@maxbec
Copy link

maxbec commented Aug 24, 2020

Hey guys,
i still get the error on my influxdb docker file when i try to start it after the update:
Create container InfluxDB failed: {"message":"logger: no log driver named 'db' is registered"}.

@markdumay
Copy link
Owner

markdumay commented Aug 24, 2020 via email

@markdumay markdumay reopened this Aug 24, 2020
@maxbec
Copy link

maxbec commented Aug 25, 2020

Hi @markdumay ,

  • Dockerfile command:
    $ docker run -p 8086:8086 \ -v $PWD:/var/lib/influxdb \ influxdb
  • Syno_docker_update command:
    sudo ./syno_docker_update.sh update (Console output was uneventful)
  • Docker is in /var/packages/Docker

@markdumay
Copy link
Owner

markdumay commented Aug 25, 2020 via email

@maxbec
Copy link

maxbec commented Aug 27, 2020

There were a lot of messages. But no fail messages. And i didn't save them, sorry :/

@markdumay
Copy link
Owner

markdumay commented Aug 27, 2020 via email

@rui-nar
Copy link

rui-nar commented Nov 14, 2020

Hey there
I'm having the same issue.
Output :

Update Docker Engine and Docker Compose on Synology to target version

Current DSM version: 6.2.3
Current Docker version: 18.09.8
Current Docker Compose version: 1.24.0
Target Docker version: 19.03.13
Target Docker Compose version: 1.27.4

WARNING! This will replace:
  - Docker Engine
  - Docker Compose
  - Docker daemon log driver

Are you sure you want to continue? [y/N] y
Step 1 from 9: Downloading target Docker binary (https://download.docker.com/linux/static/stable/x86_64/docker-19.03.13.tgz)
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100 59.3M  100 59.3M    0     0  1014k      0  0:00:59  0:00:59 --:--:-- 1066k
Step 2 from 9: Downloading target Docker Compose binary (https://github.com/docker/compose/releases/download/1.27.4/docker-compose-Linux-x86_64)
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   651  100   651    0     0   2883      0 --:--:-- --:--:-- --:--:--  2906
100 11.6M  100 11.6M    0     0   916k      0  0:00:13  0:00:13 --:--:-- 1019k
Step 3 from 9: Stopping Docker service
pkgctl-Docker stoped.
Step 4 from 9: Backing up current Docker binaries (/volume1/homes/Rui/synology-docker/docker_backup_20201114_205835.tgz)
bin/
bin/containerd-shim
bin/ctr
bin/runc
bin/docker-compose
bin/docker-init
bin/docker-proxy
bin/auplink
bin/containerd
bin/dockerd
bin/docker
dockerd.json
Step 5 from 9: Extracting target Docker binary (/tmp/docker_update/docker-19.03.13.tgz)
docker/
docker/ctr
docker/runc
docker/containerd-shim
docker/docker-init
docker/docker-proxy
docker/docker
docker/dockerd
docker/containerd
Step 6 from 9: Installing binaries
Step 7 from 9: Configuring log driver
Step 8 from 9: Starting Docker service

pkgctl-Docker started.
Step 9 from 9: Cleaning the temp folder
Done.

then I try to run my portainer container with:
docker start portainer
and I get:
Error response from daemon: failed to initialize logging driver: failed to get logging factory: logger: no log driver named 'db' is registered: error looking up logging plugin db: plugin "db" not found Error: failed to start containers: portainer

Anything else I should look for ?

Rui

@rui-nar
Copy link

rui-nar commented Nov 14, 2020

and maybe this helps as well:

Rui@DiskStation:~/synology-docker$ more /var/packages/Docker/etc/dockerd.json 
{
    "data-root" : "/var/packages/Docker/target/docker",
    "log-driver" : "json-file",
    "registry-mirrors" : [],
    "group": "administrators"
}`

@CardcaptorRLH85
Copy link

As a note, after clearing my issue in #48, I also ran into this problem. Here's my post-update dockerd.json.

{
    "data-root" : "/var/packages/Docker/target/docker",
    "log-driver" : "json-file",
    "registry-mirrors" : [],
    "group": "administrators"
}

@ypkdani00
Copy link

ypkdani00 commented Mar 6, 2021

Hello,

same problem as @rui-nar, i have ths error message:

Create container eclipse-mosquitto1 failed: {"message":"error looking up logging plugin db: plugin "db" not found"}.

i have this dockerd.json file:
{ "registry-mirrors": [], "data-root": "/var/packages/Docker/target/docker",\ "log-driver": "json-file",\ "group" : "administrator"\ }

someone have solve this problem? The hard drive on Docker is working is an ext4

@qm3ster
Copy link

qm3ster commented Nov 28, 2021

  1. What's wrong with db driver? What are the properties of it?
  2. Why do we then prefer json-file and not local?

@markdumay
Copy link
Owner

It seems db is a proprietary driver from Synology. It is not available with a default Docker installation. I have not tried local instead of json-file myself - care to try it and share your experience?

@qm3ster
Copy link

qm3ster commented Nov 29, 2021

I'll probably be trying it now. Allegedly it's the same thing (with log rotation support and stuff) as json-file but with less overhead than a json encoding.
The reason I am thinking of deviating from db is it seems to completely give up after a certain amount of spam. A running docker logs -f just stops yielding lines, the UI keeps only displaying logs up until that moment, and new docker --log-level=debug logs <container> just sit there, regardless of any --since or -f, not yielding any preexisting or new lines.
(My spammy container is eclipse/mosquitto with log_type all, but I do need those logs. Maybe I'll move its logs to tmpfs idk. Ideally, I need to process those logs and not store them.)

@qm3ster
Copy link

qm3ster commented Nov 29, 2021

It seems that local works fine.
"No logs available." in the UI, but copes with the spam.
Fun side effect: in docker logs -t the db driver gave timestamp prefixes like
2021-11-28T20:32:08.859717886Z (RFC3339Nano Z, two spaces) while local gives
2021-11-29T16:22:01.465997093+03:00 (RFC3339Nano Local, one space)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

Successfully merging a pull request may close this issue.

7 participants