What are the different ways that a message can be displayed to a bash shell after a user logs in?
Traditional unix systems display /etc/motd
after the user is successfully authenticated and before the user's shell is invoked. On modern systems, this is done by the pam_motd
PAM module, which may be configured in /etc/pam.conf
or /etc/pam.d/*
to display a different file.
The ssh server itself may be configured to print /etc/motd
if the PrintMotd
option is not turned off in /etc/sshd_config
. It may also print the time of the previous login if PrintLastLog
is not turned off.
Another traditional message might tell you whether that You have new mail
or You have mail
. On systems with PAM, this is done by the pam_mail
module. Some shells might print a message about available mail.
After the user's shell is launched, the user's startup files may print additional messages. For an interactive login, if the user's login shell is a Bourne-style shell, look in /etc/profile
, ~/.profile
, plus ~/.bash_profile
and ~/.bash_login
for bash. For an interactive login to zsh, look in /etc/zprofile
, /etc/zlogin
, /etc/zshrc
, ~/.zprofile
, ~/.zlogin
and ~/.zshrc
. For an interactive login to csh, look in /etc/csh.login
and ~/.login
.
If the user's login shell is bash and this is a non-interactive login, then bash executes ~/.bashrc
(which is really odd, since ~/.bashrc
is executed for interactive shells only if the shell is not a login shell). This can be a source for trouble; I recommend including the following snippet at the top of ~/.bashrc
to bail out if the shell is not interactive:
if [[ $- != *i* ]]; then return; fi
There are a few:
/etc/motd
/etc/issue
/etc/profile - Could echo the message
/etc/profile.d/* - Would be called from /etc/profile
Additionally
/etc/bash_bashrc
/etc/.bashrc
/etc/bashrc
$HOME/.profile
$HOME/.bashrc
You may also have to go through every program that is being called from those scripts because something like fortune
could be storing the quips it's displaying in /usr/share
. To isolate it you can do:
. /etc/profile
. /etc/bash.bashrc
. $HOME/.profile
. $HOME/.bashrc
On Ubuntu there is also file:
/etc/motd.tail
Newer systems store the MOTD components in /etc/update-motd.d
so that various macros can be run to customize the motd to have update information, system alerts, etc show on login.
Add your customization as another file with priority from 00
to 99
99-footer
usually loads /etc/motd.tail
if tacking it onto the end is sufficient and you don't want to use any of the macro items.