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

Badger storage does not start in docker #1543

Closed
pavolloffay opened this issue May 16, 2019 · 17 comments · Fixed by jaegertracing/documentation#255
Closed

Badger storage does not start in docker #1543

pavolloffay opened this issue May 16, 2019 · 17 comments · Fixed by jaegertracing/documentation#255
Labels

Comments

@pavolloffay
Copy link
Member

docker run \                                                                                      1:03 
  -e SPAN_STORAGE_TYPE=badger \
  -e BADGER_EPHEMERAL=false \
  jaegertracing/all-in-one:1.12.0
Unable to find image 'jaegertracing/all-in-one:1.12.0' locally
1.12.0: Pulling from jaegertracing/all-in-one
0ce0e4414ed8: Pull complete 
d7ea8e4b436e: Pull complete 
Digest: sha256:51b901b653f4a4ca5dd50be9133c08dacf2d3eb092e507c213e7955a0e132297
Status: Downloaded newer image for jaegertracing/all-in-one:1.12.0
{"level":"info","ts":1558004644.2606764,"caller":"flags/service.go:113","msg":"Mounting metrics handler on admin server","route":"/metrics"}
{"level":"info","ts":1558004644.261235,"caller":"flags/admin.go:108","msg":"Mounting health check on admin server","route":"/"}
{"level":"info","ts":1558004644.2613149,"caller":"flags/admin.go:114","msg":"Starting admin HTTP server","http-port":14269}
{"level":"info","ts":1558004644.261333,"caller":"flags/admin.go:100","msg":"Admin server started","http-port":14269,"health-status":"unavailable"}
{"level":"fatal","ts":1558004644.4784822,"caller":"all-in-one/main.go:102","msg":"Failed to init storage factory","error":"Error Creating Dir: \"/go/bin/data/keys\": mkdir /go/bin/data/keys: no such file or directory","errorVerbose":"mkdir /go/bin/data/keys: no such file or directory\nError Creating Dir: \"/go/bin/data/keys\"\ngithub.com/jaegertracing/jaeger/vendor/github.com/dgraph-io/badger/y.Wrapf\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/dgraph-io/badger/y/error.go:82\ngithub.com/jaegertracing/jaeger/vendor/github.com/dgraph-io/badger.Open\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/dgraph-io/badger/db.go:191\ngithub.com/jaegertracing/jaeger/plugin/storage/badger.(*Factory).Initialize\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/plugin/storage/badger/factory.go:104\ngithub.com/jaegertracing/jaeger/plugin/storage.(*Factory).Initialize\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/plugin/storage/factory.go:107\nmain.main.func1\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/cmd/all-in-one/main.go:101\ngithub.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra.(*Command).execute\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra/command.go:762\ngithub.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra.(*Command).ExecuteC\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra/command.go:852\ngithub.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra.(*Command).Execute\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra/command.go:800\nmain.main\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/cmd/all-in-one/main.go:167\nruntime.main\n\t/home/travis/.gimme/versions/go1.12.1.linux.amd64/src/runtime/proc.go:200\nruntime.goexit\n\t/home/travis/.gimme/versions/go1.12.1.linux.amd64/src/runtime/asm_amd64.s:1337","stacktrace":"main.main.func1\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/cmd/all-in-one/main.go:102\ngithub.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra.(*Command).execute\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra/command.go:762\ngithub.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra.(*Command).ExecuteC\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra/command.go:852\ngithub.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra.(*Command).Execute\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra/command.go:800\nmain.main\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/cmd/all-in-one/main.go:167\nruntime.main\n\t/home/travis/.gimme/versions/go1.12.1.linux.amd64/src/runtime/proc.go:200"}

@yurishkuro
Copy link
Member

Where does it get /go/bin/data from? I thought it defaults to temp.

@pavolloffay
Copy link
Member Author

I haven't looked into it. There is probably a bug.

@burmanm
Copy link
Contributor

burmanm commented May 21, 2019

You set the ephemeral to false, thus it doesn't write to /tmp by default, but to:

defaultDataDir := getCurrentExecutableDir() 
defaultValueDir           = "/data/values"
defaultKeysDir            = "/data/keys"
ValueDirectory:      defaultDataDir + defaultValueDir,
KeyDirectory:        defaultDataDir + defaultKeysDir,

Keeping BADGER_EPHEMERAL=true would write to /tmp

@jpkrohling
Copy link
Contributor

@burmanm, the Docker run command then should specify a volume to be mounted at /go/bin/data ?

@pavolloffay
Copy link
Member Author

In the case of -e BADGER_EPHEMERAL=false yes.

It fails even in ephemeral mode:
docker run -e SPAN_STORAGE_TYPE=badger jaegertracing/all-in-one:1.12.0

{"level":"info","ts":1558711273.3924935,"caller":"flags/service.go:113","msg":"Mounting metrics handler on admin server","route":"/metrics"}
{"level":"info","ts":1558711273.39308,"caller":"flags/admin.go:108","msg":"Mounting health check on admin server","route":"/"}
{"level":"info","ts":1558711273.393156,"caller":"flags/admin.go:114","msg":"Starting admin HTTP server","http-port":14269}
{"level":"info","ts":1558711273.3931766,"caller":"flags/admin.go:100","msg":"Admin server started","http-port":14269,"health-status":"unavailable"}
{"level":"fatal","ts":1558711273.4786692,"caller":"all-in-one/main.go:102","msg":"Failed to init storage factory","error":"Error Creating Dir: \"\": mkdir : no such file or directory","errorVerbose":"mkdir : no such file or directory\nError Creating Dir: \"\"\ngithub.com/jaegertracing/jaeger/vendor/github.com/dgraph-io/badger/y.Wrapf\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/dgraph-io/badger/y/error.go:82\ngithub.com/jaegertracing/jaeger/vendor/github.com/dgraph-io/badger.Open\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/dgraph-io/badger/db.go:191\ngithub.com/jaegertracing/jaeger/plugin/storage/badger.(*Factory).Initialize\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/plugin/storage/badger/factory.go:104\ngithub.com/jaegertracing/jaeger/plugin/storage.(*Factory).Initialize\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/plugin/storage/factory.go:107\nmain.main.func1\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/cmd/all-in-one/main.go:101\ngithub.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra.(*Command).execute\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra/command.go:762\ngithub.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra.(*Command).ExecuteC\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra/command.go:852\ngithub.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra.(*Command).Execute\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra/command.go:800\nmain.main\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/cmd/all-in-one/main.go:167\nruntime.main\n\t/home/travis/.gimme/versions/go1.12.1.linux.amd64/src/runtime/proc.go:200\nruntime.goexit\n\t/home/travis/.gimme/versions/go1.12.1.linux.amd64/src/runtime/asm_amd64.s:1337","stacktrace":"main.main.func1\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/cmd/all-in-one/main.go:102\ngithub.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra.(*Command).execute\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra/command.go:762\ngithub.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra.(*Command).ExecuteC\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra/command.go:852\ngithub.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra.(*Command).Execute\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/vendor/github.com/spf13/cobra/command.go:800\nmain.main\n\t/home/travis/gopath/src/github.com/jaegertracing/jaeger/cmd/all-in-one/main.go:167\nruntime.main\n\t/home/travis/.gimme/versions/go1.12.1.linux.amd64/src/runtime/proc.go:200"}

@jpkrohling
Copy link
Contributor

Couldn't get it to work either:

$ docker run \
  -e SPAN_STORAGE_TYPE=badger \
  -v ${HOME}/.jaeger/data:/go/bin/data \
  jaegertracing/all-in-one:1.12

It yields:

Failed to init storage factory","error":"Error Creating Dir: \"\": mkdir : no such file or directory

@srispl
Copy link

srispl commented May 24, 2019

I got it working with below command

docker run
-e SPAN_STORAGE_TYPE=badger
-e BADGER_EPHEMERAL=false
-e BADGER_DIRECTORY_VALUE=<YOUR_LOCAL_DIR>/data
-e BADGER_DIRECTORY_KEY=<YOUR_LOCAL_DIR>/key
-v <YOUR_LOCAL_DIR>
jaegertracing/all-in-one:1.12

Thanks @yurishkuro for pointers.

@bharadwr
Copy link

bharadwr commented May 24, 2019

I got it working with below command

docker run
-e SPAN_STORAGE_TYPE=badger
-e BADGER_EPHEMERAL=false
-e BADGER_DIRECTORY_VALUE=<YOUR_LOCAL_DIR>/data
-e BADGER_DIRECTORY_KEY=<YOUR_LOCAL_DIR>/key
-v <YOUR_LOCAL_DIR>
jaegertracing/all-in-one:1.12

Thanks @yurishkuro for pointers.

Was YOUR_LOCAL_DIR your GOPATH, or just any local directory that you have mounted?

@burmanm
Copy link
Contributor

burmanm commented May 26, 2019

Despite @srispl's success in getting it to work, I think there's something that could improve the usability. Docker supports mounting with --tmpfs option that would mount the host's tmpfs to the docker container. This is something badger backend should definitely use when ephemeral is true. I'll investigate tomorrow if there's a sane way to improve support when running in the container (as I did the development outside the container).

@pavolloffay
Copy link
Member Author

Let's keep this open and make it work when ephemeral=true without mounting volumes.

@pavolloffay pavolloffay reopened this May 27, 2019
@burmanm
Copy link
Contributor

burmanm commented May 27, 2019

I think it works just fine if you configure your Docker correctly:

docker run -e SPAN_STORAGE_TYPE=badger -e BADGER_EPHEMERAL=true --tmpfs /tmp jaegertracing/all-in-one:1.12

{"level":"info","ts":1558955155.6610308,"caller":"badger/factory.go:119","msg":"Badger storage configuration","configuration":{"Dir":"/tmp/badger023976390","ValueDir":"/tmp/badger023976390","SyncWrites":false,"TableLoadingMode":1,"ValueLogLoadingMode":2,"NumVersionsToKeep":1,"MaxTableSize":67108864,"LevelSizeMultiplier":10,"MaxLevels":7,"ValueThreshold":32,"NumMemtables":5,"NumLevelZeroTables":5,"NumLevelZeroTablesStall":10,"LevelOneSize":268435456,"ValueLogFileSize":1073741824,"ValueLogMaxEntries":1000000,"NumCompactors":3,"DoNotCompact":false,"ReadOnly":false,"Truncate":false}}

Docker when ran with defaults is just picky and forbids using tmpfs.

@pavolloffay
Copy link
Member Author

I am wondering if the pre-creation if the temp dir would also solve the problem as it fails on "mkdir : no such file or directory

@yurishkuro
Copy link
Member

pavolloffay reopened this 10 hours ago

I didn't realize GH now closes issues when a PR is merged in another repo.

@srispl
Copy link

srispl commented May 28, 2019

I got it working with below command
docker run
-e SPAN_STORAGE_TYPE=badger
-e BADGER_EPHEMERAL=false
-e BADGER_DIRECTORY_VALUE=<YOUR_LOCAL_DIR>/data
-e BADGER_DIRECTORY_KEY=<YOUR_LOCAL_DIR>/key
-v <YOUR_LOCAL_DIR>
jaegertracing/all-in-one:1.12
Thanks @yurishkuro for pointers.

Was YOUR_LOCAL_DIR your GOPATH, or just any local directory that you have mounted?

@bharadwr It can be any path in your Local/VM. I have tested in my local by pointing to some X location and also mounted a volume on VM and tested.

@srispl
Copy link

srispl commented May 28, 2019

I am wondering if the pre-creation if the temp dir would also solve the problem as it fails on "mkdir : no such file or directory

@pavolloffay I did not created any directories except pointing to valid location when mounting a location.

@pavolloffay
Copy link
Member Author

Yeah, I would like to make it work without mounting in ephemeral mode.

burmanm added a commit to burmanm/jaeger that referenced this issue May 29, 2019
burmanm added a commit to burmanm/jaeger that referenced this issue May 29, 2019
burmanm added a commit to burmanm/jaeger that referenced this issue May 29, 2019
Signed-off-by: Michael Burman <yak@iki.fi>
@aitoroses
Copy link

I was able to manage it by passing the user and group ids to the container this way:

jaeger:
    image: jaegertracing/all-in-one:latest
    container_name: jaeger
    restart: unless-stopped
    user: "${UID}:${GID}"
    environment:
      - SPAN_STORAGE_TYPE=badger
      - BADGER_EPHEMERAL=false
      - BADGER_DIRECTORY_VALUE=/tmp/jaeger/data
      - BADGER_DIRECTORY_KEY=/tmp/jaeger/key
    volumes:
      - ./jaeger_data:/tmp/jaeger
    ports:
      - 6831:6831/udp
      - 6832:6832/udp
      - 16686:16686
      - 14268:14268
      - 14269:14269

I hope it helps!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging a pull request may close this issue.

7 participants