1

I'm configuring a VPS that I recently subscribed to and I follow other devs' blogposts to help me setting my own up. I often see them changing the VPS hostname. The default VPS hostname doesn't look very pretty (e.g. vps-1343-8332.myvpsprovider.cloud), so they change it to their domain name. For instance:

hostnamectl set-hostname --static www.yourdomainname.com

However, to my understanding, as long as DNS is resolving the domain names to the correct IPs, hostname has no influence at all on the hosted domain name.

Then I wonder, for what reasons do fellow devs change their default VPS hostname?

user2923322
  • 183
  • 5

2 Answers2

3

Prevent mistakes

Logging into productive systems interactively opens up ways to commit various dangerous mistakes. If $PS1 is configured so your shell prompt and window title is showing what machine you are working on, that better be something that helps you notice "whoops, i am on the wrong machine!"

A good server may include numbers, but should include a word that helps admins distinguish different machines.

Ease administration

Network configuration gets a lot simpler when each service can just default to one host name set in OS. In email context, you often want to greet other servers announcing your host name (matching your reverse name) that is demonstrating your actions are attributable to you.

Few servers will receive mail from *.myvpsprovider.example, as such host name has so far exclusively sent them spam.

anx
  • 6,875
  • 4
  • 22
  • 45
3

Changing the hostname assigned by the hosting provider to something matching your own organisation's naming convention is usually a good idea.

Predictable and memorable host names help humans remember and identify systems much more easily than the ip-address and will likely help prevent mistakes.

From a branding perspective you usually also want your servers to identify themselves as part of your domain, not the hosting providers.

  • Keep in mind that a hostname must uniquely identify a specific server and a server can (should) have only one hostname.

    • The forward DNS entry for the hostname should exist and the FQDN should point to the servers main ip-address. (Also see this Q&A)
      That also implies that you usually use a domain that you actually own, not something you make up.
    • The name of the host does not need to be the same as the service running on that host.
      I.e. avoid the situation where a single web server is hosting multiple websites and that has the hostname www.example.com. You can spend hours checking and finding nothing wrong with that website before realizing that the issue is with "www other-site" running on www.example.com
    • You want to avoid recycling hostnames, it gets annoying fast when you need to distinguish individual hosts by "the old www.example.com" and "the new www.example.com" and similar such non-sense.

    • The hostname will be used in system prompts, banners, error messages , log files etc.
      When you have for instance a cluster of web servers all with the same hostname www.example.com identifying the specific misbehaving node is unnecessarily difficult.

    • With forward DNS you can point an unlimited number of different and unrelated host and domainnames to a server's ip-address, but for reverse DNS you can effectively only map the ip-address to a single hostname. Align the reverse DNS record with the hostname set in the server.

HBruijn
  • 72,524
  • 21
  • 127
  • 192
  • Thank you. Could you explain why you suggest to align the reverse DNS record with the hostname? – user2923322 Mar 03 '19 at 12:15
  • 1
    @user2923322 Two reasons : - reliable mail delivery , the typical mailserver will identify itself to the receiving smtp server by its host name and the receiver will do a reverse (and forward) lookup to see if the ip-address resolves to that hostname - and debugging client connections , frequently error messages will convert the ip-address And you get *“connection refused for `user` from `hostname` “* – HBruijn Mar 03 '19 at 17:56