NTP server is important component in every enterprise system since it gets the network time synchronized, scripts execute on time, backup jobs done…
On RHEL 8 ntp is implemented by chronyd. Chrony can work both as server and client.
So, let us set it up.
(run all commands as root)
Install and configure chrony server:
First, we will install the package
sudo yum -y install chrony
data:image/s3,"s3://crabby-images/b8004/b800430590446b4f66640cf916feacd9017c5523" alt=""
Next, we will start chronyd service and set it to start after reboot
systemctl start chronyd
systemctl status chronyd
systemctl enable chronyd
data:image/s3,"s3://crabby-images/7ec86/7ec868cde63d42f3caa67fc185a72c10e8aa76e3" alt=""
Now we will set Chrony as our main time server for the local network.
We will edit /etc/chrony.conf
I will edit it with vi editor.
vi /etc/chrony.conf
data:image/s3,"s3://crabby-images/0eca7/0eca713cdea5dd440b96eb013c368cdc4435f525" alt=""
There is a line in chrony.conf which we will uncomment and set to allow machines from local network to update from our time server
Before
data:image/s3,"s3://crabby-images/d53f0/d53f03083b020471d86495c596d367d1fd3bd322" alt=""
I will set network for my lab network, you of course will enter network you use
This is after
data:image/s3,"s3://crabby-images/17e33/17e336a3eb71fed0b5048bfc9ab95fd145c053a1" alt=""
Save and exit
You can also use /etc/chrony.conf file to add more NTP servers to it, here are some of the NTP servers you can add:
server 0.rhel.pool.ntp.org iburst
server 1.rhel.pool.ntp.org iburst
server 2.rhel.pool.ntp.org iburst
server 3.rhel.pool.ntp.org iburst
server 0.centos.pool.ntp.org iburst
server 1.centos.pool.ntp.org iburst
server 2.centos.pool.ntp.org iburst
server 3.centos.pool.ntp.org iburst
here is also great list of NTP servers here – https://www.ntppool.org/en/
I added a few servers that are close to my area – at the beginning of the /etc/chrony.conf
Save and exit…
After that we can run following command
sudo timedatectl set-ntp true
data:image/s3,"s3://crabby-images/0aa44/0aa4452f90913b33e0fbc36c5b2eaa9f46382258" alt=""
Restart service by entering:
systemctl restart chronyd
data:image/s3,"s3://crabby-images/da2ac/da2ac7040d9e6d254f7c7f738e93a3d853acdfce" alt=""
Next, we will open firewall to allow NTP requests
(two minuses are before permanent, add and reload words)
firewall-cmd --permanent --add-service=ntp
firewall-cmd --reload
data:image/s3,"s3://crabby-images/d03cd/d03cd680347c3b76aafb87f81864ad92b4c1b6b1" alt=""
We will now check if NTP is working by entering following command
chronyc sources
data:image/s3,"s3://crabby-images/8377c/8377c4827437e7dad5247e6db45c13aab30fce46" alt=""
Now, we will set client to sync time with our NTP server.
I have CentOS 8 which will serve as a client for this purpose
Frist, we will install chrony to our client
yum install chrony
data:image/s3,"s3://crabby-images/e7b94/e7b94c1fe69ffa8217a32a9a266f256742104613" alt=""
In my case it is already installed, but you will confirm you want to install if you don’t have installation.
Next step will be to start and enable chrony service after reboot
systemctl start chronyd
systemctl enable chronyd
systemctl status chronyd
data:image/s3,"s3://crabby-images/c8ad6/c8ad6be4e55416cc16ce42405dc23cb93d8258df" alt=""
Again, we will edit /etc/chrony.conf again, this time on this client
vi /etc/chrony.conf
data:image/s3,"s3://crabby-images/84e11/84e1114d9da9a5eada9068d99895b8501576c753" alt=""
Comment ntp servers that are active at the top of the document and enter address of your local ntp server. In my case it is
server 10.20.10.7
It should look like this
data:image/s3,"s3://crabby-images/cd9a1/cd9a1f413ff26aa0b9957544b217954a36246ae6" alt=""
Save and exit
Set NTP synchronization by entering:
sudo timedatectl set-ntp true
data:image/s3,"s3://crabby-images/6e407/6e4072dbb5ad48bfc46081f48becca350f13a8fc" alt=""
Now, we will restart chronyd service by entering:
systemctl restart chronyd
data:image/s3,"s3://crabby-images/440e4/440e433f76ecf2edccc2120cb92c0f75c2bebcd5" alt=""
On client, check to see what are your ntp servers by entering:
chronyc sources
data:image/s3,"s3://crabby-images/00535/00535cde6b2b517f252af3c2a3327732cc0db8ed" alt=""
On server, you can check active clients by entering
chronyc clients
data:image/s3,"s3://crabby-images/d851e/d851e37fd9213cd318585b3ed94c5007bae83820" alt=""
In case you are getting question mark instead of *, check again your settings, check firewall setup, check if the chrony service is active on server and client, recheck all.