- Subscribe to RSS Feed
- Mark Question as New
- Mark Question as Read
- Float this Question for Current User
- Bookmark
- Subscribe
- Mute
- Printer Friendly Page
how to remove old registered hosts from DB
- Labels:
-
Apache Ambari
-
Apache Hadoop
Created ‎12-05-2017 03:12 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
I am trying to remove old worker from the DB ( from ambari-server machine ) as the following
* reference - https://community.hortonworks.com/questions/52910/how-can-i-remove-registered-host-but-do-not-added....
psql -U ambari ambari Password for user ambari:
ambari-> select host_id from hosts where host_name='worker05.sys59.com'; host_id --------- 255 (1 row)
so I delete the host:
ambari=> Delete from hoststate where host_id=255 ambari-> Delete from hosts where host_id=255
ambari=> select host_id from hosts where host_name='worker05.sys59.com'; host_id --------- 255 (1 row)
this worker still exists in DB , ( host_id=255 ) , even I restart the ambari-server !!
why?
and how to total remove this worker include all worker properties from postgreSQL ?
Created ‎12-05-2017 08:21 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
You can try the following approach to completely remove the unwanted host from your ambari Database.
0. Stop ambari-server.
# ambari-server stop
1. Please take a fresh ambari DB dump for safety and backup.
2. Now run the following SQL queries inside your ambari DB to delete the unwanted host. Please replace the "unwanted1.host.com" with your unwanted hostname and similarly the "351" with the "host_id" that you want to remove from your Database.
delete from execution_command where task_id in (select task_id from host_role_command where host_id in (351)); delete from host_version where host_id in (351); delete from host_role_command where host_id in (351); delete from serviceconfighosts where host_id in (351); delete from hoststate where host_id in (351); delete from kerberos_principal_host WHERE host_id='unwanted1.host.com'; ----> For kerberized Env delete from hosts where host_name in ('unwanted1.host.com'); delete from alert_current where history_id in ( select alert_id from alert_history where host_name in ('unwanted1.host.com'));
3. Now restart ambari-server.
# ambari-server start
.
Created ‎12-05-2017 03:35 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Add a semicolon at the end of the statement
ambari=> Delete from hoststate where host_id=255; ambari=> Delete from hosts where host_id=255;
Note: Do the above with caution. Before removing the node from cluster it is advised to move all the services to other nodes and make sure that the node is clean before deleting the node.
Below is the API to delete the node
curl -u {ambari-user}:{ambari-password} -H "X-Requested-By: ambari"-X DELETE http://{ambari-host}:{ambari-port}/api/v1/clusters/{clustername}/hosts/{hostname}
Thanks,
Aditya
Created ‎12-05-2017 03:46 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
I am usually remove it by the amabri GUI ( dlete node ) , but I guess the API do the same ?
Created ‎12-05-2017 03:48 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Yes. Ambari calls the same API internally. If you want to run it from command line instead of Ambari GUI , you can use the API.
That should take care of clearing the entries from DB. You need not delete the entries from DB manually
Created on ‎12-05-2017 04:05 PM - edited ‎08-17-2019 07:57 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Created ‎12-05-2017 04:08 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
It shouldn't take so long. Please check the ambari log to see what is going wrong.
Check this file /var/log/ambari-server/ambari-server.log in ambari server node
Created ‎12-05-2017 04:15 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
the deleted host - worker 06 only deleted and we not removed the worker component , so now when we add this worker again mayby this is the conflict because worker is already installed ?|
Created ‎12-05-2017 04:40 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
If the host deletion was not proper then there can be conflicts. The ambari log below doesn't show any errors. Try restarting ambari server and see if you can proceed further.
ambari-server restart
Created ‎12-05-2017 04:34 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
from the ambari-server log we see that
configs for this execution command: Cluster not found, clusterName=clusterID=-1 05 Dec 2017 16:33:37,189 WARN [ambari-action-scheduler] ExecutionCommandWrapper:185 - Unable to lookup the cluster by ID; assuming that there is no cluster and therefore no configs for this execution command: Cluster not found, clusterName=clusterID=-1 05 Dec 2017 16:33:37,189 WARN [ambari-action-scheduler] ExecutionCommandWrapper:185 - Unable to lookup the cluster by ID; assuming that there is no cluster and therefore no configs for this execution command: Cluster not found, clusterName=clusterID=-1 05 Dec 2017 16:33:38,222 WARN [ambari-action-scheduler] ExecutionCommandWrapper:185 - Unable to lookup the cluster by ID; assuming that there is no cluster and therefore no configs for this execution command: Cluster not found, clusterName=clusterID=-1 05 Dec 2017 16:33:38,222 WARN [ambari-action-scheduler] ExecutionCommandWrapper:185 - Unable to lookup the cluster by ID; assuming that there is no cluster and therefore no configs for this execution command: Cluster not found, clusterName=clusterID=-1 05 Dec 2017 16:33:38,222 WARN [ambari-action-scheduler] ExecutionCommandWrapper:185 - Unable to lookup the cluster by ID; assuming that there is no cluster and therefore no configs for this execution command: Cluster not found, clusterName=clusterID=-1 05 Dec 2017 16:33:39,247 WARN [ambari-action-scheduler] ExecutionCommandWrapper:185 - Unable to lookup the cluster by ID; assuming that there is no cluster and therefore no configs for this execution command: Cluster not found, clusterName=clusterID=-1 05 Dec 2017 16:33:39,247 WARN [ambari-action-scheduler] ExecutionCommandWrapper:185 - Unable to lookup the cluster by ID; assuming that there is no cluster and therefore no configs for this execution command: Cluster not found, clusterName=clusterID=-1 05 Dec 2017 16:33:39,247 WARN [ambari-action-scheduler] ExecutionCommandWrapper:185 - Unable to lookup the cluster by ID; assuming that there is no cluster and therefore no configs for this execution command: Cluster not found, clusterName=clusterID=-1 05 Dec 2017 16:33:40,272 WARN [ambari-action-scheduler] ExecutionCommandWrapper:185 - Unable to lookup the cluster by ID; assuming that there is no cluster and therefore no configs for this execution command: Cluster not found, clusterName=clusterID=-1 05 Dec 2017 16:33:40,273 WARN [ambari-action-scheduler] ExecutionCommandWrapper:185 - Unable to lookup the cluster by ID; assuming that there is no cluster and therefore no configs for this execution command: Cluster not found, clusterName=clusterID=-1 05 Dec 2017 16:33:40,273 WARN [ambari-action-scheduler] ExecutionCommandWrapper:185 - Unable to lookup the cluster by ID; assuming that there is no cluster and therefore no configs for this execution command: Cluster not found, clusterName=clusterID=-1 ^C
Created ‎12-05-2017 04:54 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
another issue I have about :
ambari=> Delete from hosts where host_id=351; ERROR: update or delete on table "hosts" violates foreign key constraint "fk_host_role_command_host_id" on table "host_role_command" DETAIL: Key (host_id)=(351) is still referenced from table "host_role_command".
