How to correctly set hostname and domain name?
I am also renting a domain name, let’s name it domain.org . What I would like to do would be to rename my server as server1.domain.org .
This means configuring my hostname as server1 and my domain name as domain.org .
How can I do it correctly?
Indeed, the manpage for hostname is not clear. To me at least:
- When called with one argument or with the —file option, the commands set the host name or the NIS/YP domain name. hostname uses the sethostname(2) function, while all of the three domainname, ypdomainname and nisdomainname use setdomainname(2). Note, that this is effective only until the next reboot. Edit /etc/hostname for permanent change.
- You cannot change the FQDN with hostname or dnsdomainname.
So it seems that editing /etc/hostname is not enough? Because if it really changed the hostname, it would have changed the FQDN. There’s also a trick I read to change the hostname with the command sysctl kernel.hostname=server1 , but nothing says whether this is the correct way or an ugly trick.
- What is the correct way to set the hostname?
- What is the correct way to set the domain name?
5 Answers 5
- You’ll want to edit /etc/hostname with your new hostname.
- Then, run sudo hostname $(cat /etc/hostname) .
Setting your domain, assuming you have a resolvconf binary:
- In /etc/resolvconf/resolv.conf.d/head , you’ll add then line domain your.domain.name (not your FQDN, just the domain name).
- Then, run sudo resolvconf -u to update your /etc/resolv.conf (alternatively, just reproduce the previous change into your /etc/resolv.conf ).
If you do not have resolvconf , just edit /etc/resolv.conf , adding the domain your.domain.name line.
Finally, update your /etc/hosts file. There should be at least one line starting with one of your IP (loopback or not), your FQDN and your hostname. grepping out ipv6 addresses, your hosts file could look like this:
127.0.0.1 localhost 1.2.3.4 service.domain.com service
In response to hostnamectl suggestions piling up in comments: it is not mandatory, nor exhaustive.
It can be used as a replacement for step 1 & 2, IF you OS ships with systemd. Whereas the steps given above are valid regardless of systemd being present (pclinuxos, devuan, . ).
Both those conf files say DO NOT EDIT THIS FILE BY HAND — YOUR CHANGES WILL BE OVERWRITTEN on my server (same version).
Don’t be fooled by the fact that the «DO NOT EDIT» warning appears in /etc/resolvconf/resolv.conf.d/head . Everything in the head file is prepended to the resulting /etc/resolv.conf output file, so that’s why the warning is in there, so that it shows up in the final result. Threw me for a loop at first.
This doesn’t seem to apply to 18.04 LTS — there’s no such file /etc/resolvconf/resolv.conf.d/head and there’s no such utility resolvconf .
Note also that if you use AWS you’ll also need to preserve the hostname after reboots — sudo nano /etc/cloud/cloud.cfg update preserve_hostname: true (default is false ).
127.0.0.1 hostname.domain.com hostname localhost
MUST HAVE SINGLE HOSTNAME after FQDN in /etc/hosts file. Works fine on Ubuntu 18.04.1 and all other versions. On EC2 and elsewhere.
Didn’t mess with resolve file or anything else.
That shows hostname in shell and then has the FQDN when you need it.
@MikeCiffone Technically, hostname should not contain the domain name — i.e. should not be FQDN. Many deployments do it, but it should not be done that way. Note that in-kernel hostname under Linux after 1.0 is restricted to 64 characters (see man 2 sethostname ) because that’s the value of HOST_NAME_MAX . (Until 1.0 it was mere 8 bytes.)
@bfontaine You don’t have to care about any of the reasons I’ll state — most of my hosts were configured with hostname=fqdn most of the time, and they worked. One reason is that your FQDN, not shortname, is then limited to 63ch ( HOST_NAME_MAX ). Another is that molly-guard will require you to type fqdn, not the shortname. Another is that hostname CLI prints out the full FQDN, not just hostname -f . Another is that some software might print out FQDN in place of shortname, or append the domain a second time to the FQDN (i.e. foo.example.org.example.org instead of foo.example.org ).
You can, of course, dismiss all of these as hypotheticals — but I feel correctness of having the hostname contain just, well, the hostname is more correct and professional.
Instructions written against Ubuntu 18.04.3 LTS (bionic)
sudo hostnamectl set-hostname server1
Check result by running hostnamectl :
root@www:/# hostnamectl Static hostname: server1
Change the domain via new network manager, Netplan, by editing /etc/netplan/01-netcfg.yaml and changing the search parameter:
sudoedit /etc/netplan/01-netcfg.yaml
# This file describes the network interfaces available on your system # For more information, see netplan(5). network: version: 2 renderer: networkd ethernets: eth0: dhcp4: yes nameservers: search: [ domain.org ]
Test changes by logging in a second time, and running sudo netplan try in one of the sessions and checking settings in the other:
# netplan try Do you want to keep these settings? Press ENTER before the timeout to accept the new configuration Changes will revert in 97 seconds Configuration accepted.
# systemd-resolve --status . Link 2 (eth0) Current Scopes: DNS LLMNR setting: yes MulticastDNS setting: no DNSSEC setting: no DNSSEC supported: no DNS Servers: 8.8.8.8 8.8.4.4 DNS Domain: domain.org
# cat /etc/resolv.conf . nameserver 127.0.0.53 options edns0 search domain.org
# hostname -f server1.domain.org
It all is well, press ENTER at the sudo netplan try prompt to make things permanent.
[…] You cannot change the FQDN with hostname or dnsdomainname. The recommended method of setting the FQDN is to make the hostname be an alias for the fully qualified name using /etc/hosts, DNS, or NIS. For example, if the hostname was "ursula", one might have a line in /etc/hosts which reads 127.0.1.1 ursula.example.com ursula Technically: The FQDN is the name getaddrinfo(3) returns for the host name returned by gethostname(2). The DNS domain name is the part after the first dot. Therefore it depends on the configuration of the resolver (usually in /etc/host.conf) how you can change it. Usually the hosts file is parsed before DNS or NIS, so it is most common to change the FQDN in /etc/hosts. If a machine has multiple network interfaces/addresses or is used in a mobile environment, then it may either have multiple FQDNs/domain names or none at all. Therefore avoid using hostname --fqdn, hostname --domain and dnsdomainname. hostname --ip- address is subject to the same limitations so it should be avoided as well. […]
This was kindly pointed out by poige in another thread and is exactly what Lutz proposed here.
You should not put your fqdn into /etc/hostname .
I tried to change my domain entry from myhome.local to myhome.lan I had to edit the /etc/hosts file and the /etc/network/interfaces file. My /etc/hosts file now looks like:
127.0.0.1 localhost 192.168.3.2 server.myhome.lan server
and my /etc/network/interfaces file now looks like:
# This file describes the network interfaces available on your system # and how to activate them. For more information, see interfaces(5). source /etc/network/interfaces.d/* # The loopback network interface auto lo iface lo inet loopback # The primary network interface auto enp2s0 iface enp2s0 inet static address 192.168.3.2 netmask 255.255.255.0 network 192.168.3.0 broadcast 192.168.3.255 gateway 192.168.3.1 # dns-* options are implemented by the resolvconf package, if installed dns-nameservers 192.168.3.1 dns-search myhome.lan
How to setup domain name in Linux server
Many companies have an internal domain for their IT infrastructure. This needs its servers to be configured with a domain name. This will ensure all servers will have FQDN (Fully Qualified Domain Name). For example, server12 is hostname and server12.kerneltalks.com is its FQDN. In such setup, many tools, monitoring requires servers to be identified by FQDN only.
For such a scenario you have to configure the domain name for your Linux server. We will walk you through steps that need to be taken to the setup domain name on your Linux server.
First of all, check if your server is having domain name already set up or not using below command :
root@server12 # dnsdomainname kerneltalks.com
If you get output like above then your server is configured with the domain name. If your output is blank then you have to the setup domain name for your server.
Without further delay lets jump into steps to configure domain name.
Step 1.
How to setup FQDN in Linux?
First thing to be done is add FQDN to your hostname in /etc/hosts file.
root@server12 # cat /etc/hosts 10.10.2.32 server12.kerneltalks.com server12
To confirm your FQDN, run below command :
root@server12 # hostname -f server12.kerneltalks.com
Output should be hostname.domain name
Step 2.
Configure domain name in Red Hat RHEL, Fedora and CentOS
Add below line in /etc/sysconfig/network
Add below parameter in /etc/sysctl.conf
Configure domain name in Ubuntu
Edit your hostname (not FQDN) in /etc/hostname file. and restart hostname service. If you see below error :
# service hostname restart Failed to restart hostname.service: Unit hostname.service is masked.
you can set hostname using :
# hostnamectl set-hostname server12
Once done, confirm normal hostname (using hostname ) and FQDN (using hostname -f )
Step 3.
Add domain in /etc/resolv.conf . This file used for setting nameservers as well.
root@server12 # cat /etc/resolv.conf search kerneltalks.com
This addition makes sure that you can resolves hostnames within your domain.
Step 4.
Confirm that changes are working perfectly. Question is how to check the domain name of the Linux server?
Below are the commands to check hostname, FQDN, and domain name of your server.
root@server12 # hostname server12 root@server12 # hostname -f server12.kerneltalks.com root@server12 #dnsdomainname kerneltalks.com
hostname command shows your server’s hostname. hostname -f shows your FQDN. dnsdomainname command shows your domain name of the server!
Related stuff:
- File encryption / password protect file in HPUX
- How to convert JKS file to KEY file for Apache
- Howto get CPU details in HPUX
- How to configure nameserver in Linux
- How to boot SPYRUS WorkSafe Pro Linux2Go drive
- How to upgrade package using YUM in RHEL
- How to check and test APA in HPUX
- Execute command at shutdown and boot in Suse Linux
- How to disable direct root login on Linux & HPUX
- How to open the file in the read-only mode under vi or vim
- How to add Cloundfront CDN in WordPress blog with SSL
- How to disable iptables firewall temporarily