Passing Environment Variables to Sudo Command
Suppose you have a bash script that sets an environment variable, and then invokes something with sudo:
#!/bin/bash export MY_VAR=test sudo /do/something
You will find that the environment variable you set using
export is not available to the
When you run sudo, you are actually starting a new environment as the root user (or whatever user you have instructed sudo to run as), so any environment variables that exist in your current shell will not be passed. There are two ways to get around this.
Tell sudo to preserve environment
sudo has a handy argument
--preserve-env which will pass all your environment variables into the sudo environment.
Passing only the variables you need
A better approach is to just pass the environment variables you want to need to preserve, instead of passing everything. There are two ways to accomplish this, first you can supply a list of environment variable names to the
--preserve-env argument. For example:
sudo --preserve-env=HOME /usr/bin/env
Finally you can also set environment variables directly in the
sudo command, like this:
sudo ZEBRA=true /usr/bin/env
Note, we are using the
/usr/bin/env command above, which simply echo's all the environment variables.
Like this? Follow me ↯Tweet Follow @pfreitag
Passing Environment Variables to Sudo Command was first published on September 23, 2019.
If you like reading about bash, linux, sudo, or environment then you might also like:
- Creating a Symbolic Link with ln -s What Comes First?
- Bash Loop To Wait for Server to Start
- Counting IP Addresses in a Log File
- Recursively Counting files by Extension on Mac or Linux
- Difference between cd - vs cd ~-
- The 15 Essential UNIX commands
- Linux and OS X Shell Commands
- Counting files
Want Security Advisories via Email?
Advisory Week is a new weekly email containing security advisories published by major software vendors (Adobe, Apple, Microsoft, etc).
Indicates to the security policy that the user wishes to add the comma-separated list of environment variables to those preserved from the user's environment.