Skip to main content

Introduction to UiPath Orchestrator

Orchestrator is the component of the UiPath Platform for managing automations, robots, and the related entities. Although it comes with different cloud and on-premises delivery options, including persistence, high availability, and disaster recovery, users can access it through a simple web interface.

Orchestrator offers role-based access control and a structure of tenants and folders to replicate organizational structures. Users can run the automation workflows developed in Studio and published to Orchestrator using the unattended robot workforce. Furthermore, Orchestrator is used to manage and distribute licenses, as well as to store automation resources.

A single Orchestrator instance can be split into multiple Tenants. Each tenant in an organization can be further subdivided and organized into Folders. Tenants are designed for the purpose of complete isolation of all Orchestrator entities (i.e., Robots, Assets, Queues, etc.) between these segregated instances of your deployment, all without having to maintain multiple Orchestrators. Modern folders provide multiple features such as automatic robot management, hierarchical structures, and fine-grained role assignment for users.

Consider a typical large company, in which both the data and the business processes are typically separated between divisions like Sales and Finance. But then, the subdivisions would have some of the data or some of the processes separated, at the same time, sharing others.

In Orchestrator, some of the entities exist in the tenant context, while others exist in the folder context.

Orchestrator concepts

Robot (Orchestrator)

By now you're familiar with UiPath Robot, the component of the UiPath Platform. This is an execution host that runs automation processes published in Orchestrator, as jobs.

In Orchestrator, a robot entity represents an image or the Robot component, controlling its connection and capabilities. The robot entity exists only if it is defined in relation to a user/ robot account in Orchestrator.

Folder

Folders enable the separation and hierarchical organization of automation entities (processes, queues, assets) and the fine-grained configuration of roles and permissions.

You can create as many sibling folders as you want on a given level. The maximum hierarchy depth is 7, meaning you can have a maximum number of 6 nested subfolders under a first-level folder.

Folders help replicate the organizational hierarchies, with the separation of automated processes between teams, segregation of process data, and access control for users. At the same time, when it makes sense, they allow sharing of the resources and assets.

Package

A project developed in UiPath Studio that is published to Orchestrator as a NuGet package. Multiple versions of the same project can be stored and used.

Packages can also be manually uploaded to Orchestrator.

Additionally, by viewing the versions for a package you can download it from Orchestrator.

Process

It is a version of a package that's been allocated to a certain folder.

Given that most processes use a queue, asset, or storage bucket, the Package Requirements tab, for when adding a new process, makes it easy to identify which entities your package is using and if they are missing from your folder.

Job

A job represents the execution of a process on a UiPath Robot. You can launch the execution of a job in either attended or unattended mode. You cannot launch a job from Orchestrator on attended robots, unless for debugging purposes using personal workspaces, and they cannot run under a locked screen.

Heartbeat

Attended and unattended robots send a heartbeat to Orchestrator every 30 seconds. This signals to Orchestrator that the connection is working.

Tenant entities

From the entities defined above, robots are tenant entities. This means that they can be allocated to multiple folders in that tenant. Using roles and permissions, the way robots work with each of the folders can be customized.

Packages are published to Orchestrator using feeds. The feeds can be configured to be at tenant level, or at folder level. A package published to the tenant feed can then be used in a process in any of the folders. If it is published using a folder feed, it can't be used for processes in other folders.

There are a couple of other Orchestrator entities which exist at the tenant level:

User

Both human users and robots are uniquely identified with users in Orchestrator.

On the Accounts & Groups page, in Automation Cloud, you can define local user accounts, robot accounts, and local groups for your organization.

The level of access and the actions that your users can perform is controlled using two elements:

accounts, which establish the identity of a user and are used to log in to your UiPath applications
roles, which are assigned to accounts in order to grant them certain permissions within the UiPath ecosystem.
Accounts are not created or managed in Orchestrator, only roles and their assignments are.

Machine (Orchestrator)

These are Orchestrator entities corresponding to the workstations where human users and robots work. Using API keys, they enable the connection between the physical or virtual machines and Orchestrator.

License

The right to use Studio and/or Robots, both attended and unattended, is done through licenses. Licenses exist at tenant level, from where they get distributed to users, and consumed when the machines connect to Orchestrator.

Webhook

Webhooks facilitate the communication between Orchestrator and other applications at API level. These are mapped at tenant level, which means they cannot be differentiated between folders and will provide information for the entire tenant.

Folder entities

A folder is a storage area that helps keep your projects separate. From the entities defined at the beginning of the lesson, processes and jobs are folder entities. Packages depend on feed configuration.

Asset

An asset is a piece of data stored in Orchestrator for the use of robots. There are four types of assets:

Text - stores only strings (it isn't required to add quotation marks).
Bool - supports true or false values.
Integer - stores only whole numbers.
Credential - contains usernames and passwords that the Robot requires to execute particular processes, such as login details.
Assets can have a global value or a value per user. This means that only the specified user will access a certain value stored in that asset.

Storage Bucket

Storage buckets are entities used for storing files which can be used in automation projects.

Queue

Queues are containers that can hold an unlimited number of items, storing different types of data.

The process of feeding items to a queue is typically different from the process of processing the queue items, and is handled by different robots.

Trigger

Triggers enable the execution of jobs in a preplanned manner:

Time triggers—they instruct the automation to start at regular intervals.
Queue triggers—they instruct the automation to be activated whenever new items are added to your queues.
Event triggers—they instruct the automation to start whenever a specified event occurs.

Personal Workspaces

A personal workspace is a modern folder available for the dedicated use of a particular attended user. Personal Workspaces make it easy to deploy automations to your own robot, for easy regular execution, with the organizational benefits of logging, visibility, and potential reuse.

They come with the following entities: package feed, machine template, and resources (jobs, assets, logs, queues, etc.).

Roles

Roles are sets of permissions used to control the access of human users and robots to tenant and folder entities.

Each permission is defined from the combination of at least an action type (view, edit, create, and delete) and an entity, be it at the tenant or folder level. For example, you can set up the right to view only the queues in a certain folder, but not the queues from other folders

Logs in Orchestrator

Logs are time-stamped files that contain informational events, errors, and warning messages relevant to the application. The UiPath Platform has logging capabilities for all of its main components. Logs are created locally of every robot and automation action, then sent to Orchestrator from where they can be filtered, viewed, and analyzed.

There are two types of Orchestrator logs:

Diagnostic logs generated by UiPath Orchestrator regarding its behavior.
Execution logs are logs generated by process execution. The Logs page displays logs generated by Robots in all folders you have access to, including logs generated for jobs started through remote debugging sessions. To access it, navigate to the Automations tab from a folder context, and select Logs tab.

Provision an Unattended Robot to Orchestrator

Robot provisioning refers to the process of setting up and configuring robots within Orchestrator.

You can connect your attended and unattended robots to Orchestrator in different ways.

On a high level it involves adding robots to Orchestrator, establishing the necessary connections, and configuring their properties to enable effective management and execution of automation processes.

User and Robot accounts

In Orchestrator, both human users with attended licenses (Robot or Studio) and unattended robots need to have a corresponding Orchestrator user.

Depending on the deployment type and the organizational setup, users are added and managed in different ways:

Users can be added locally in on-premises, standalone Orchestrator.
Users have to be added in Automation Cloud, then in cloud Orchestrator to grant them a license.
Users can be added from Active Directory for both on-premises and cloud Orchestrator if the integration was configured beforehand.
Robot accounts have to be created in Automation Cloud, and they behave like user accounts regarding permissions. The only differences compared to user accounts are:

Robot accounts aren't allowed to have any interactive-related process configuration.
No email address is required to create a robot account.

Automatic robot creation

To simplify the attended and unattended robot creation, as well as the license provisioning, the automation robot creation can be enabled at user level, for both attended and unattended robots, and at group level for attended robots.
Basically, you enable the Attended Robot or Unattended Robot toggle at the account or group level, configure the various settings (robot execution settings, machine login credentials, if applicable), and a floating robot with those attributes is created.

Note: You can only enable attended robot auto-provisioning for user groups, unattended robot auto-provisioning is not possible.

Machine templates

Robots run on physical or virtual workstations. These are mirrored in Orchestrator by entities called machines. The machines in Orchestrator work as API key generators, authorizing the connection between the robots and Orchestrator.

There are two types of machines in Orchestrator:

Machine templates: this allows the connection to multiple workstations with a single API key.
Standard machines: this allows the connection between Orchestrator and a single machine. This is suitable for scenarios in which robots need to run on specific machines.

License distribution

In Orchestrator, licenses are also called runtimes. They're allocated at machine template level, under Machines in the Tenant menu.
The number of runtimes allocated there should be matched with the maximum number of users which can run on a single machine connected using that machine template. On a regular Windows machine, only one user can run. But on a Windows server machine, multiple users can run simultaneously.
Licenses are consumed as soon as a machine is connected to Orchestrator, no matter the number of users running on it.

Use-case/ problem statement

It’s time to take your environment further by provisioning an unattended robot and connecting it to the same Orchestrator using the Client ID in the Assistant. You can set it up on your current machine, but bear in mind that in a real scenario you'll need a different machine (virtual or physical).

In Automation Cloud and Orchestrator:

Navigate to Admin section, in Automation Cloud, and then Accounts & Groups and select the Robot accounts tab.
Click Add Robot Account, give it a name, and click Add..
Navigate to Orchestrator and go to Manage Access at Tenant level.
Click Assign roles and assign the Robot role to your Robot Account under the General details page.
Move to the Unattended setup page and:
Verify that the "Allow unatteded robots to run automations as this robot acocount" option is checked.

 Select the "Use a specific Windows account" option and add your machine login credentials. Click Assign.

Create a machine template under Machines at Tenant level and assign at least one unattended runtime. Here we have the Client ID and Client secret which we'll need a bit later.

Create a new Folder. Assign both the user and the machine template to that folder.

Add a process to the newly created folder, if possible, for a bit of practice.

On the machine where the unattended robot will be deployed:

Open UiPath Assistant.
On the Preferences menu, click Orchestrator Settings.
Select Client ID for the Connection Type.
In the Orchestrator URL field, enter Orchestrator’s web address, such as https://myOrchestrator.uipath.com/.
In the Client ID field, enter the client ID generated by the machine object in Orchestrator.
In the Client Secret field, enter the client secret generated by the machine object in Orchestrator.
Click Connect.

Optional: if you have created a process and successfully deployed the unattended robot, then put your robot to work by running a job.

Unattended Automation with Folders

Functionally, the purpose of attended automation is to have the robots ready to take over the undesirable tasks when the human users need it, in their cycle of work and during work hours.

When it comes to unattended automation, the purpose is quite different: the robot needs to be busy as much as possible, with as little human input as possible.

The use of folders and job priorities

By accurately reflecting the business hierarchies with the help of folders, roles and permissions, we can control the access to automation processes and make sure the effort is spent where it brings the most return. Job priorities can ensure that business priorities are well reflected in the automation process.

The separation of processes based on UI interaction

Processes in Orchestrator are now differentiated between those that interact with the user interface (known as foreground processes) and those that don't, called background or headless processes.

This has a significant impact on the way automation jobs are executed. An unattended robot can simultaneously run a foreground job and as many headless jobs as available runtimes on a machine.

The license allocation per machine

Allocating licenses (runtimes) per machine makes sure that their consumption is optimized. For example, on a Windows Server machine, multiple robots can open sessions and run unattended jobs up to the maximum number of runtimes.

Custom job allocation strategies

Unattended automation was designed in Orchestrator to ensure resource optimization and effectiveness. But there are cases in which business logic is more important. Orchestrator offers a couple of features and options to allow the customization of the job allocation process so that certain jobs or resources are available only to certain users.

See Also: Working with Orchestrator Resources
Source: UiPath Academy

Comments

Popular posts from this blog

How to set Profile Attribute in Siebel Workflow

For setting the Profile Attribute in Siebel Workflow, follow below steps: Add Business Service box in workflow. Open Business Service properties. Set  SessionAccessService in Business Service Name. Set  SetProfileAttr in Method Name. Then click on Business Service and set Input Arguments as below: Against Name argument you will add your profile attribute name and against Value argument you will add value for the new profile attribute, it could be from Process Property or Literal.

How to call Popup Applet through Server Script in Siebel

Background: Based on the requirements you need to show data or reports on a popup applet. You can invoke popup applet using workflow (below business service will be used in business service step), applet server script or browser script and using vanilla method and setting field user properties. Procedure: Below is the script for calling popup applet through server script: if (MethodName == "MethodName") { var oServiceAF = TheApplication().GetService("SLM Save List Service"); var inputPropAF = TheApplication().NewPropertySet(); var outputPropAF = TheApplication().NewPropertySet(); inputPropAF.SetProperty("Applet Name","ABC Popup Applet"); inputPropAF.SetProperty("Applet Mode","6"); inputPropAF.SetProperty("Applet Height", "700"); inputPropAF.SetProperty("Applet Width", "700"); oServiceAF.InvokeMethod("LoadPopupApplet", inputPropAF, outputPropAF) return (CancelOperati...

How to create and publish Inbound Web Service in Siebel based on Workflow

Inbound Web Services: The Inbound Web Service allows an external system to call a Siebel published Web Service. You can publish a business service or a business process as a Web Service and generate a Web Service Definition Language (WSDL) file that an external system can import. The Inbound Web Services can only be published from Siebel C using SOAP-RPC binding. Source: Oracle Docs What Is The Difference Between Web Services and APIs? An API is an interface that allows you to build on the data and functionality of another application, while a web service is a network-based resource that fulfills a specific task. Yes, there’s overlap between the two: all web services are APIs, but not all APIs are web services. Both web services and APIs are — at their core — very useful and very much used today. However, it’s the web services associated with SOAP and/or Service Oriented Architecture which are falling out of favor. Source: NordicApis Process: Prepare the workflow which will serve as Si...