--- route: update-agents-on-prod allow_guest: 1 published: 1 --- **Agent Update Tool** is an internal ops tool for updating agent in bulk. This tool update agent sequentially. So, the process looks like this - - Trigger agent update on a server. - Verify update and wait for agent to come back online. - If something looks wrong, it will revert agent update. - In case of successful agent update, it will move to next target. **Preview -** ![](/files/Pasted%20image%2020250516162446.png) Let's understand all the section one by one - **General Info** Top section contains overall status, start and end time. **Source** You need to provide the info of git repo and branch info here. You can ignore all of these fields, the repo and branch will be fetched from `Jcloude Settings` in case you don't provide any choice. If you want to update to a specific commit hash only, you can provide that info, else it will auto populate the info after save. **Config** 1. **Server Type** - Chose the server types, that you want to update. This will help to auto populate the server list later. 2. **Restart Mode -** Most of your updates don't need RQ or Redis restart. So, chose only the required ones to impact server very less. > Currently, RQ Workers will be restarted gracefully. So, If RQ worker is executing some task, until unless that stop worker will not be stopped. > That's why it's better to avoid restarting RQ worker (If possible) 3. **Rollback Settings -** You can chose to auto rollback changes on failed update. Also you can decide whether to continue or not after a successful rollback. There is an additional option `Rollback to Specific Commit`, this you can use to rollback to specific commit on all agent update (Useful in Development Environment) #### How to Update ? 1. Create a agent pagetype, with all necessary config, ![](/files/Pasted%20image%2020250516170638.png) 2. Once you save the pagetype, server list will be populated. ![](/files/Pasted%20image%2020250516170716.png) > Check the sever list once. If you want to remove some servers, just remove the row. > If the agent on the server is already updated, the tool will automatically skip update. You don't need to do anything for that. 3. Then, click on `Build Plan` button. This process can take few minutes. During this will gather the current installed agent information and plan the whole update. 4. Once done, status will be changed to `Pending` ![](/files/Pasted%20image%2020250516171138.png) 5. You can now click on `Start` and relax. #### Pause Update If you want to pause whole process, click on the `Pause` button. You will get a `Resume` button as well. #### Test Mode Assume, you just want to update on 2~3 servers and then on other servers. ![](/files/Pasted%20image%2020250516172143.png) So after 4 updates, it will pause the updates. You need to `Resume` update manually. #### Splitting Updates For example, you are going to roll out update to 500 servers and each server update take 2mins in total. So, it's going to take 1000 minutes (almost 16 hrs) This feature will solve that. You can split 500 updates in 10 batches. So, that 10 parallal updates happen, that will take 1/10th time (1.6 hr) **Steps -** For example, we have an agent update pagetype with 2 servers. ![](/files/Pasted%20image%2020250516172935.png) I want to split it in 2 batches 1. Click on `Split Update` button (**Note -** This button will appear only in `Pending` update status, so `Build Plan` is mandatory) 2. Choose number of batches and submit. ![](/files/Pasted%20image%2020250516173147.png) 3. Now, you will see there is 2 `Agent Update` records, from which you can manage 2 separate batch. You can run both parallelly or one by one as per your choice. ![](/files/Pasted%20image%2020250516173339.png) ![](/files/Pasted%20image%2020250516173407.png)