ClearSCADA 2013R1 Design Guidelines
ClearSCADA 2013R1 Design Guidelines
ClearSCADA 2013R1 Design Guidelines
Wastewater Application Starter Project A new application example is included within the Example Projects to provide a foundation for development of a real-world Wastewater Lift Station. This example leverages the close integration of the SCADAPack E RTU objects and includes sample IEC 6-1131 logic for the SCADAPack 334E RTU. This project will be used as the basis for examples of topics discussed within this document. This icon is used to provide a demonstration of the current topic within the SCADA Expert ClearSCADA sample database.
Further Information Further information is available with the Schneider Electric Telemetry & Remote SCADA Solutions Resource Centre: http://resourcecentre.controlmicrosystems.com This icon is used to link directly to a relevant article within the Schneider Electric TRSS Resource Centre.
Ver 1.0
Page 2 of 26
Scope
In addition to the ClearSCADA background information, the guidelines within this document will focus on the following areas: System Design Mimic Design Server Performance o Historic Storage o Use of Logic Client Performance o Use of Mimic Cache o Mimic Scripting
Ver 1.0
Page 3 of 26
Ver 1.0
Page 4 of 26
Individual Driver Modules o These processes are installed as required and include optional features such as DNP3 Modbus Crystal Reports OPC ODBC NTP, etc o Each of these individual driver modules are run as a separate driver module executable (e.g. DriverDNP3.exe) and are run only when the server is running as Main, however also have a DLL module loaded by DBServer at startup time which defines the objects for that driver. o These drivers are each responsible for the implementation of their specific objects within the database. When these objects are used to interface with equipment external to ClearSCADA, these modules are also responsible for the implementation of the required protocol, and therefore the connection of the internal database objects to the associated field devices. o These separate drivers can be monitored within the WindowsTM Task Managers Process tab, as each driver will be listed when it is operational.
Ver 1.0
Page 5 of 26
Database Structure While not directly impacting system performance, the database structure and design has a large impact on overall operability and user experience. The following database design guidelines are considered good-practice: Structure the database hierarchy based on physical or logical groupings of equipment, for example; o Asset Type (e.g. Water / Wastewater / Reuse / etc.) o Geographical Area (e.g. North / South / East / West) o Station Name or Identifier o Plant Area (e.g. Inlet Works / Sludge Dewatering etc.) o Equipment (e.g. Pump / Flow Meter / SCADA Equipment / etc.) Avoid repetition of the same word within an objects FullName; o E.g. Water.Northern Region.Pump Station 1.Pump 1.Pump Running o E.g. Wastewater.Southern Region.Lift Station 1.Wet Well.Well Level Avoid selecting a point name that describes a state of the point; o E.g. use Pump 1.Run State instead of Pump 1.Running o E.g. use Peer.Communications State instead of Peer.Communications Fault
Templates should be used within the database hierarchy to represent common equipment where possible, as this simplifies future maintenance and can assist with hierarchy design as all configuration (points, graphics, etc.) associated with a particular piece of equipment will be located within its template. Furthermore, instances of multiple templates can be combined as required within other templates which then represent complete sites or plant areas.
Ver 1.0
Page 6 of 26
The Example Projects section is broken up by Industry (Electricity, Oil & Gas, Water/Wastewater), and then further by individual areas and/or sites. The Wastewater Application sites are organised into equipment using templates where possible to inherit common configuration.
Archiving
Archiving is an important feature of ClearSCADA, allowing users to create an external backup of historical data providing long-term offline storage. In summary, historic data and event messages are kept in the database only for a specified number of weeks after which time they are deleted. The total amount of time for which historic data and event messages are stored is referred to as the Keep Online time. To avoid losing data, you must ensure that archiving takes place before the end of the Keep Online time, configured within Server Configuration as shown below.
Ver 1.0
Page 7 of 26
The archiving process will require effort on the part of ClearSCADA to process and copy the historic data, therefore archiving should be performed on a Standby server to ensure that the main server remains available for normal database operation. The archive is a manual process that can be configured on a schedule to suit your needs, however the archiving process should be performed frequently (e.g. every other week) to ensure that the amount of data archived each time is kept manageable. It is recommended that each periodic archive is stored in a new location (identified by the archive date, for example) to allow for selective restoration of specific periods of historic data.
Alarm Banner Display When an object within the database generates an alarm, the FullName of this object is used within the Alarm Banner as the source of the alarm. As the length of the object FullName increases, either by adding hierarchy levels or extending the name of each hierarchy level, the Alarm Banner source description is lengthened, and can become unmanageable. For this reason care should be taken when designing the database hierarchy to keep hierarchy levels and length of names to a minimum. As an alternative to the FullName, ClearSCADA supports configuration of an Alarm Source (within the Alarm tab of configuration form). This property is then used in lieu of the FullName within the Alarm Banner display, provided that the Alarm Source is unique within the database. Reuse of Common Configuration In addition to the database hierarchy that represents the grouping of equipment, it is recommended to include also a configuration group which contains all common objects including templates, symbols, colours, scripts, reports, security configuration, etc. These common configuration objects can then be referenced as required within the rest of the database. Since this common group contains all important configuration items, it simplifies the implementation of database security as it can easily be hidden from view except for authorised users/groups. It is important to create and reference colour objects within the database instead of explicitly configuring a specific colour within the mimic design, as this provides the ability to quickly and easily adjust the database colour scheme by reconfiguring a few colour objects. Without the use of colour objects, potentially each individual mimic would have to be re-configured to achieve the same result.
Ver 1.0
Page 8 of 26
Time Synchronisation To ensure each ClearSCADA server has an accurate representation of time, synchronisation should be implemented with an external source. This can be handled automatically by the Domain Controller within an Active Directory environment, although for remote or distributed architectures this is not always possible. An alternative is to utilise Network Time Protocol (NTP) to manage the time synchronisation, whereby the WindowsTM Operating System is configured to synchronise with a networked NTP server. In this scenario ClearSCADAs NTP Monitor driver can be configured to monitor the accuracy of the time synchronisation and generate an alarm if the local server time deviates too far from the NTP source.
Metadata ClearSCADA includes the ability for additional fields to be added to configurable locations within the existing database tables, and can be used to store links to other database items, lists, strings, check boxes, etc. that are specific to your system. Since Metadata fields need to have unique names within each database table, care should be taken to select names specific to your system. Consider the scenario whereby a future version of ClearSCADA is expanded or a new driver installed which includes a database field that conflicts with one of your existing metadata fields but is used for a different purpose. Potential mass reconfiguration would be required within your database to rename and re-align all of your references accordingly. To avoid this consider prepending a project/customer acronym to the beginning of the field name, for example: sePointReference for a new point reference field as part of a Schneider Electric project.
Ver 1.0
Page 9 of 26
System Monitoring ClearSCADA includes a variety of measures to monitor the operation and performance of the ClearSCADA system and its hardware which should be implemented to ensure correct operation and better diagnose potential causes of underperformance.
1. Performance Monitor The Performance Monitor driver (sometimes referred to as NTMon) is used to monitor various aspects of server performance on a ClearSCADA system. This is best implemented to monitor Operating System metrics including: CPU Usage o Overall (DBServer.exe) and process specific (e.g. DriverDNP3.exe) monitoring available. o It may be pertinent to monitor the DBServer application and the most commonly utilised communications driver. HDD Free Space RAM Usage (Available Virtual Memory / DBServer memory usage) Page File Usage Network Usage System Uptime
At certain times it may be useful to record additional metrics due to specific behaviours of your system, for example if youre noticing occasional disk performance issues you could monitor the disk queues. Performance Monitor points have been implemented within the Diagnostics page of the ClearSCADA Product Life Cycle presentation. These points currently monitor CPU usage, available RAM, free disk space and average bytes per disk write.
Ver 1.0
Page 10 of 26
2. ClearSCADA Status (via OPC) Operation of the ClearSCADA server can be monitored via OPC points within ClearSCADA. Monitoring can be performed of any network-connected ClearSCADA server, and therefore can include all partnered servers in a redundant architecture. Monitoring of ClearSCADA server operation should include: Server Name Server State (Main / Standby) Server State Change Time Server Type (Lone Server, Dual/Triple Standby, Permanent Standby etc.) Standby Server Synchronisation Status (of Configuration, Data, History, etc.)
The Diagnostics page of the SCADA Expert ClearSCADA Product Life Cycle presentation monitors the status of the local server via OPC, although since this is only monitoring of the local server the information is available directly from the OPC database explorer and no database points are required. Currently monitored are server name, server state, server type, and time when the server came online.
3. SNMP The Simple Network Management Protocol (SNMP) is a simple protocol for managing devices on an IP network, and should be used to monitor the status of important networking devices including routers, switches, printers, UPS (uninterruptable power supplies), as well as internal server components including HDDs and RAID adapters. ClearSCADAs SNMP driver supports SNMP version 1.
4. ICMP ClearSCADAs ICMP Driver can also be used to determine the connectivity of critical network components within an IP network including routers, printers, operator workstations, etc. SNMP polls should be implemented to capable devices in lieu of ICMP if this is not permitted within the SCADA network.
Ver 1.0
Page 11 of 26
Mimic Design
Efficient Mimic Design ClearSCADA provides a comprehensive set of features for graphical user interface design. If used poorly they can potentially cause performance problems, therefore unnecessary use of the following features should be avoided: Use of Indirect Referencing. Use of graphical enhancements: o transparent or semi-transparent animation o gradient shading o Fast Update feature o Excessive object movement Excessive use of polylines, particularly where lots of separate lines are used where a single segmented line or curved line could be used to create the same effect. Large number of objects within the mimic. Images (jpg, png, bmp) embedded directly into mimics. Large number of embedded mimics, including: o Number of parameters for each embedded mimic o Whether embedded from individual instance/group or common symbol o Multi-level embedded mimics (embedded mimics containing embedded mimics containing) o Any of the above graphical enhancements implemented within the embedded mimics Excessive use of tooltips, especially those that implement complex calculations from database items. Hidden objects or layers. o Layers or objects that are hidden are still loaded into memory on mimic load, which increases the load time even though they may not be immediately displayed. Mimic_Navigate or Mimic_Load scripting that performs database calls.
In summary; as the overall complexity of the mimic increases, so will the load time, therefore the aim of the designer should be to balance mimic functionality with complexity. The Wastewater Application uses simple, non-gradient fill colours to match the relevant process colour in this case wastewater. The embedded mimics are limited to one level where possible, and only two levels elsewhere to simplify the implementation (the well, for example). The Schneider Electric logo and other illustrations are all created as vectorised graphics, instead of embedded images, as these are stored and accessed much more efficiently.
Ver 1.0
Page 12 of 26
The faceplates are instantiated from a default template to inherit common configuration, and contain a combination of embedded mimics to display the data as required. Each transmitter and pump faceplate contains a link to an associated Historic Data Access faceplate. These faceplates exist within a common area and are linked to with parameters to populate their configuration, rather than existing pre-configured in every single template instance as would otherwise be required. Trends are not directly embedded onto the main overview mimic; instead links are used to provide quick access from the Mimic Header and within each Faceplate. In this way, the trend is only displayed when requested and doesnt impact mimic load time. The trend buttons provide a dynamic list of trends, such that as new trends are added to the database they will automatically appear in the list next time it is accessed.
Embedded Mimics The use of embedded mimics is recommended wherever multiple copies of the same symbol are required, rather than separately managing multiple copies independently. There are two main implementation strategies for embedded mimics; 1. Creating animated symbols within templates and embedding these as required on mimics, or 2. Embedding parameterised symbols directly onto the mimic and animating as required. Because each mimic object within ClearSCADA maintains its own copy within the local disk cache, it is preferable to design overview mimics that reference embedded mimics from a common symbol with parameters, instead of embedding animated mimics from a template instance. This implementation method isnt always possible, although should be preferred when many of the same source mimic are embedded onto a single overview mimic display. Of course, either of the above embedded mimic implementations is highly recommended over separately maintaining multiple independent copies. The Mimic Header is embedded from a common symbol whereas the Site Menu section (buttons Alarms, Events, Notes, Trends, Reports) is separately embedded from a template instance as it needs to be located within the site hierarchy for the links to work properly.
Ver 1.0
Page 13 of 26
The Pumps and Transmitter symbols are embedded direct from common symbols to reduce mimic disk cache, although they have Shared with Other Embedded Mimics unchecked as they include hover actions which would otherwise not animate properly (and hence are separately loaded into the embedded mimic cache).
Mimic Properties Dialog Pin A little-known ability of the Mimic Properties dialog box is that it can be pinned so that it will remain open when selecting between multiple mimic objects (or the mimic itself), meaning that the dialog is not repeatedly closed and re-opened. This can be used to enhance the mimic design experience and make the implementation of mimics more efficient. The following image shows the Mimic Properties dialog box highlighting the ability to pin the window open.
Ver 1.0
Page 14 of 26
Server Performance
Logic Programs Care should always be used when implementing logic programs within ClearSCADA; logic is run as a single-threaded core process and requires the database to be static during each cycle of execution. For this reason temporary locks are applied on the database in conjunction with the execution of logic applications. This is usually seamless and goes unnoticed by the user if the logic application executes quickly, however complex logic programs (those containing loops, SQL queries, nested execution etc.) can cause noticeable periods of server freezing or unavailability. To avoid unnecessary repeated executions, logic programs should, where possible, only be executed On Input Processed rather than executed periodically on a specific interval. Ensure that any actions performed within On Input Processed logic programs do not write to any of the associated input variables of that program; else an infinite logic execution loop will be created. This includes Refresh actions which update variables. Care should also be used when implementing logic programs within templates. Implementation of logic within templates isnt a problem in itself provided the above logic guidelines are followed, although heavy instantiation of templates containing logic can affect performance. For more information see: http://resourcecenter.controlmicrosystems.com/x/twJG
Within the Wastewater Application the Trio Radio VSWR (Voltage Standing Wave Ratio) calculation is performed using logic. This logic is configured to run On Input Processed i.e. only when one of the inputs has changed.
Historical Storage of History and Events Having an historical record of past system events and operations is arguably one of the most valuable tools provided by SCADA systems, second only to the real-time operational ability it provides. While the capturing of history is of value, users should be careful not to store excessive amounts of historical data as this can compromise the operational performance of the system. It is strongly recommended that each database point is limited to a maximum sustained rate of 4 historic records per minute. The length of time which history and event data can be kept online can vary between different ClearSCADA servers, allowing for Permanent Standby / Performance servers to store large amounts of historic data for long-term and reporting access, while not consuming resources on the Main/Standby servers. SCADA Expert ClearSCADA 2013 R1 Design Guidelines Ver 1.0 Page 15 of 26
Systems with storage of important historical information should utilise the Archive feature, configurable within the Server Configuration application. The Archive after setting is disabled by default, but allows historic data to be considered read-only after the configured time period and synchronised more efficiently to Standby servers. For more information see: http://resourcecenter.controlmicrosystems.com/x/YIA3
Server Logging The ClearSCADA server includes built-in logging of all server actions to ensure complete traceability in the event of any server problems. There are multiple logging streams within ClearSCADA; one for the main server process, and one additional stream for each separate driver module. These logs are enabled by default, although are configured to provide history of two x 2 MB log files per stream which is usually insufficient for production installations. The logs for each stream are generated in a FIFO-type arrangement where the oldest log file is removed and replaced with the new one when the maximum number of log files is reached. It is recommended that the number and/or size of log files for each stream is increased (as required for your system) to be capable of spanning at least 2-3 days to ensure that events occurring over the weekend, for example, still remain within the active logs for review if required. Consideration needs to be given to the capacity of the logging location used for large production environments as the server log files can be generated quickly which could potentially require hundreds of MBs of storage. The following image shows the Server Configuration options, highlighting those that we recommend should be increased as required for your system.
Ver 1.0
Page 16 of 26
Note that additional logging options within the ClearSCADA Server Status application (not demonstrated here) should not be modified except under direction from a Schneider Electric ClearSCADA Support Engineer. For more information see: http://resourcecenter.controlmicrosystems.com/x/O4Lo
Ver 1.0
Page 17 of 26
Client Performance
Embedded Mimic Cache ViewX contains an embedded mimic cache which is maintained for each session of ViewX only; the cache is purged when ViewX is shutdown. When a mimic that contains an embedded mimic is displayed, the embedded mimic is loaded into memory on the client PC (into the embedded mimic cache). The cache for that embedded mimic can then be accessed locally by any other mimic that contains the same embedded mimic. Embedded mimics that do not have the Shared with other embedded mimics option checked will not be stored within the common cache, but instead each embedded mimic object will occupy a separate area of memory. The memory for each of these non-shared embedded mimics has to be separately loaded and unloaded each time the main mimic is displayed. The embedded mimic cache size can be managed via the Tools Options dialog box within ViewX. To help minimize potential loss of performance, ClearSCADA will attempt to remove unused embedded mimics from the cache if the amount of memory being used reaches the defined cache limit. When the limit is reached, ClearSCADA will remove the embedded mimic files for any embedded Mimics that are not currently on display, starting with the oldest files first. However, ClearSCADA can only remove the files for embedded mimics that are not currently being displayed on mimics. When making changes to the size of the embedded mimic cache, you can examine the effects by using the View feature for the embedded mimic (available on the Options window). This allows you to see whether embedded mimic files are being loaded in and out of the cache. We recommend that you only change the embedded cache size if specifically advised to do so by a Schneider Electric ClearSCADA Support Engineer.
Mimic Disk Cache The ViewX client manages a mimic cache on its local disk to reduce network load between the server and the client. The first time a mimic is loaded from the server is it stored in the local cache, and all subsequent requests for this mimic are retrieved from the local cache after confirming that no recent changes have been made to the server copy. The following occurs each time a ViewX client requests a mimic from the server (including all embedded mimics): Read version of the mimic from the server Check server version against local cached mimic version If mimic doesnt exist in cache or version incorrect, read mimic from server into local cache Uncompress cached mimic and load into ViewX
Ver 1.0
Page 18 of 26
Its important to remember that ClearSCADA maintains a local copy of each mimic object within the disk cache; this includes all symbols and mimics instanced within templates. Because of this, complex mimics which contain many embedded mimics require more effort to load as each individual embedded mimic first needs to have its version checked against the server copy (and transferred if the server copy has been updated) before the main mimic can be displayed. As the number and/or complexity of embedded mimics grows, so does the load-time for these mimics, especially when accessing the ClearSCADA server via highlatency and/or low-bandwidth links.
Mimic Scripts The ClearSCADA client-side Visual Basic (VB) scripting interface allows users to create scripts that provide useful functionality specifically tailored to their requirements, for example; implement navigation features, display dialog boxes, create user interface forms etc. While ClearSCADA gives users the flexibility of placing script behind each mimic, or even within the configuration of a mimic button itself, this can often result in duplication of code which quickly becomes difficult to maintain. It is recommended that script libraries are implemented where possible to allow re-use of common code within the entire ClearSCADA database, ensuring that any required maintenance or upgrades are as simple and costeffective as possible. Mimic scripts implemented within the Wastewater Application are all implemented within a Script Library; these scripts are referenced when required instead of being duplicated which simplifies any future changes.
It should be noted that mimic scripts access the ClearSCADA server via the web port (default port 80), not the standard ViewX port. If you are experiencing issues with client-side scripting, check that the web port is not in use by another application and available for use by ClearSCADA, visible with the Server Status application. The following image shows an invalid configuration where ClearSCADA is unable to use the http web port, therefore scripts will fail to execute.
Ver 1.0
Page 19 of 26
Ver 1.0
Page 20 of 26
More Information
The ClearSCADA Online Help is a great first resource and contains information on resolving common system problems. Browse the contents for Core Reference Server Status Tool Common System Problems, or search for "Common System Problems". Further information is also available with the Schneider Electric Telemetry & Remote SCADA Solutions Resource Centre: http://resourcecentre.controlmicrosystems.com
Ver 1.0
Page 21 of 26
SD1
Implement server redundancy for production environments. Implement Permanent Standby servers to remove ViewX / WebX client load from the Main/Standby servers. Limit excessive storage of history on the Main/Standby servers; instead implement long-term storage in the Permanent Standby servers only. Structure the database hierarchy based on physical or logical groupings of equipment. Avoid repetition of the same word within an objects FullName.
SD2
SD3
SD4
SD5
SD6
Avoid selecting a point name that describes the state of the point. Use templates within the database hierarchy to represent common equipment to simplify maintenance. Create common configuration objects within a central configuration area and reference as required. These common objects should include templates, symbols, colours, scripts, reports, security configuration etc. Reference colour objects instead of explicitly configuring colours directly within mimics. Implement Time Synchronisation (e.g. via Domain Controller or NTP) within the ClearSCADA servers to ensure that each server has an accurate clock. Ensure added Metadata field names are very specific so as to reduce likelihood of future conflict with additional drivers/modules. Implement system monitoring to track system operation, including:
SD7
SD8
SD9
SD10
SD11
o o o o
/ 11
Ver 1.0
Page 22 of 26
Mimic Design
Guideline Number Guideline Adherence to guideline
MD1
Do not use Indirect Referencing. Limit the use of the following graphical enhancements:
MD2
o o o o
transparent or semi-transparent animation gradient shading Fast Update feature moving animations
MD3
Limit the use of tooltips which reference values of multiple database items. Do not make excessive use of polylines. Ensure that polygon shapes are simple, using as few segments as possible. Ensure that imported vector graphics are simplified as much as possible. Ensure that single segmented lines or curved lines are used in place of separate lines. Reduce, as far as possible, the number of objects on the mimic. Create common symbols and reference these multiple times within each mimic, instead of creating multiple copies of individual objects. Where possible, ensure that all embedded mimics have Shared with other embedded mimics checked. Where possible use embedded mimics that are sourced direct from a common symbol and animated with appropriate parameters, instead of creating graphic(s) within a template and embedding the graphic from each instance onto the mimic. Reduce the number of levels within embedded mimics (a mimic embedded in a mimic embedded in a mimic). Configure common visibility settings for a specific layer and place relevant objects on this layer, instead of individually controlling visibility on multiple objects.
MD4
MD5
MD6
MD7
MD8
MD9
MD10
MD11
MD12
MD13
Ver 1.0
Page 23 of 26
Guideline Number
Guideline
Adherence to guideline
MD14
Vectorised graphics are used in lieu of embedded images (jpg, png, bmp) directly onto the mimic. If images are required use remote images hosted by ClearSCADAs web server. Do not display unbounded queries from large datagrids that reference updating database variables. Avoid Mimic_Navigate or Mimic_Load scripting that performs database calls.
MD15
MD16
/ 16
Ver 1.0
Page 24 of 26
Server Performance
Guideline Number Guideline Adherence to guideline
SP1
Limit the use of FOR or WHILE loops within logic programs. Limit the use of chained execution (program A calls program B, which calls program C) of logic programs. Where possible, execute logic programs On Input Processed rather than on interval. Use caution when implementing SQL queries within logic programs; ensure that all queries are appropriately bounded. Avoid implementing SQL queries within logic that reference either the historical or event database. The amount of data in these stores grows quickly when in operation, and can cause extended delays to the execution of the logic. Avoid implementing logic with heavily instantiated templates. Implement historic compression or significant change deadbands to restrict logging for historic points to below absolute maximum of 4 records per minute for each point. Increase maximum number of server log files to allow spanning of minimum of 2-3 days to allow historic review of server operation.
SP2
SP3
SP4
SP5
SP6
SP7
SP8
/8
Ver 1.0
Page 25 of 26
Client Performance
Guideline Number Guideline Adherence to guideline
CP1
Consult a Schneider Electric ClearSCADA Support Engineer to adjust the mimic cache size (within the guidelines) to suit the requirements of your system. Limit the use of Shared with other embedded mimics when using embedded mimics, where possible. Implement Script Libraries where possible to enable re-use of common VB script code.
CP2
CP3
/3
Ver 1.0
Page 26 of 26