/
Update PureInsight Bound Hostname (v2.1.0+)

Update PureInsight Bound Hostname (v2.1.0+)

This documentation will show you have to update PureInsight Cluster’s bound hostname. This will bind the services associated with the PureInsight Cluster.

You need to bind to a hostname rather than IP.

PreReqs

  1. You’ll need to update PureInsight to at least 2.1.0

  2. Identify the network layout and determine IP and hostnames to use

  3. Turn off Alerts, IDS, Pcap Indexer, and realtime stats

Steps

  1. You’ll want to be on the QP that you’ve updated the hostname of.

  2. First update the hostname on the QP to whatever you want.

    image-20250324-184410.png
    1. You will have to go into root to set the hostname this way

  3. Make sure you’re actually able to connect to this QP from all the other QP’s within the cluster after the hostname has been updated

    1. This might involve altering each /etc/hosts file if no DHCP or DNS server is set up

  4. Change into the admin user su admin

  5. Run the bash script bash /opt/quantea/api/pi_cluster_management/pi_cluster_setup.sh update_hostname

    1. Follow the prompts

      1. If running the script for the first time - you’ll need to udpate the SSL Certificates. Type in y

      2. You’ll need to update the SANS file

        1. Add the new hostname(s) using DNS.2=hostname. You can bind as many hostnames or IP’s as you want. DNS.X or IP.X

      3. Make sure to verify your host’s keys

        image-20250324-195505.png
    2. This script will automatically detect what roles this QP has within the cluster.

    3. Mongo Role

      1. This script will prompt you to ask which hostname you’re updating.

image-20241211-231422.png
Select the appropriate member that you’re updating

d. Kafka Role: This script will go ahead and reconfigure Kafka automatically

  1. The script will then continue, and set up the connectivity on each QP for the new node. It may prompt you to verify the new node’s host key - since the previous host key is under the previous hostname.

    1. You’ll have to verify the key is correct

      image-20241211-231829.png

  2. After it’s done you can verify Kafka and Mongo again

    1. python pi_cluster_management/kafka_cluster_management.py --verify_kafka

    2. python pi_cluster_management/mongo_cluster_management.py --verify

 

Errors

No host described in new configuration

A common error that occurs during the update process is

image-20250324-183602.png

An operation failure that says something along the lines of No host described in new configuration with {version: 2, term: 2} for replica set piRS13375646 maps to this node, full error: {'ok': 0.0, 'errmsg': 'No host described in new configuration with {version: 2, term: 2} for replica set piRS13375646 maps to this node

It is due to the configuration file being updated with the new host, and the host being rejected. This is more common in replica sets that don’t maintain availability or with a replica set with only one host.

All you have to do is to restart the node sudo systemctl restart mongod and then run the script again.

image-20250324-184122.png

And we’ll see that the successive run of the update_hosts script works.

image-20250324-184149.png

 

Temporary failure in name resolution

This error will occur after setting up known hosts on each of the units within the cluster after the hostname has been set. This usually happens if you did not verify that all units could connect to the new hostname

image-20250324-190207.png

We can see in this picture that we successfully updated the hostname of qp4k-pidev01 to qp4k-pidev191.

However when setting up the connectivity for all the other hosts, we can see that we can’t connect to qp4k-pidev01 with the updated hostname qp4k-pidev191

image-20250324-190332.png

You’ll have to debug that issue on each node that gets that error.

  1. make sure each node can connect to the node with the updated hostname

  2. update /etc/hosts on each node if applicable

After updating the hosts/DNS on each unit, you can verify it by issuing

python /opt/quantea/api/pi_cluster_management/pi_cluster_management.py cluster_setup_conn

This will setup the connections of every unit in the cluster to the current unit. We can see that the known hosts lists has been updated

image-20250324-191821.png

 

 

PureInsight Connect Workers fail

The Connect workers will still be bound to the last hostname and fail. In this case you must manually restart the workers.

image-20250324-200021.png
image-20250324-200146.png
After a manual restart