Should You Self-Host Your Blog or Website?

First let me make something very clear.

While not all ISPs (Internet Service Providers; the people you get your Internet connection from) allow you to host off of your Internet connection, there are ones that will let you run your own server from your house or office.

For the rest of this blog post, I’ll assume you are using an ISP that allows you to run your own server.


I have read forum posts before about people who say that running a web-server from your own house is a bad idea. Well if they mean that it is bad to host your own server at the home/office in every single circumstance…then they are wrong. If you think about it, there are actually really good reasons to run a server from your house (or even office).

  1. Since your web-server is running from your house, you have better control of what happens to the server. On the other hand, running your web-server (or renting a web-server, which means you don’t even own a server then!) from a data center somewhere in the US does not really give you control of what happens to the server.
  2. You get more privacy when hosting yourself. You do not have to worry about someone copying your server data off onto some other computer to snoop through your information.
  3. When it comes to fire, floods, theft, etc. both the home/office and the data center are pretty much equivalent.
  4. If you have a business-grade connection from your ISP, you may get even better bandwidth than if you hosted from a data center, since the data center would be hosting 100s if not 1000s of servers.
  5. You get to choose all your server hardware that you want to use when you host at the home/office.
  6. Both the home/office and data centers can deal with power-loss issues. Of course, a data center will be better equipped to handle power outages. However if you have a battery backup on your home server, it will last for a bit. I do agree, if you have bad power (e.g., power goes off once every other day), then I would not try to self-host.
  7. In my opinion, you would get about the same (if not better) up time hosting yourself, then having a very busy data center try to host your server with everyone else.

Conclusion:  Assuming that you have the equipment and an ISP that let’s you do it, there is really no huge difference between hosting a server at a data center and hosting a server at the home/office for your personal or small business use.


Posted in Internet and Servers

IIS vs Apache: Which is the Right Choice?

Last Updated: 08/26/2024

Both Apache and Microsoft IIS (Internet Information Services) have great abilities to host many kinds of websites for many kinds of people and businesses. If you are looking into starting your own web-server, you probably came across the old IIS vs Apache war.

True…Apache does have the most compatibility with websites mainly with .htaccess files and with older web applications, but IIS is a powerful, capable web-server as well (supports the ASP.Net framework, a powerful web application framework).

Over the years, IIS has gained much attention from the web hosting crowd in supporting web applications (e.g., WordPress). Also, PHP still supports Windows (as they have for years already).

Both IIS and Apache can be installed and used instantly, out of the box, with hosting HTML files. However, both need to be configured to make use of other technologies (such as PHP or Perl).

IIS also sandboxes people’s websites from each other (Application Pool Isolation), and allows for separate security permissions via Access Control Lists that are in the NTFS file-system as well as the rest of the Windows operating system.


Here are my opinions on which web-server software performs the best in certain areas.

Specific Area Winner
Easy Website Sand-boxing (websites, hosted on the same web server, protected from each other)  |  Application Pool Isolation IIS
Quick and Easy Initial Setup IIS & Apache (tie)
Easier to Manage IIS (because of its powerful graphical user interface)
Most Compatible with Websites (excluding ASP and ASP.Net websites) Apache
Amount of Available Internet Support Apache
Best PHP Performer (assuming Fast-CGI is used) IIS & Apache (tie)
Lighter on your System Resources IIS
Native ASP and ASP.Net Support IIS (there is .NET Core for Linux, but it is not 1:1 with the full .NET Framework)
Immune to the Slowloris attack IIS (Apache can be configured to be resistant to the Slowloris attack, but without a rewrite, will not be able to be immune to this type of attack.)

Notes

  • (Application Pool Isolation) IIS application pools isolate different web applications from each other. This means that if one application crashes or its security is compromised, it does not affect others running on the same server.
  • Fast-CGI allows servers to serve PHP enabled websites faster by keeping the PHP process or processes on, instead of turning them off when not in use, since creating a process and then terminating a process is resource intensive when a server has many requests to deal with.
  • There is Mono for Apache, but that does not count, since Mono is emulating ASP.Net. It’s not an authentic ASP.Net framework.
  • The Slowloris attack is a type of Denial-of-Service that causes a website to be temperately taken offline when using an affected web server (e.g., Apache).
    • The attack uses up all the connection slots on the web server, so legitimate web traffic cannot get through. Unfortunately, Apache can never be immune to this attack without a rewrite of its code.
    • There is an interesting Apache module you get get to help mitigate a Slowloris attack. In my testing, the mod_antiloris Apache module appears to mitigate the attacks quite effectively.
    • In addition, putting Apache behind a reverse proxy (e.g., Caddy) will also stop the Slowloris attack from affecting your Apache web server.

Now am I saying that Apache is not any good? No, not at all. I personally view web servers – and any other server software – as tools. Just as a mechanic has different tools for his work, so does a server administrator have different tools at his disposal. If you feel Apache gets the job done, use Apache. If IIS gets the job done, use IIS.


Posted in Internet and Servers, Software

Is There Anything Wrong with Using Linux as a Server?

I have used both Windows and Linux on servers. They both are capable operating systems. What you need to ask yourself is “What do I need and/or want?”

I cannot (nor can anyone else) tell you “you need to use Windows…or…you need to use Linux”. If you know what your goals are, then it will make it easier for you to decide which OS to use as a server.

Here are some tips on which OS to use, based upon some possible reasons you have for choosing one OS over the other. Please note these are based upon my own opinions from using both for several years.

Supports the Most Popular Web Technologies Windows/Linux (a tie)

(Windows does support ASP & ASP.Net, whereas Linux officially does not)

Makes Better Use of Your CPU Windows
Makes Better Use of Your Memory Linux
More Flexible (not counting file-system security permissions) Linux
Out-of-the-Box Security Windows
More Stable Windows / Linux (a tie)*
Availability of Free Server Software Linux
Available Online Support Windows / Linux (a tie)
Flexibility of File-system Security Windows**
More User-Friendly Windows

* In my opinion, 99% of crashes on Windows are due to faulty hardware and/or drivers. However, both Windows (NT family) and Linux are stable operating systems, when using good, stable hardware and good, stable drivers.

** Due to the fact that Windows uses ACLs (Access Control Lists) by default. ACLs are much more flexible than UNIX Read/Write/Execute bits.


Posted in Internet and Servers, Operating Systems

Response to “6 Reasons Why Linux Servers are More Secure”

This is a response to the author’s post of “6 Reasons Why Linux Servers are More Secure” (http://smashingtips.com/6-reasons-why-linux-servers-are-more-secure).
My responses are in purple and direct-quotes from the author are in red. Please note that I mean no disrespect with my replies.

-SEVERAL LEVELS OF SECURITY WITH LINUX SERVERS-

Linux based servers are not much different in terms of capabilities with what the server can provide in terms of processing the websites and other information stored on the server. The big difference between Linux servers and other options is the fact that there are many more layers of security that are possible with Linux based server software. There are other security layers possible with third party software mechanisms available as well.

What does “many more layers of security” mean? With all due respect, there is no information here that would convince me that Linux software is secure, much less really secured.

Bottom line: There is no real information in this section to make an argument for Linux software being secure.

-YOU CAN LIMIT ACCESS TO THE ROOT OF THE SERVER-

You can limit Root access as well as disable Root SSH Logins that make it possible for hackers to gain access to your valuable files and other resources on the server. You can even make it so only a few users have access to administrative tools by setting special user attributes while others are still restricted in the event that a hacker got a hold of another user account which could attempt to use the switch command to the Root of the server.

I am not sure how this qualifies as a point of Linux being more secure than other options that are out there. In Windows, you can limit access to the Administrator account (the Administrator account on Windows is like the root account on Linux).

Linux, Windows, Mac OS X (a UNIX, not Linux, OS), and FreeBSD (a UNIX, not Linux, OS) are all the same in this regard. Windows Administrators can limit their own access via ACLs (Access Control Lists) that are present in the NTFS file system. Linux has ACLs too, but I do not think they are widely used nor do I think many Linux programs are compatible with ACLs.

Bottom line: This is a weak argument for Linux being secure.

– SOFTWARE OPTIONS FOR LINUX SERVERS ARE LESS VULNERABLE-

Most of the software that is developed for Linux servers is designed to have the highest levels of security to prevent hackers and virus attacks. The vulnerability of the software is entirely up to how long a hacker is willing to attempt to hack each individual software component of the servers that you are using. This limits the access to the important sections of your Linux servers and provides even more security.

Where is the proof to back up the statement “Most of the software that is developed for Linux servers is designed to have the highest levels of security to prevent hackers and virus attacks.”? I highly doubt that most software for Linux is written with high security in mind. Sure, I can see some server software for Linux designed with heavy security in mind, but not most of the Linux software. You really cannot make statements like this without some proof (like a link to a reliable source on the Internet) to back it up.

Bottom line: Nothing here to really make a good argument for Linux security.

-UPDATES TO LINUX SERVER SOFTWARE ARE MORE FREQUENT-

The constant necessity of security with Linux servers prompts for more frequent software updates. These updates remove vulnerabilities as well as increases security all around. When used in conjunction on servers, the security of the server is increased exponentially. It simply becomes more secure every month providing that the owner of the server performs the updates to the software options when they become available for use.

Software updates are not always for fixing security problems. Even when updates fix security problems in both the OS and the software running on the OS, that does not mean that the update did not cause other security problems that have gone unnoticed. In addition, you could count many updates as not a good sign, since it might indicate a design flaw in the OS or the software you are updating.

Bottom line: Many OS/software updates DOES NOT equal better/more security.

-NO EXECUTABLE AND REGISTRY-

Like windows linux doesn’t support .exe files. Most of the viruses in windows are being spread with .exe files what happens you just double click on .exe file and virus,trojan or malware easily integrate itself with windows. And similarly Registry is another place where viruses put their information. Even if you delete the file, It rewrites its information from registry and it is also too difficult to find where virus hides its information in registry.Linux uses configuration files rather than registry so another big hole for viruses is closed and as i mentioned in point 1 that linux doesn’t allow any normal user to edit system files.

Viruses are made in different file extensions, not just exe files! Saying that Linux does not get viruses because it “doesn’t support exe files” is silly.

A virus is just a program that runs without the user knowing it is there (at least that is the idea ;-]  ) and runs a pre-programmed set of tasks that the virus author(s) want it to do. Some viruses, I am sure, have some sort of A.I. in them to adapt to situations, but these are very rare to come across.

Also, it’s not really true that Linux does not support exe files, since if you install “wine” (a program that tries to run Windows programs on Linux) then Linux would then support exe files!

Linux can get viruses too, but without running a real-time anti-virus program on your Linux box, how can you have the potential to know that you do not have a virus on your Linux desktop/server? People who say that “no viruses” is a reason to switch to Linux do not know what they are talking about.

Also, you cannot blame the Windows registry for the virus’ use of it. Using configuration files, instead of a registry, does not really make you any more secure. Who says that viruses could not make use of current OS config files, or even make their own config files on your computer.

Bottom line: You cannot take a file extension used in an OS (in this case, .EXE files in Windows) and make it sound like it is an evil file extension that causes the spread of viruses on that particular OS (Windows in this case). Someone could put a virus in a .SH file for Linux and you could be infected if you ran it, or any other file in Linux, since most if not all files in Linux can be used as an executable. However, the file would have to be chmodded to allow the file to be executed. Lastly, the Windows registry cannot be blamed for the viruses using it.

-FTP ACCESS IS RESTRICTED AND EASY BACKUPS ARE POSSIBLE-

You can restrict access to the FTP for the Linux server to allow for different levels of access to all of the allowed accounts. This access can also be limited to only viewing and downloading content from the server. You can also make quick backups of all important data with a Linux server which can be restored in the event that the server is changed during an attack. Backing up couldn’t be easier on Linux, cron jobs make backups pretty painless and the options are really unlimited for choosing the best way to back up your server.

Um…FTP servers work on Windows and UNIX too (with user restrictions as well). I really do not understand what your point is about FTP.

‘Easy backups’ and ‘cron jobs’ have nothing to do with what your article is talking about. I really do not understand your point on this one either.

Bottom line: Nothing here to suggest that Linux is more secure choice than other OSes.

-CONCLUSION-

Being able to choose between different distros on Linux creates limitless possibilities. Debian, Ubuntu, Red Hat, and all of the others provide different features for server admins to choose from. The ability to run the distribution that best serves your application, company, or web site really allows Linux to be the best all around option for a server admin. Windows is limited to Windows Server, which provides great functionality, but the depth that Linux can provide cannot be easily matched. Let alone the performance.
Having these options available as a server admin may be confusing as a new comer, but as you start learning about the features and unique qualities of each distribution, you will be able to find a favorite that suites you and really get the most out of your server by utilizing every aspect of the hardware and software working efficiently together. The most fun part is sometimes just downloading 10-20 different .iso’s of the new linux distributions and installing them on different partitions or running them on LiveCD or USB stick and playing with the new features and environments each of them are working on.
Go out there and learn about the advantages and disadvantages of each Linux distro and find the one that best suites you and learn it inside and out. Doing so will give you the best experience and most secure server you could ask for.

“The ability to run the distribution that best serves your application, company, or web site really allows Linux to be the best all around option for a server admin.” Many options can be a good thing or it can be a bad thing. If I were a web hosting company, and everyone on an online forum told me to use CentOS, no wait…Ubuntu…no wait…Gentoo…no wait…FreeBSD (UNIX OS)…no wait…Debian…no wait…Linux Mint…no wait…OpenSUSE…no wait…Arch…no wait…Fedora…no wait…I would just have to try them out for myself.

With Windows, many programs will work fine from one version to another. The Windows OS itself, on the surface, will pretty much run the same from one version to another (I know there are changes under the hood though and Windows 8 and Windows Server 2012 had big interface changes).

“Windows is limited to Windows Server, which provides great functionality, but the depth that Linux can provide cannot be easily matched. Let alone the performance.”

Ok. Let’s talk about this sentence one part at a time.

“Windows is limited to Windows Server…”What exactly are you meaning? Of course, Windows Server is Windows Server. Linux is Linux. UNIX is UNIX.

“…which provides great functionality…”True!

“…but the depth that Linux can provide cannot be easily matched. Let alone the performance. Let alone the performance.” I agree that Linux is much more flexible than Windows, but performance wise it all depends on your hardware, software, Linux kernel (the Windows kernel you cannot change or modify, but it obviously works fine for many people the way it is).

“Having these options available as a server admin may be confusing as a new comer, but as you start learning about the features and unique qualities of each distribution, you will be able to find a favorite that suites you and really get the most out of your server by utilizing every aspect of the hardware and software working efficiently together. ” Most people are not going to have time or even want to do this. The idea is to make things easier for people, not give them 10s or 100s of operating systems to go through.

“Go out there and learn about the advantages and disadvantages of each Linux distro and find the one that best suites you and learn it inside and out. Doing so will give you the best experience and most secure server you could ask for.” I would agree that researching the right Linux distribution (at least during the time you have available to burn) would help you to choose a good distribution, but I disagree that research would give you the most secure server you ever could get. You can secure Linux, Windows, and UNIX, but nothing will be totally secure.


Posted in Internet and Servers, Operating Systems