OSISoft PI Setup Guide for Productive Maintenance
This section explain how to configure several components of OSI PI in order to connect to PI servers to retrieve time series data from PI data server.
PI Data Server Connection
The PI data server hosts configuration of PI points, stores values of the PI points and allows PI Web API connect to it and retrieve data from the clients. Make sure your machine can connect to the running instance of the PI data server.
-
Go to the Windows menu items or location of PI system typically located at C:\ProgramData\Microsoft\Windows\Start Menu\Programs\PI System.
-
Run PI system explorer and select Servers menu.
-
If you see Data Server (and Asset Server) are connected no further configuration is required. Otherwise select Tools > Options menu.
-
Check PI Trust, uncheck Windows Security and check Allow login prompt. Then when you try to connect to data server it will prompt you with Windows authentication and your windows credentials.
PI Web API Configuration
The PI Web API needs to be configured to retrieve PI points attributes and values using REST.
-
Go to the Windows menu items or location of PI system typically located at C:\ProgramData\Microsoft\Windows\Start Menu\Programs\PI System.
-
Run PI Web API Admin Utility and connects to the PI Asset Server instance.
-
Select HTTPS port 443 and Firewall exception.
-
Select Bypass Advanced Certification Check.
-
Select account type and account name.
-
Select AF server and database, and data server.
-
Follow the screens to continue configuration and note down the PI Web API url.
Web API System Configuration
This section talks about configuration items which are supported but not configured by default. Follow these steps to configure Web API system:
-
Open PI System Explorer
-
Click on Database and select Configuration
-
Expand Elements / OSISoft / PI Web API / PI_Server_Host / System Configuration, and then click on 'Attributes' tab
-
Configure the following items:
Item | Details | Comments |
---|---|---|
Basic Auth config |
* Select AuthenticationMethods |
Needed to authenticate and connect client to Web API. |
Bulk Request config |
* If you see IgnoreCacheControlForBulkRequests make sure it is set to True |
Needed for value set URL to get data for multiple points |
POST Request config |
* Set EnableCSRFDefense to false |
Needed for POST to work to avoid 403 suite access denied error |
Configure PI Randomizer Interface
Follow these steps to configure the random interface and install it as a Windows service.
-
Run PI Interface Configuration Utility
-
Select Interface > New Windows interface instance from a bat file or from an exe file and browse to Random interface installation directory typically C:\Program Files\PIPC\Interfaces\Random containing random.exe or random.bat file
-
Select Host PI data server and click on add
-
In the general section make sure the point source is R and in the scan frequency, you specify the frequency at which random interface will simulate PI points. You can specify multiple frequencies
-
In the Service section make sure tcp/ip is selected as a dependency
Configure PI Points
PI Interface for Random Simulator Data is installed and configured with PI Data Archive, is an excellent source of test data. You can configure points to generate various types of randomized data. The default point source for this interface is R.
Point builder will allow you to configure PI points. Run PI System Management Tools and select Points > Point Builder . Click on 'New' and provide point details as described in the following sections.
General Tab
-
Name: it must be a unique name across all points, for example, FlowLevel-M23
-
Descriptor: can be used to store some important info such as machine or location where the point is attached
-
Stored Value: how value is stored in data server, select Real-time data
-
Point Source: source of value, for Random interface select R
-
Point Class: select Classic
-
Point Type: data type of the point such as int, float, string, timestamp, blob or digital
-
Digital Set: if the data type is Digital, select the set of value defined in the Digital Set
-
Eng Units: engineering unit of the point being measured, for example, PSI for flow, F for temperature
Archive Tab
-
Typical Value: typical value of the point, for example, 50
-
Zero: minimum value of the point, for example, 10
-
Span: maximum value of the point, for example, 100
-
Make sure the Scan and Archiving are selected On
Classic Tab
The values in the Location 1 to 5, depends on the Data Type, Scan Class of the random interface being used, desired amount of change between each value, and number of value to change before midpoint resets to current value. Note that not all location values are required for each point. For example:
Field | Value | Description |
---|---|---|
Location1 |
||
Location2 |
10 |
If the span is 100, it will allow to change value by 1 in each scan (10*(100/1000)) = 1 |
Location3 |
25 |
After 25 random value it will reset to current value |
Location4 |
1 |
Scan class of PI point. Look at random.bat or Random interface configuration. This says the PI point will be changed as per line 1, so if that is 30 sec, the PI point value will change every 30 seconds. |
Location5 |
1 |
Number from 0 to 5 depending on point data type |
Digital States configuration
When point data type is selected as Digital, its value can be one of those specified in a Digital State.
-
Select Points > Digital States and click on Add icon.
-
Name the set and set of state values with state name.
The result should be a Digital State for a Maintenance Status, which can be 0=Active
and 1=Broken
.
Use PI Web API to Retrieve Attributes and Values of PI Points
Once PI servers, data server, Web API, random interface and PI points are configured you can use PI Web API to retrieve and update point attributes and values from PI server. The Web API provides REST interface to interact with PI server over the web.
The following table describes some of the common endpoints to retrieve PI point information. Note that each points and assets in PI server is identified using a unique webId.
Description | Web API URL |
---|---|
PI Web API home page |
|
Get attributes of all PI points |
|
Get attributes of multiple specified PI points |
|
Get value of a specific PI point |
|
Get values of multiple specified PI points |
|
Get attributes of multiple specified PI points using POST method |
POST: |
Get data values of multiple specified PI points using POST method |
POST: |
PI Point Configuration for this Use Case
This use case measures vibration delta, temperature, oil level, noise level, and maintenance status of several machines. The following table describes the configuration of these PI points for one machine.
Attribute | Point1 | Point2 | Point3 | Point4 | Point5 |
---|---|---|---|---|---|
General Tab |
|||||
Name |
Vibration Delta |
Temperature |
Oil Level |
Noise Level |
Maintenance Status |
Descriptor |
Machine1 |
Machine1 |
Machine1 |
Machine1 |
Machine1 |
Stored Values |
Real-time data |
Real-time data |
Real-time data |
Real-time data |
Real-time data |
Point Source |
R |
R |
R |
R |
R |
Point Class |
classic |
classic |
classic |
classic |
classic |
Point Type |
Int32 |
Int32 |
Int32 |
Int32 |
Digital |
Digital Set |
MachineStatus |
||||
Eng Units |
Hz |
F |
Percentage |
Decibels |
|
Display Digits |
|||||
Archive Tab |
|||||
Typical Value |
500 |
125 |
50 |
115 |
1 |
Span |
1000 |
160 |
100 |
160 |
1 |
Zero |
10 |
90 |
0 |
70 |
0 |
Scan |
On |
On |
On |
On |
On |
Archiving |
On |
On |
On |
On |
On |
Classic Tab |
|||||
Location1 |
|||||
Location2 |
|||||
Location3 |
100 |
100 |
100 |
100 |
|
Location4 |
1 |
1 |
1 |
1 |
1 |
Location5 |
2 |
2 |
2 |
2 |
1 |
Misc |
|||||
Data Type |
Station Data |
Station Data |
Station Data |
Station Data |
Random Data |
Scale |