data:image/s3,"s3://crabby-images/388ba/388ba27093856cd858270c68bb54120eab22038e" alt="Say what? What's my path again"
What’s my path again? Why did my command fail?
Ever get ‘command not found’ errors when calling a command on a machine? Many times, these errors are related to what is defined on said machine. So with monitoring tools like SCOM, ALA, Azure Automation, BMC Patrol, the ID used in monitoring rely on filepaths defined on the local server (holds true for Windows/UNIX). Because sometimes even ls, awk, dir, etc. if their various bin directory filepaths are NOT specified as a security hardening measure. The result of STIG/Security hardening is ALL scripts/commands require a fully qualified filepath.
Fully qualifying command paths holds true for Windows and UNIX, from generic OS commands, AND also application specific files (including an executable). Updates are required if you want to supply the short name command. Add the full filepath to PATH= statement. The alternative is to fully qualify in your SCOM mgmt. pack, so the command will run regardless of user, as long as the path is correct.
Check for specified shell
First, let’s check UNIX to see what shell is specified for user(s).
Second, log into your UNIX server, and check files type: ls -al .* | more
data:image/s3,"s3://crabby-images/69a56/69a567a5e60dada484b8cf0814329bc83949d604" alt="Use ls -al | more to see what PATH files are in the user directory"
Third, another option with less output
example: ls -al .*profile
data:image/s3,"s3://crabby-images/ad1e0/ad1e0833d1ceff216b41ad573a8c7e76b83eee92" alt="What's my path? Use command ls -al .*profile to find which profile(s) exist"
Fourth, Look for the shell defined for the user account
On my server, SCOM user is bash shell (but I do NOT have a .bash_profile, only a .profile (also note NO .ksh_profile) ) Knowing what profiles are configured for user account will help define what is inherited from the OS, (automatically included). Leverage when calling commands in your management packs for custom rules/monitors.
In conclusion, if executable is NOT in the filepath variable, you have two ways to resolve the issue:
- Create a .bash_profile
- Call bash/ksh shell in your script or command line: bash; <commandhere>
To check path:
UNIX $PATH vs. Windows $ENV:path
UNIX example – ‘echo $PATH’ from UNIX ssh session/logon
data:image/s3,"s3://crabby-images/24937/2493716939844b36368377bdf06eb58307d92949" alt="What's my path again? Use echo $PATH"
Windows PowerShell example
data:image/s3,"s3://crabby-images/c3c98/c3c98ba469932cbea468e822b856ae36b7e605ba" alt="What's my path? Windows PowerShell example of $PATH"
Here’s my .profile that sets up SCOM user (only /bin shown)
data:image/s3,"s3://crabby-images/12689/12689a8a1add8afbf81f884df3fb9139e9ff1c04" alt="What's my path? Use UNIX .profile to find PATH"
Here’s a UNIX .profile example:
https://www.unix.com/unix-for-dummies-questions-and-answers/21995-basic-profile-setup.html
Example
set PATH=$PATH:/usr/homes/myhome/sqlldr:/appl/oracle/product/9.2.0/bin