Solution Execution and Runtime designate the active stage where a Solution operates. This involves the utilization of functional Modules, data acquisition and processing, updating visual displays, and carrying out other tasks in accordance with the solution's specified configuration.
The runtime environment consists of all the Modules loaded and operating according to the solution configurations. This setup is directed by Execution Profiles, which guide the solution's connections and actions. These profiles enable the same solution configuration to interface with various databases and devices, accommodating different phases such as Development, Validation, or Production.
A distinct feature of this runtime framework is its Online Configuration, which supports real-time adjustments to an actively running solution without causing any disruption to its execution. Additionally, Hot Updates facilitate the seamless integration of offline solution changes, ensuring flexibility and adaptability in the continuing runtime environment.
On this page:
The purpose of the Runtime and Solution Execution is to actively operate the configured Solutions, execute real-time data-acquisition, scripts, alarms, and all Solution configured items from all Modules. It is an essential and final phase of the Solution development, effectively delivering its functionality.
The term Runtime, or Runtime environment, refer to the execution environment operates. It is used to do a differentiation from the Configuration (or Engineering, or Development) phase. The term Runtime is also use to refer the software components and computer processes in execution.
An execution profile is a set of configurable settings that allows customization during runtime of Database Connections, Device Network addresses, facilitating the management of different environment. It allows to setup the connections used during the Development, Validation and Production phases, to their settings, still having only solution configuration file.
This feature enables real-time modifications to be made to a running solution without stopping its execution. It allows users to adapt the solution to changing requirements, improving flexibility and responsiveness.
Hot updates are a subset of online configuration, permitting the application of offline solution changes without disrupting the runtime environment. They are essential for maintaining solution stability and avoiding downtime while ensuring the solution stays up-to-date with the latest changes.
The build and publish process involves compiling solution code and creating a read-only version of the solution, which can be distributed to end-users. This step is critical in ensuring the solution is ready for deployment and accessible to the intended audience.
When the solution is in execution, the realtime-variables for the application, i.e. Tags, Templates, Assets, are loaded into memory, and it acts as central point of reference, to other functional modules can request values from those variables, or publish values, as they perform its function.
The computer process and executable responsible to hold the Real-time database is the TServer.Exe.That application can as a Windows Service, or it can be deployed to Linux and other supported operating systems.
The are various ways to start the execution of a Solution. You can start it manually by going to the Runtime→Startup page. The various other ways to setup its execution are detailed in the chapter Deploying the Application.
When you click on the Start button on the Designer interface, the follow steps are executed:
This utility is a solution loader, it will read the Solution Configuration for Startup, accordingly the Execution Profile selected, parse \ command line parameters, and active the main process TServer.exe
The TServer.EXE starts, loading solution objects, tags, templates, assets, into memory, and a communication service is stablished allowing other modules to start and connect for that.
The other modules defined to start, like Historian, Alarms, Devices, Scripts, Datasets and Reports, start their execution, reading the the solution configuration and establish connection with the main process.
When the modules are starts they will behave according the definitions on the Execution Profiles. For instance, you can estou that in Development mode, you use a temporary local SQLite database for your alarm records, and on the Production mode, the Alarm Database is automatically mapped to a SQL server.
The Solution designer automatically connects to the running solution, allowing users to monitor progress, make adjustments, and troubleshoot issues as needed using the Monitor and Diagnostics pages.
The Operations display, using HTML5 from any type of Browser, or high performance WPF graphics pages can be opened from any remote computer connected with the server.
During execution, the system can apply online configuration changes and hot updates without disrupting the runtime environment. This capability enables users to adapt the solution to changing requirements and maintain high system availability..
The Solution Runtime Environment is isolated from the development and configuration processes to maintain stability and prevent interference between the two.
This separation allows for smooth operation during runtime and facilitates troubleshooting and modifications during the development process.
It also allows you to easily open multiple solutions during the configuration phase.
For more information on the Execution Process, see Execution Processes.
The Runtime Section in the Solution Designer allows to the define the settings to start the execution the application, perform solution verification and backup, and diagnostic the execution.
The User interface for Runtime configuration, is composed by four sub-section that will be covered in this chapter. They are:
Those parameters define which Profile the solution will use, Communication Ports and other settings. It allows to control the starting and stopping of the execution, as well the Online Configuration.
Startup Parameters | |
---|---|
Field | Description |
Enable Online Configuration | Select in order to your changes to immediately apply to the test runtime. You must also be connected to the running solution (see status setting above). |
Execution Path | Overrides the default execution path, which is the solution file location. |
Startup Parameters | |
---|---|
Field | Description |
Module Information | Runs the Module Information tool. |
Password | Enter the password that corresponds to the username. |
Port | Displays the port that FactoryStudio uses for access. For test, it uses 3201. For startup, it uses 3101. These ports must be open on the server. |
PortWA | Displays the port that FactoryStudio uses for access with Windows Authentication. For test, it uses 3202. For startup, it uses 3102. These ports must be open on the server. |
Solution Server | Read-only. Displays the IP address or the name of the computer where the solution is, which is based on the configuration in the Server tab. |
Property Watch | Runs the Property Watch tool. |
Run Modules | Select which modules are executed when running the solution. |
Startup Computer | Read-only. Displays whether or not the configured server is the local computer or a remote server. |
Status | Shows the current status of running, connected, or disconnected.
|
Trace Window | Runs the TraceWindow tool. |
Use only Windows Authentication | Checks if the system can only accept Windows Authentication. |
UserName | Enter a valid username to access the application. |
Startup Port Settings | |
---|---|
Field | Description |
Enable Online Configuration | Select in order to your changes to immediately apply to the test runtime. You must also be connected to the running solution (see status setting above). |
Execution Profile | An execution profile is a set of configurable settings that allows customization during runtime of Database Connections, Device Network addresses, facilitating the management of different environment. It allows to setup the connections used during the Development, Validation and Production phases, to their settings, still having only solution configuration file. |
Startup Port Settings | |
---|---|
Field | Description |
Auto Ports | ---------------------- |
Main Port | Displays the port that FactoryStudio uses for access. For test, it uses 3201. For startup, it uses 3101. These ports must be open on the server. |
WA Port | Displays the port that FactoryStudio uses for access with Windows Authentication. For test, it uses 3202. For startup, it uses 3102. These ports must be open on the server. |
Windows Authentication | Checks if the system can only accept Windows Authentication. |
Web Port | Checkbox to enable a webport in the solution. By default use port 80. |
Windows Service | Setup Solution to start as a Windows Service. Current Status: Remove Service and Apply Service. |
Execution Environment | |
Field | Description |
Local Computer | The Solution is launched locally on the local computer. |
Solution Server | Read-only. Displays the IP address or the name of the computer where the solution is, which is based on the configuration in the Server tab. |
Path/Use Solution Path | Used by the system to allow one station to automatically update the solution in the redundant pair when doing online solution changes and HotStart commands. Example: /SolutionIPPath:192.168.0.1;C:\FactoryStudio\Solutions\test.tproj. |
Startup Modules | Select which modules are executed when running the solution. |
Redundancy Enabled | |
Field | Description |
Primary Server IP/Port | Enter the IP address and port of the primary server. |
Secondary Server IP/Port | Enter the IP address and port of the secondary server. |
Timeout | Connection timeout time, in seconds. If reached, this will cause the system to switch to the secondary server. |
On Primary Startup |
|
Replication |
|
You can use Enable Online Configuration to apply changes in real-time. All changes must be saved before they can appear on a screen. |
Development and testing profiles are used to manage different environments within a solution. These profiles enable developers to work on new features, bug fixes, or improvements while keeping the production environment stable. By configuring separate profiles for development and testing, teams can maintain code quality and avoid deploying untested changes to the live environment. This separation also facilitates the debugging process and helps to identify issues that may arise during development.
Execution profiles are a vital aspect of managing solutions on our software platform, as they enable users to configure and run solutions with different settings tailored to specific environments or stages of development. The latest release introduces three primary execution profiles:
Production: This profile is designed for use in live environments, where the solution is fully functional and serves end-users. It optimizes performance and stability while minimizing the system's resource usage. Debugging and development tools are generally disabled or limited in this profile to ensure seamless operation.
Development: The development profile is tailored for solution creation, testing, and iteration. It enables a wide range of debugging and diagnostic tools to assist developers in identifying and resolving issues during the development process. While performance might not be fully optimized in this profile, the focus is on providing a robust environment for developers to build and refine their solutions.
Validation: The validation profile is intended for use during the final stages of solution development, such as quality assurance and user acceptance testing. It provides a balance between the development and production profiles, enabling necessary debugging tools while maintaining a level of performance and stability suitable for testing. This profile helps ensure that the solution meets its requirements and performs as expected before being deployed to a production environment.
You can learn more about each of the profiles at Execution Profiles.
Diagnostics on runtime execution are essential for monitoring a solution's performance, identifying potential issues, and ensuring overall stability. By implementing logging, performance metrics, and error reporting, developers can gain valuable insights into the execution process. These insights can be used to troubleshoot problems, optimize performance, and maintain system health. Effective diagnostic tools are crucial for maintaining a reliable and high-performing solution.
For more information on Diagnostics, see Diagnostics Tools.
Publishing read-only versions of a solution is crucial for maintaining a stable production environment while allowing developers to work on new features and bug fixes. The process involves preparing the solution for publication, creating a snapshot or branch, building and testing the solution, packaging the build, marking it as read-only, and deploying it to the production environment.
This approach reduces the risk of unintentional changes, simplifies rollback processes, and separates development and production environments. Adhering to best practices like regular release scheduling, using version control, thorough testing, documentation, and clear communication ensures a smooth and efficient publishing process for read-only versions.
To learn more, visit Build and Publish.
Working with the runtime is a key aspect of software development, as it involves managing the execution of a program while it's running. This includes starting and stopping the execution, switching execution profiles, and applying configuration changes. This comprehensive guide provides an overview of best practices and techniques for efficiently working with the runtime.
To start the solution execution, you need to launch the application or server, depending on the solution type. It's essential to monitor the system for any errors or issues during startup, as they may prevent the application from running correctly.
To stop the solution execution, you can use the appropriate command or interface provided by the runtime environment or the application itself. Make sure to gracefully shut down the application to avoid data loss or corruption.
To start the solution is production mode,
There are a few customizations you can do on how the solution shall be executed, such as if the solution will run in your local computer or start in a remote Server computer, which modules will be loaded, and some other settings described in this section.
Run | Startup Computer options | |
---|---|
Field | Description |
Local | The TStartup (solution ) is launched locally on the local PC |
SolutionServer | The This option is only enabled if the solution was opened from a remote SolutionServer. |
On Run → Modules, you should see two options regarding the displays affected by this setting:
Displays
is selected - A RichClient is opened on the solution server when the solution is startedLocalDisplays
is selected - A RichClient is opened on local PC when the solution is startedThere are a few ways to stop the running Solution. All those options assume the current user has Security Authorization to shutdown the solution. For information on Security, refer to Security, Users and Roles.
Manually stopping the Solution Execution | |
---|---|
Where | Description |
Windows Trail icon | Locate the Icon TServer, right click and select stop. |
Solution Designer | On Runtime → Startup or Runtime → Execution Profiles, connect the solution <<icon>> and click Stop. |
TStartup application | When the solution starts running, a startup status windows is presented (TStartup.exe application). A shutdown button is available at that window. |
File → Shutdown | If the menu is enabled on the Operator Displays, there is the option File → Shutdown. |
Command in the Solution | The property |
Closing the Window running the displays DOES NOT stop the solution execution. All Modules (alarms, devices, etc.) keep running in background; only the Display Module is closed. Closing the Windows is equivalent to trigger the property Client.Shutdown , in opposition to Server.Shutdown . |
Configuration changes can be applied to the runtime environment to modify the behavior of the application. These changes can include modifying settings, adding or removing modules, or adjusting resource allocation. To apply configuration changes, follow these steps:
Runtime issues can occur during the execution of the application, such as crashes, performance problems, or unexpected behavior. To troubleshoot these issues, follow these steps:
In this section: