105.1 Customize and use the shell environment
Weight: 4
Description: Candidates should be able to customize shell environments to meet users’ needs. Candidates should be able to modify global and user profiles.
Key Knowledge Areas:
Set environment variables (e.g. PATH) at login or when spawning a new shell
Write Bash functions for frequently used sequences of commands
Maintain skeleton directories for new user accounts
Set command search path with the proper directory
The following is a partial list of the used files, terms and utilities:
source
/etc/bash.bashrc
/etc/profile
env
export
set
unset
~/.bash_profile
~/.bash_login
~/.profile
~/.bashrc
~/.bash_logout
function
alias
lists
We have already talk about environment variables in section "103-1". In this section we want to talk about user profiles and system wide profile , and how they interact when user log on.
Login shell and Non login shell
The shell program, for example Bash, uses a collection of startup scripts to create an environment. Each script has a specific use and affects the login environment differently. Every subsequent script executed can override the values assigned by previous scripts.
Startup is configured differently for Login shells and Non login shells.
Login shells : If you open a shell or terminal (or switch to one), and it asks you to log in (Username? Password?) before it gives you a prompt, it's a login shell.
Non login shells : If it doesn't ask you log in (like gnome-terminal), and lets you use it straight away, it's a non-login shell (GUI)
Adding global configuration for login shell
/etc/profile
/etc/profile contains Linux system wide environment and startup programs. It is used by all users with bash, ksh, sh shell. It only runs for login shell.
/etc/profile.d
if you need to customize the login environment for all users on your system, you can use /etc/profile, but as the distribution files in /etc, such as /etc/profile, can be modified by system updates, so it is better not to edit them directly. Rather, create additional files in /etc/profile.d.
adding global configs for non-login (interactive) shell
/etc/bash.bashrc & /etc/bashrc
You can use /etc/bash.bashrc ( or /etc/bashrc )[based on your distro] for adding global configs and global aliases.
user specfic configs
/home/user/.bash_profile & /home/user/.bashrc
~/.bash_profile
and ~/.bashrc
are shell scripts that contain shell commands. These files are executed in a user's context when a new shell opens or when a user logs in so that their environment is set correctly. As we mentioned~/.bash_profile
is executed for login shells and ~/.bashrc
is executed for interactive non-login shells.
This means that when a user logs in (via username and password) to the console (either locally or remotely via something like SSH), the ~/.bash_profile
script is executed before the initial command prompt is returned to the user. After that, every time a new shell is opened, the ~/.bashrc
script is executed.
Most of the time PATH and env vars go into the in ~/.bash_profile and aliases go into the ~/.bashrc.
Aliases
In bash, you can define aliases for commands. You use aliases to provide an alternative name for a command, to provide default parameters for the command, or sometimes to construct a new or more-complex command.
You set aliases or list aliases with the alias
command and remove them with the unalias
command.
in order to make aliases permanent for user they are defined in /home/user/.bashrc
:
Another common use of aliases is for the root user. The
cp
,rm
, andmv
commands are usually aliased to include the-i
parameter, to help prevent accidental destruction of files.
/etc/skel
You might be wondering how files like ~/.bash_profile, ~/.bashrc, or ~/.bash_logout got created in your home directory. These are skeleton files that are copied from /etc/skel.
.bash_logout
The file .bash_logout is read and executed every time a login shell exits. It clears the screen whenever you log out. Without .bash_logout whatever you were working on could be visible for the next user!
. and source
If a script runs in a child shell, any variables it might export are lost when it returns to the parent.
So if .profile runs the ~/.bashrc script, why aren’t the variables and functions that are exported from ~/.bashrc lost? The answer is that you run the script in the current environment by using the source
(or .
) command.
Shell functions
Aliases are useful, but what happens if you want to handle parameters? Aliases expand only the first word, and everything else on the command line is appended to the expansion. If you want to run a command with some parameters and then process the output somehow, you are out of luck with an alias. In this case, you need a shell function.
$1
returns the first argument
Shell functions have a couple of advantages over aliases:
You can handle parameters.
You can use programming constructs, such as testing and looping, to enhance your processing.
We can use unset
command inorder to unset our defined function.
lists
Shell supports a different type of variable called an array variable. This can hold multiple values at the same time. Arrays provide a method of grouping a set of variables. Instead of creating a new name for each variable that is required, you can use a single array variable that stores all the other variables.
Another example:
Keep your eyes on syntax!
.
.
.
With the special thanks of shawn powers.
.
Last updated