Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 3 Next »

Agents are the tools data collectors of Insights. These are python snippets which connects to Devops tools and collect data using REST protocol. Each agents needs to be registered in system (Postgres DB, agent_configuration table) to start collecting data. Agent management screen in Admin tab helps manage agent registration, update, start, stop, Uninstall. 

When Insights product is installed, one of the important steps in to installed Agent Daemon. This is daemon process running on server where you want to run your tools agents. Daemon agents helps Insights in agent registration, update, uninstall.

Daemon agent needs connectivity to RabbitMQ. It is very critical that you make sure agent Daemon is running (generally server 2, but can be anywhere you decide) before you start registering agent from Insights UI (Admin tab). 

NOTE - Current  out-of-box agent daemon and agents support Windows and RHEL 7.x OS. For other OS flavors, one need to follow specific instructions given below in installation steps. 

Agent Daemon is available in doc root at -  http://platform.cogdevops.com/insights_install/release/latest/agentdaemon.zip

Follow below installation instructions for Daemon agent configuration. 

 Daemon Agent Configuration and Execution

On Agent server


  • Create a folder at desired location to hold AgentDaemon and Tools agent code. For Example - On Windows D:\\Agents
  • Set up environment variable INSIGHTS_AGENT_HOME pointing to above folder
  • Create the following folders under the environment variable path $INSIGHTS_AGENT_HOME
            AgentDaemon and
            PlatformAgents

For example  - D:\\Agents\\AgentDaemon and D:\\Agents\\PlatformAgents

{

"baseExtractionPath": "$INSIGHTS_AGENT_HOME/PlatformAgents",

"insightsTimeZone": "Asia/Kolkata",

"loggingSetting": {

"logLevel": "WARN"

},

"mqConfig": {

"host": "127.0.0.1",

"password": "guest",

"user": "guest",

"exchange": "iSight",

"agentExchange":"iAgent"

},

"publish": {

"health": "AGENT.DAEMON.HEALTH"

},

"isDebugAllowed": false,

"subscribe": {

"agentPkgQueue": "INSIGHTS.AGENTS.PACKAGE"

},

"timeStampFormat": "%Y-%m-%dT%H:%M:%SZ",

"toolsTimeZone": "GMT"

}

Create AgentDaemon as service - 


RHEL 7.x OS

  • Use installdaemonagent.sh  to create OS specific AgentDaemon service and provide OS input while running the script. 
  • Service name is "InSightsDaemonAgent"

installdaemonagent.sh currently supports Linux, might need to update it based on OS types and versions.

Windows OS

  • Install nssm utility on Agent server (which is part of Insights installation package )
  • Run installdaemonagent.bat provided inside ..\\Agents\\AgentDaemon folder
  • It will create Windows daemon agent service with name "DaemonAgent"
  • Validate whether service has been installed and started successfully

Once agent daemon start running successfully, it should have creates a queue in RabbitMQ with name 'INSIGHTS.AGENTS.PACKAGE'


On Application/Platform server (Tomcat)


server-config.json should be updated as follows - 

  • Add new section and change unzipPath parameter
  • If your web server doesn't have permission to connect to docroot URL, then make isOnlineRegistration as false and provide offlineAgentPath path. This is offline agent registration
  • Inside offlineAgentPath, create folder and give it some version like v1.0 or same version which you are planning to manually download from docroot url.
  • Inside version folder create agent specific folders like "git", "jenkins", "jira" same as that of docroot
  • Download individual agent zip from docroot and unzip them in respective agent folders
  • Make sure folder structure is starting from com/cognizant/.... 

         For Example typical structure assuming offlineAgentPath as "D://download//agents" --

         "D:\\download\\agents\v1.0\git\com\cognizant..."

         "D:\\download\\agents\v1.0\jenkins\com\cognizant..."


"agentDetails": {
         "isOnlineRegistration" : true,
         "docrootUrl":"http://platform.cogdevops.com/insights_install/release",
         "offlineAgentPath" : "D://download//agents",
         "unzipPath":"D://download",
         "agentExchange" : "iAgent",
         "agentPkgQueue" : "INSIGHTS.AGENTS.PACKAGE"
}

  • Make sure that server-config.json has the following section

"messageQueue": {

"host": "localhost",

"user": "iSight",

"password": "iSight"

}

Deploy new PlatformService WAR

Run below SQL query to register Daemon Agent

Update highlighted value '{"key":"value"}' in below query with daemon config.json.


INSERT INTO public.agent_configuration(id, agent_id, agent_json, agent_key, agent_status, agent_version,data_update_supported, os_version, tool_category, tool_name,unique_key, update_date) VALUES (0, 0,'{"key":"value"}','daemon-1523257126' ,'' ,'' , FALSE,'' , 'DAEMONAGENT', 'AGENTDAEMON', 'daemon-1523257126', current_date);

  • Register all required agents using Agent management tab in Admin screen 
  • Run latest new updated Insights Engine Jar
  • Validate all agents are running successfully and collecting data
 Steps to upgrade older version of agents management

1. Stop all existing running agents

2. Very Important - Note down the time (including seconds) when you stopped individual agents. This time will be used while registering agents using UI.

3. Take backup of existing agent code including tracking.json

4. Let Insights Engine consume all queues data. Verify all the queues have 0 pending data

5. Shut down Insights Engine.

6. Undeploy PlatformService WAR

7. Take back up of AGENT_CONFIGURATION table in PostgreSQL

8. DELETE all records from AGENT_CONFIGURATION table in PostgreSQL after taking backup

9. Deploy new PlatformService WAR and verify it has created below new columns in AGENT_CONFIGURATION table - 

  • agent_key
  • agent_status
  • agent_version
  • os_version

10. Run SQL DDL script –

ALTER TABLE public.agent_configuration ADD CONSTRAINT agentKeyUnique UNIQUE(unique_key);

11. Execute below SQL query in PostgreSQL to register Daemon Agent - (Do no change anything in this query)

Update highlighted value '{"key":"value"}' in below query with Daemon agent config.json.

INSERT INTO public.agent_configuration(id, agent_id, agent_json, agent_key, agent_status, agent_version,data_update_supported, os_version, tool_category, tool_name,unique_key, update_date) VALUES (0, 0,'{"key":"value"}','daemon-1523257126' ,'' ,'' , FALSE,'' , 'DAEMONAGENT', 'AGENTDAEMON', 'daemon-1523257126', current_date);

12. Follow Agent 2.0 installation steps

13. Register all required agents using Agent management tab in Admin screen.

  • In this screen we will have the opportunity to edit the agent config json. Please make sure to get relevant fields from existing config json.
  • After registering agent, go to the agent server. Stop the agent service. Replace tracking.json and restart the agent service. 

14. Run latest new updated Insights Engine Jar

15. Validate all agents are running successfully and collecting data as usual

16. We recommend to take latest artifacts for PlatformService.war and PlatformEngine.jar and UI app.

Other OS

Running an application has service differs based on Unix flavor. For Example, Linux RHEL it runs from /etc/init.d folder, in Ubunut it runs from /etc/systemd/system. Hence to run agent daemon and agents follow below steps. 

  • Once agent daemon is downloaded and extracted in $INSIGHTS_AGENT_HOME\AgentDaemon folder, modify installagentdaemon.sh for OS specific steps. 
  • Follow offline agent registration steps given above
  • Once agent packages are downloaded in offlineAgentpath, modify individual agent's installagent.sh for OS specific steps. 

Top Section

  • No labels