the agent knows which args to look for and to split them on =
by default the agent will hide the clearml secrets, AWS secrets etc.
If you're using docker, you can just add environment variables in the extra_docker_args
section
agent.extra_docker_arguments: ["-e", "MY_ENV_VAR=foo"]
add any other keys you want to hide to that list
will it pass variables to the training containers?
in the agent configuration, use:agent.hide_docker_command_env_vars.extra_keys: ["DB_PASSWORD"]
So maybe that's something I missed? 😞 - Can you send a more complete log so I'll try to find out where this is coming from?
we're using os.getenv in the script to get a value for these secrets
DilapidatedDucks58 can you provide an example?
I guess I could edit docker-compose.yaml
agent.hide_docker_command_env_vars.extra_keys: ["DB_PASSWORD=password"]
like this? or ["DB_PASSWORD", "password"]
it works, but it's not very helpful since everybody can see a secret in logs:
Executing: ['docker', 'run', '-t', '--gpus', '"device=0"', '-e', 'DB_PASSWORD=password']
Oh, wait, my bad 😆 - you need to tell the agent this env var should be hidden 🙂
this is probably what I need, thanks. I'll check if it works
DilapidatedDucks58 which ClearML Agent version are you using? I remember adding specific sanitation to the logs for these cases in the latest versions...
agent.hide_docker_command_env_vars.extra_keys: ["DB_PASSWORD"]
ah, I see, I still keep it in agent.extra_docker_arguments
you can actually just provide a very large list of all env var names you might use for secrets in agent.hide_docker_command_env_vars.extra_keys
, it doesn't matter if you actually usem the or not, the agent will just look for them and hide them when displaying
it only hides a pre-specified set of args (since most of the time you do want to see the value for non-secrets)
how to display and what to pass are two different things
obviously you should replace the passwords with something there 🙂
right now we can pass github secrets to the clearml agent training containers ( CLEARML_AGENT_GIT_PASS) to install private repos
we need a way to pass secrets to access our database with annotations