My First Server

My First Server | Real HD-Audio

Server security doesn’t need to be complicated. My security philosophy is simple: adopt principles that will protect you from the most frequent attack vectors, while keeping administration efficient enough that you won’t develop “security cruft”. If you use your first 5 minutes on a server wisely, I believe you can do that.

Any seasoned sysadmin can tell you that as you grow and add more servers & developers, user administration inevitably becomes a burden. Maintaining conventional access grants in the environment of a fast growing startup is an uphill battle - you’re bound to end up with stale passwords, abandoned intern accounts, and a myriad of “I have sudo access to Server A, but not Server B” issues. There are account sync tools to help mitigate this pain, but IMHO the incremental benefit isn’t worth the time nor the security downsides. Simplicity is the heart of good security.

Our servers are configured with two accounts: root and deploy. The deploy user has sudo access via an arbitrarily long password and is the account that developers log into. Developers log in with their public keys, not passwords, so administration is as simple as keeping the authorized_keys file up-to-date across servers. Root login over ssh is disabled, and the deploy user can only log in from our office IP block.

The downside to our approach is that if an authorized_keys file gets clobbered or mis-permissioned, I need to log into the remote terminal to fix it (Linode offers something called Lish, which runs in the browser). If you take appropriate caution, you shouldn’t need to do this.

Note: I’m not advocating this as the most secure approach - just that it balances security and management simplicity for our small team. From my experience, most security breaches are caused either by insufficient security procedures or sufficient procedures poorly maintained.

Let’s Get Started

Our box is freshly hatched, virgin pixels at the prompt. I favor Ubuntu; if you use another version of linux, your commands may vary. Five minutes to go:


Change the root password to something long and complex. You won’t need to remember it, just store it somewhere secure - this password will only be needed if you lose the ability to log in over ssh or lose your sudo password.

apt-get update apt-get upgrade

The above gets us started on the right foot.

Install Fail2ban

apt-get install fail2ban

Now, let’s set up your login user. Feel free to name the user something besides ‘deploy’, it’s just a convention we use:

useradd deploy mkdir /home/deploy mkdir /home/deploy/.ssh chmod 700 /home/deploy/.ssh

Require public key authentication

vim /home/deploy/.ssh/authorized_keys

Add the contents of the on your local machine and any other public keys that you want to have access to this server to this file.

chmod 400 /home/deploy/.ssh/authorized_keys chown deploy:deploy /home/deploy -R

Test The New User & Enable Sudo

Now test your new account logging into your new server with the deploy user (keep the terminal window with the root login open). If you’re successful, switch back to the terminal with the root user active and set a sudo password for your login user:

passwd deploy

Set a complex password - you can either store it somewhere secure or make it something memorable to the team. This is the password you’ll use to sudo.


Comment all existing user/group grant lines and add:

root ALL=(ALL) ALL deploy ALL=(ALL) ALL

The above grants sudo access to the deploy user when they enter the proper password.

Lock Down SSH

Configure ssh to prevent password & root logins and lock ssh to particular IPs:

vim /etc/ssh/sshd_config

Add these lines to the file, inserting the ip address from where you will be connecting:

PermitRootLogin no PasswordAuthentication no AllowUsers deploy@(your-ip) deploy@(another-ip-if-any)

Now restart ssh:

service ssh restart

Set Up A Firewall

No secure server is complete without a firewall. Ubuntu provides ufw, which makes firewall management easy. Run:

ufw allow from {your-ip} to any port 22 ufw allow 80 ufw allow 443 ufw enable

This sets up a basic firewall and configures the server to accept traffic over port 80 and 443. You may wish to add more ports depending on what your server is going to do.

Enable Automatic Security Updates

I’ve gotten into the apt-get update/upgrade habit over the years, but with a dozen servers, I found that servers I logged into less frequently weren’t staying as fresh. Especially with load-balanced machines, it’s important that they all stay up to date. Automated security updates scare me somewhat, but not as badly as unpatched security holes.

apt-get install unattended-upgrades vim /etc/apt/apt.conf.d/10periodic

Update the file to look like this:

APT::Periodic::Update-Package-Lists "1"; APT::Periodic::Download-Upgradeable-Packages "1"; APT::Periodic::AutocleanInterval "7"; APT::Periodic::Unattended-Upgrade "1";

One more config file to edit:

vim /etc/apt/apt.conf.d/50unattended-upgrades

Update the file to look like below. You should probably keep updates disabled and stick with security updates only:

Unattended-Upgrade::Allowed-Origins { "Ubuntu lucid-security"; // "Ubuntu lucid-updates"; };

Install Logwatch To Keep An Eye On Things

Logwatch is a daemon that monitors your logs and emails them to you. This is useful for tracking and detecting intrusion. If someone were to access your server, the logs that are emailed to you will be helpful in determining what happened and when - as the logs on your server might have been compromised.

apt-get install logwatch vim /etc/cron.daily/00logwatch

add this line:

All Done!

I think we’re at a solid place now. In just a few minutes, we’ve locked down a server and set up a level of security that should repel most attacks while being easy to maintain. At the end of the day, it’s almost always user error that causes break-ins, so make sure you keep those passwords long and safe!

I’d love to hear your feedback on this approach! Feel free to discuss on Hacker News or follow me on Twitter.


There’s a great discussion happening over at Hacker News. Thanks for all the good ideas and helpful advice! As our infrastructure grows, I definitely plan on checking out Puppet or Chef - they sound like great tools for simplifying multi-server infrastructure management. If you’re on Linode like us, the above can be accomplished via StackScripts as well.

g4u First Day In School
Mobile Application (g4u)
  • Game Features:
  • Cleanup the messy play-room
  • Get ready and makeover the little girl for school
  • Server the food in cafe to every student
  • For entertainment, clean and groom up the dog
  • Use your creativity and repair the music instruments
  • Do classwork in a coolest way
  • Study made easy with fun
Norpro Norpro My Favorite Spatula
Kitchen (Norpro)
  • Strong and flexible, lift and serve!
  • A must have spatula when cooking with nonstick cookware and bakeware; will not scratch nonstick, enamel coated or glass pots and pans.
  • Ideal for turning fish, eggs, crepes, hashbrowns, omelets and pancakes. Great for cookies, cakes, quiche, and an absolute essential for brownies!
  • The black beveled edges and narrow blade slides under delicate food easily, yet strong enough to lift and serve heavier foods. Easily your new favorite lasagna server!
  • High heat resistant to 500°F / 260°C.Size: 11 x2 / 28cmx5cm
Norpro Norpro Grip-EZ Pie Server
Kitchen (Norpro)
  • Soft santoprene handle for a strong and comfortable grip
  • Ergonomically designed for left and right hand users
  • Finger indents keep hands clear of tool s functional surface
  • Diswasher safe
  • Measures at 10-inch
Server First-Time Installation - Hardware and Software
Installation Services ()
  • Deploy the server in an existing rack
  • Connect the server to existing AC power, and dress to match server room/data center standards
  • Connect network cable to existing cable plant, and dress to match server room/data center standards
  • Attach peripherals such as keyboard and mouse, or connect to existing KVM switch
  • Install Microsoft Windows 2003/08 Server/Advanced Server, Microsoft Windows NT , Microsoft Windows Small Business Server 2003/08 or Novell NetWare, commercially...
  • Setup a print queue
  • Create 5 user login accounts
HOM Men's Dad Papa Shirts My Daughter is My World | Server Gift for Father's Day Birthday T Shirt
Apparel ()
  • PERFECT GIFT FOR DAD - Buy the perfect gift for your Father, Dad, Daddy, Papa for hir Birthday, Anniversary, Father s Day or Just like that.
  • FUNNY & EMOTIONAL DADDY LOVE - Whether for yourself or a Father this humorous, emotional or meaningful message is awesome on a merchandise or product
  • STRONG - The T Shirt has Double­needle stitched sleeves, bottom hem and front neck which ensure high quality
  • COMFORT - The TearAwayTM label on the T Shirt ensures maximum comfort for the one who wears it
  • CARE INSTRUCTIONS - Do a simple machine wash, tumble dry & do NOT bleach the shirt. Avoid ironing on the print for a longer life

Related posts: