- Keep users off of the servers. That is to say: do not give them interactive login shells, unless you absolutely must.
- Lock down the workstations, assume users will try to 'fix' things (heck, they might even be hostile, temp workers/etc).
- Use encryption wherever possible to keep plain text passwords, credit card numbers and other sensitive information from lying around.
- Regularly scan the network for open ports/installed software/etc that shouldn't be, compare it against previous results.
Remember: security is not a solution, it is a way of life.
Generally speaking workstations/servers are used by people that don't really care about the underlying technology, they just want to get their work done and retrieve their email in a timely fashion. There are however many users that will have the ability to modify their workstation, for better or worse (install packet sniffers, warez ftp sites, www servers, irc bots, etc). To add to this most users have physical access to their workstations, meaning you really have to lock them down if you want to do it right.
- Use BIOS passwords to lock users out of the BIOS (they should never be in here, also remember that older BIOS's have universal passwords.)
- Set the machine to boot from the appropriate harddrive only.
- Password the LILO prompt.
- Do not give the user root access, use sudo to tailor access to privileged commands as needed.
- Use firewalling so even if they do setup services they won’t be accessible to the world.
- Regularly scan the process table, open ports, installed software, and so on for change.
- Have a written security policy that users can understand, and enforce it.
- Remove all sharp objects (compilers, etc) unless needed from a system.
Remember: security in depth.
Properly setup, a Linux workstation is almost user proof (nothing is 100% secure), and generally a lot more stable then a comparable Wintel machine. With the added joy of remote administration (SSH/Telnet/NSH) you can keep your users happy and productive.
Servers are a different ball of wax together, and generally more important then workstations (one workstation dies, one user is affected, if the email/www/ftp/etc server dies your boss phones up in a bad mood). Unless there is a strong need, keep the number of users with interactive shells (bash, pine, lynx based, whatever) to a bare minimum. Segment services up (have a mail server, a www server, and so on) to minimize single point of failure. Generally speaking a properly setup server will run and not need much maintenance (I have one email server at a client location that has been in use for 2 years with about 10 hours of maintenance in total). Any upgrades should be planned carefully and executed on a test. Some important points to remember with servers:
- Restrict physical access to servers.
- Policy of least privilege, they can break less things this way.
- MAKE BACKUPS!
- Regularly check the servers for changes (ports, software, etc), automated tools are great for this.
- Software changes should be carefully planned/tested as they can have adverse affects (like kernel 2.2.x no longer uses ipfwadm, wouldn't that be embarrassing if you forgot to install ipchains).
Minimization of privileges means giving users (and administrators for that matter) the minimum amount of access required to do their job. Giving a user "root" access to their workstation would make sense if all users were Linux savvy, and trustworthy, but they generally aren't (on both counts). And even if they were it would be a bad idea as chances are they would install some software that is broken/insecure or other. If all a user access needs to do is shutdown/reboot the workstation then that is the amount of access they should be granted. You certainly wouldn't leave accounting files on a server with world readable permissions so that the accountants can view them, this concept extends across the network as a whole. Limiting access will also limit damage in the event of an account penetration (have you ever read the post-it notes people put on their monitors?).