APLawrence.com -  Resources for Unix and Linux Systems, Bloggers and the self-employed
RSS Feeds RSS Feeds

(OLDER) <- More Stuff -> (NEWER) (NEWEST)
Printer Friendly Version
-> ./bashrc doesn't run automatically

./bashrc doesn't run automatically

Author: dhart
Date: Fri Apr 8 13:27:02 2005
Subject: ./bashrc doesn't run automatically

On a Red Hat system:
Linux Allied-2 2.4.21-4.ELsmp #1 SMP Fri Oct 3 17:52:56 EDT 2003 i686 i686 i386 GNU/Linux

my customer has played with webmin and did something to logins so that some users .bashrc doesn't get executed. Instead they find themselves at a $ prompt and if they type in ./.bashrc it runs fine.

-rwxr-xr-x 1 tom titan 168 Apr 7 15:27 .bashrc

I've compared ownership & permissions with users that work correctly, no joy.

Any Ideas?

If this page was useful to you, please help others find it:  


More Articles by

Click here to add your comments
- no registration needed!

Fri Apr 8 13:38:05 2005: 301   TonyLawrence

Well, for one, are you sure you understand what .bashrc is for?

Sounds to me like you are trying to use .bashrc for what .bash_profile should be used for. That's most definitely a path to disaster; see http://aplawrence.com/Detective/shbash.html

The use of bashrc can be overridden by "--rcfile file" on startup - don't know if that's what webmin did do you, but you should NOT be using bashrc to start other programs: use .bash_profile or .profile.

Fri Apr 8 13:43:25 2005: 302   dhart

looks like .bashrc doesn't run if .bash_profile doesn't exist. go figure.

Fri Apr 8 13:51:00 2005: 303   TonyLawrence

No, that's not really what's happening, but .bashrc is NOT for starting programs (unless it's something that you want to run everytime any other shell script runs).

Logging a user into an app should be done in .bash_profile, not .bashrc

From the man page:
       When  bash is invoked as an interactive login

shell, or as a non-inter- active shell with the
--login option, it first reads and executes com-
mands from the file /etc/profile, if that file
exists. After reading that file, it looks for
~/.bash_profile, ~/.bash_login, and ~/.profile,
in that order, and reads and executes commands
from the first one that exists and is readable.
The --noprofile option may be used when the
shell is started to inhibit this behavior.

When a login shell exits, bash reads and
executes commands from the file ~/.bash_logout,
if it exists.

When an interactive shell that is not a login shell
is started, bash reads and executes commands
from ~/.bashrc, if that file exists. This may be
inhibited by using the --norc option. The --rcfile
file option will force bash to read and
execute commands from file instead of ~/.bashrc.

So, yes, it won't run .bashrc without SOMETHING else to run, but again: it's purpose is NOT to start apps for users.. use .bash_profile for that.

Fri Apr 8 14:00:40 2005: 304   dhart

mmmm, yes, I see your point. The road to .bashrc is fraught with peril.

I had managed to avoid that trap by placing exec /usr/local/bigbadshellscript in .bashrc.

Curious, then, that .bashrc is executable at all.

Don't miss responses! Subscribe to Comments by RSS or by Email

Click here to add your comments

If you want a picture to show with your comment, go get a Gravatar

Kerio Samepage

Have you tried Searching this site?

Unix/Linux/Mac OS X support by phone, email or on-site: Support Rates

This is a Unix/Linux resource website. It contains technical articles about Unix, Linux and general computing related subjects, opinion, news, help files, how-to's, tutorials and more. We appreciate comments and article submissions.

Publishing your articles here

Jump to Comments

Many of the products and books I review are things I purchased for my own use. Some were given to me specifically for the purpose of reviewing them. I resell or can earn commissions from the sale of some of these items. Links within these pages may be affiliate links that pay me for referring you to them. That's mostly insignificant amounts of money; whenever it is not I have made my relationship plain. I also may own stock in companies mentioned here. If you have any question, please do feel free to contact me.

I am a Kerio reseller. Articles here related to Kerio products reflect my honest opinion, but I do have an obvious interest in selling those products also.

Specific links that take you to pages that allow you to purchase the item I reviewed are very likely to pay me a commission. Many of the books I review were given to me by the publishers specifically for the purpose of writing a review. These gifts and referral fees do not affect my opinions; I often give bad reviews anyway.

We use Google third-party advertising companies to serve ads when you visit our website. These companies may use information (not including your name, address, email address, or telephone number) about your visits to this and other websites in order to provide advertisements about goods and services of interest to you. If you would like more information about this practice and to know your choices about not having this information used by these companies, click here.


This post tagged:

       - Forum
       - Shell

My Troubleshooting E-Book will show you how to solve tough problems on Linux and Unix systems!

book graphic unix and linux troubleshooting guide

Buy Kerio from a dealer
who knows tech:
I sell and support

Kerio Connect Mail server, Control, Workspace and Operator licenses and subscription renewals

Click and enter your name and phone number to call me about Kerio® products right now (Flash required)