TrakHound DataClient reads MTConnect® streams and sends the data to TrakHound DataServers to be stored.
TrakHound DataClient and DataServer are designed specifically to store MTConnect® data in a database. Nearly all MTConnect data is stored with its original terminology in database tables for data storage or to use with cloud applications.
The TrakHound DataClient and DataServer applications provide the manufacturing community with a Free and Open Source alternative so anyone can start collecting valuable machine data that can be used to analyze and improve future production in the upcoming years that will dominated by the IIoT. TrakHound provides you the tools to collect MTConnect data in near raw form and to store that data for later use. Even if you don't see the need for this data now, you may in several years and will wish you had previous year's data to compare. Prepare for tomorrow by getting started with TrakHound today!
- Automatically finds and configures MTConnect devices on a network
- Data filtering with triggers to collect all data or only what is needed
- Ability to send data to multiple TrakHound DataServers to create data redundancy or to meet data security requirements (local vs cloud)
- Utitlizes streaming connections for both MTConnect and connections to TrakHound DataServers
- Supports SSL(TLS) for sending data to TrakHound DataServers
- Non-volatile buffering to retain collected data between connection interruptions
### Data Storage **MTConnect Agents by themselves are not storage applications.** This is made clear in the MTConnect Standard. Instead the purpose of MTConnect Agents is to serve data to client applications when requested. While the Agent does keep a small buffer, this buffer is not intended to be used for data storage but rather to retain data between connection interruptions. TrakHound fulfills the role of requesting this data and then storing it in a database for permanant storage. Data is stored which can then be accessed by other TrakHound applications, ERP/MES systems, third party software, or by reading the database directly using software such as Microsoft Access.
Although the MTConnect Agent is a server application itself, most situations require Incoming connections where the application accesses the Agent directly which requires firewall exceptions and since many Agents run on the machine contol itself this would mean each machine would need to accessible from outside networks (usually undesirable for security reasons). TrakHound solves this issue by centralizing the data onto a single server which can either be accessed using the TrakHound API over HTTP/HTTPS or directly to the database itself. Since all of the MTConnect data is now Outgoing as opposed to Incoming, machine controls can stay isolated from external networks while a single DataServer accepts incoming requests.
One of the main goals of TrakHound is to provide tools to securely collect data so that no matter what restrictions your industry requires, you can still benefit from data analysis to improve your manufacturing processes. TrakHound fully supports SSL(TLS) encrypted connections for the DataClient -> DataServer connections as well as the API access. When used with a trusted SSL Certificate, data is sent securely just as online banking/payments are sent.
By centralizing the point where data is accessed, TrakHound also allows internal machine networks to stay isolated from external networks to prevent both unauthorized data access and possible viruses from effecting the machine controls themselves.
Each TrakHound DataClient can also filter data to only send specific data to certain DataServers. This can be used to only send status data to a cloud server used for machine status monitoring, while sending ALL data to a secure onsite server.
Of course, the biggest security benefit to using TrakHound is that it is Open Source and the source code can be reviewed to insure exactly what data is being collected and to make sure that no other data is being sent anywhere it shouldn't be.
# Data Format Data is sent to the DataServer(s) in the form of JSON using the below format:
{
"stream_data_type": 1,
"device_id": "16223e3b-670b-425a-ba2f-8f8bfaa7cbe5",
"address": "192.168.1.15",
"port": 5001,
"physical_address": "01-23-45-67-89-ab"
}
{
"stream_data_type": 2,
"device_id": "16223e3b-670b-425a-ba2f-8f8bfaa7cbe5",
"timestamp": 1486941244000,
"instance_id": 1485218744,
"sender": "mtcagent",
"version": "1.3.0.9",
"buffer_size": 131072
}
{
"stream_data_type": 3,
"device_id": "16223e3b-670b-425a-ba2f-8f8bfaa7cbe5",
"agent_instance_id": 1485218744,
"id": "dev",
"uuid": "000",
"name": "VMC-3Axis",
"sample_interval": 10.0,
"sample_rate": 0.0,
"iso_841_class": "6"
}
{
"stream_data_type": 4,
"device_id": "16223e3b-670b-425a-ba2f-8f8bfaa7cbe5",
"agent_instance_id": 1485218744,
"parent_id": "dev",
"type": "Axes",
"id": "ax",
"name": "Axes",
"sample_interval": 0.0,
"sample_rate": 0.0
}
{
"stream_data_type": 5,
"device_id": "16223e3b-670b-425a-ba2f-8f8bfaa7cbe5",
"agent_instance_id": 1485218744,
"parent_id": "cn1",
"id": "estop",
"category": "EVENT",
"type": "EMERGENCY_STOP",
"sample_rate": 0.0,
"significant_digits": 0
}
{
"stream_data_type": 7,
"device_id": "16223e3b-670b-425a-ba2f-8f8bfaa7cbe5",
"timestamp": 1486941044659,
"agent_instance_id": 1485218744,
"id": "estop",
"sequence": 389526903,
"cdata": "ARMED"
}
# DataServer Response Each item of data sent to the DataServer should be separated by a new line ('\r\n') and each item is validated by the DataServer for correct format. The DataServer will respond with a **200**, **400**, or **401** code representing Success, Bad Request Format, and Authentication Failed. This sequence happens for each item in order to insure data integrity.
Note : Code 401 (Authentication Failed) only occurs when using the TrakHound Cloud DataServer which requires an ApiKey for authentication.
# Buffer A Buffer is used to store data that was unsuccessfully sent to the DataServer in the case of a temporary loss of connection. The buffer is composed of multiple csv files. By storing the buffer on the filesystem (as opposed to in memory), this makes the buffer 'non-volatile' and is automatically recovered on power loss. This system insures that data is never lost and allows for easy DataServer maintenance.
# MTConnect The DataClient application uses MTConnect in order to retrieve data from devices. Operations are performed using the MTConnect.NET library which utilizes a streaming connection.
# Configuration Configuration is read from the **client.conf** XML file in the following format:
<?xml version="1.0" encoding="utf-8" ?>
<DataClient>
<!--List of configured MTConnect Devices to read from-->
<Devices>
<Device deviceId="0307f8be-5be9-4c14-85a6-8a2a9c9223db" address="agent.mtconnect.org" port="80" deviceName="VMC-3Axis"/>
</Devices>
<!--Configuration for finding MTConnect Devices on the network-->
<DeviceFinder scanInterval="3600000">
<!--Specify Port Range-->
<Ports minimum="5000" maximum="5020"/>
</DeviceFinder>
<!--Configuration for sending data to TrakHound DataServers-->
<DataServers>
<DataServer hostname="192.168.1.15" port="8472" useSSL="true">
<!--Data Buffer Directory to buffer failed transfers until sent successfully-->
<Buffer path="Buffers"/>
<!--Define the data to send to DataServer-->
<DataGroups>
<!--Ignore constantly changing samples-->
<DataGroup name="monitor" captureMode="ARCHIVE">
<Deny>
<Filter>BLOCK</Filter>
<Filter>LINE</Filter>
<Filter>BLOCK</Filter>
<Filter>POSITION</Filter>
<Filter>PATH_FEEDRATE</Filter>
<Filter>PATH_POSITION</Filter>
<Filter>ROTARY_VELOCITY</Filter>
</Deny>
<Include>
<DataGroup>snapshot</DataGroup>
</Include>
</DataGroup>
<!--Take a snapshot of All dataitems-->
<DataGroup name="snapshot" captureMode="INCLUDE">
<Allow>
<Filter>*</Filter>
</Allow>
</DataGroup>
</DataGroups>
</DataServer>
</DataServers>
</DataClient>
List of configured MTConnect Devices to read from.
<Devices>
<Device deviceId="0307f8be-5be9-4c14-85a6-8a2a9c9223db" address="agent.mtconnect.org" port="80" deviceName="VMC-3Axis"/>
<Device deviceId="TY3FNQCZKM3R2V0WWI9H3AUISLW" address="192.168.1.198" port="5000" deviceName="Haas_Device"/>
<Device deviceId="KGI13AOQSUERHF1XVQSFWLDIBS" address="192.168.1.198" port="5001" deviceName="OKUMA.Lathe"/>
<Device deviceId="RVJGKEA9ZXUPUIGFVMTQP98L0UY" address="192.168.1.198" port="5006" deviceName="OKUMA.Lathe"/>
<Device deviceId="UPSFKO6IBDAEOPSFEHLGAIMLCM" address="192.168.1.198" port="5003" deviceName="OKUMA.MachiningCenter"/>
<Device deviceId="UXJGZKSQS9DIEY7JQ912RS7Q4" address="192.168.1.198" port="5002" deviceName="OKUMA.Grinder"/>
</Devices>
The globally unique identifier for the device. When detected automatically, the Device ID is a hash of the device's DeviceName, port, and MAC address. The MAC address is used so that MTConnect Agents can use DHCP while still being identified as the same device. If manually added, always use a GUID.
The DeviceName of the MTConnect Device to read from
The base Url of the MTConnect Agent. Do not specify the Device Name in the url, instead specify it under the deviceName attribute.
The TCP Port of the MTConnect Agent.
Configuration for finding MTConnect Devices on the network. If omitted, the network will not be scanned and no devices will be automatically found or configured.
<DeviceFinder scanInterval="5000">
<!--Specify Port Range-->
<Ports minimum="5000" maximum="5020">
<Allow>
<Port>5120</Port>
</Allow>
<Deny>
<Port>5002</Port>
<Port>5003</Port>
<Port>5007</Port>
</Deny>
</Ports>
<!--Specify Address Range-->
<Addresses minimum="192.168.1.100" maximum="192.168.1.120">
<Allow>
<Address>192.168.1.198</Address>
</Allow>
<Deny>
<Address>192.168.1.110</Address>
<Address>192.168.1.102</Address>
</Deny>
</Addresses>
</DeviceFinder>
The interval (in milliseconds) at which the network will be scanned for new devices. If omitted, the network will only be scanned when the DataClient is initially started. Note: If needed at all, it is recommended to keep this interval set high since the network will receive a Ping on all nodes which can lead to Anti-Virus/Security software flagging the application.
Used to filter the ports to scan. If omitted, the default port range of 5000 - 5010 will be used.
The minimum in the range of ports to search
The maximum in the range of ports to search
List of Ports that are specifically allowed to be searched. Allowed ports override the range and denied ports.
List of Ports that are specically denied and not allowed to be searched.
Used to filter the IP addresses to scan. If omitted, all reachable IP addresses within the subnet will be scanned.
The minimum in the range of addresses to search
The maximum in the range of addresses to search
List of Addresses that are specifically allowed to be searched. Allowed addresses override the range and denied addresses.
List of Addresses that are specically denied and not allowed to be searched.
Represents each TrakHound Data Server that data is sent to in order to be strored.
<DataServers>
<DataServer hostname="192.168.1.15" port="8472" useSSL="true">
<!--Data Buffer Directory to buffer failed transfers until sent successfully-->
<Buffer>Buffers</Buffer>
<!--Define the data to send to DataServer-->
<DataGroups>
<!--Ignore constantly changing samples-->
<DataGroup name="monitor" captureMode="ARCHIVE">
<Deny>
<Filter>BLOCK</Filter>
<Filter>LINE</Filter>
<Filter>BLOCK</Filter>
<Filter>POSITION</Filter>
<Filter>PATH_FEEDRATE</Filter>
<Filter>PATH_POSITION</Filter>
<Filter>ROTARY_VELOCITY</Filter>
</Deny>
<Include>
<DataGroup>snapshot</DataGroup>
</Include>
</DataGroup>
<!--Take a snapshot of All dataitems-->
<DataGroup name="snapshot" captureMode="INCLUDE">
<Allow>
<Filter>*</Filter>
</Allow>
</DataGroup>
</DataGroups>
</DataServer>
</DataServers>
The hostname of the TrakHound Data Server to send data to
The port to send data to the TrakHound Data Server on. If omitted, the default 8472 will be used.
The hostname of the TrakHound Data Server to send data to. If omitted, the default of False will be used.
The Api Key used to authenticate when using the TrakHound Cloud DataServer. An ApiKey will be assigned to your user account when created at www.TrakHound.com.
Data Buffer Directory (relative or absolute path) to buffer failed transfers until sent successfully. If omitted, no buffer will be used and may result in "lost" data.
DataGroups allow configuration for what data is captured and sent to the DataServer. Data is filtered by Type or by their parent container type. DataGroups can include a list for allowed types as well as for denied types. A CaptureMode can also be defined to configure when the data in the DataGroup is sent.
<DataGroups>
<!--Collect ALL Data-->
<DataGroup name="all" captureMode="ARCHIVE">
<Allow>
<Filter>*</Filter>
</Allow>
</DataGroup>
</DataGroups>
The identifier for the DataGroup. This is primarily used when the DataGroup is being included in another group.
The mode in when data is captured.
- ARCHIVE : Capture all data and add to DataServer's archived_samples table (permanent storage)
- CURRENT : Only capture the most current data. Similar to the MTConnect "Current" request. Can be used to minimize data storage space when only needing the current data. This data is stored in the DataServer's current_samples table.
- INCLUDE : Only capture data when included in another DataGroup using the "Include" list (see below).
A list of Types and Ids to capture. This can also include container paths with the wildcard character (*) to allow any types or ids within the container.
- ID : DataItem/Component/Device Id to allow (case sensitive)
- TYPE : DataItem/Component/Device Type to allow. Can be in the format of "PATH_FEEDRATE" or "PathFeedrate".
A list of Types to not capture. This overrides any allowed types.
A list of other DataGroups to include when capturing for the current DataGroup. For example, this can be used to capture position data only when another group changes in order to reduce the amount of data stored in the DataServer's database.
Filters specify the path to either allow or deny. Below are examples of accecptable syntax:
-
***** (All types/ids)
-
EmergencyStop (Any DataItem with the type of EMERGENCY_STOP) *Note: either format can be used "EmergencyStop" or "EMERGENCY_STOP"
-
cn2 (Only the DataItem with the ID of "cn2")
-
Controller/* (All types/ids WITHIN any component of type Controller)
-
Controller/Path/* (All types/ids WITHIN any component of type Path that is also within a Controller component)
-
Controller/Path/cn3 (Only the DataItem with the ID of "cn3" that is within Path component that is also within a Controller component)
-
c1/* (All types/ids WITHIN the component with the ID of "c1")
Watch for when new "Status" data items are received within a Controller component that isn't listed under the Deny list. DataItems are denied that change constantly such as the current program line/block, feedrate, etc. When a new item is found, include the DataGroup "all". This essentially takes a snapshot of the entire device whenever one of the "Status" items is changed.
<!--Ignore constantly changing samples-->
<DataGroup name="monitor" captureMode="ARCHIVE">
<!--List the Denied Filters (Denied Filters override Allowed)-->
<Deny>
<Filter>BLOCK</Filter>
<Filter>LINE</Filter>
<Filter>BLOCK</Filter>
<Filter>POSITION</Filter>
<Filter>PATH_FEEDRATE</Filter>
<Filter>PATH_POSITION</Filter>
<Filter>ROTARY_VELOCITY</Filter>
</Deny>
<!--List the additional groups to include when current group is captured-->
<Include>
<DataGroup>snapshot</DataGroup>
</Include>
</DataGroup>
<!--Take a snapshot of All dataitems-->
<DataGroup name="snapshot" captureMode="INCLUDE">
<!--List the allowed Filters-->
<Allow>
<Filter>*</Filter>
</Allow>
</DataGroup>
Only collect the most current data. Can be used for
<DataGroup name="current" captureMode="CURRENT">
<Allow>
<Filter>*</Filter>
</Allow>
</DataGroup>
Only collect data for a single DataItem with the type of "EXECUTION".
<DataGroup name="execution" captureMode="ARCHIVE">
<Allow>
<Filter>EXECUTION</Filter>
</Allow>
</DataGroup>
Only collect axis data.
<DataGroup name="axes" captureMode="ARCHIVE">
<Allow>
<Filter>Axes/*</Filter>
</Allow>
</DataGroup>
Only collect data when the DataItem of type EMEGENCY_STOP is changed.
<DataGroup name="all" captureMode="INCLUDE">
<Allow>
<Filter>*</Filter>
</Allow>
</DataGroup>
<DataGroup name="estop" captureMode="ARCHIVE">
<Allow>
<Filter>EmergencyStop</Filter>
</Allow>
<Include>
<DataGroup>all</DataGroup>
</Include>
</DataGroup>
Starting the DataClient with the 'debug' command line argument runs the DataClient as a Console Application instead of a Windows Service. This mode can be used for quickly debugging issues or for testing and development.
Starting the DataClient with the 'install' command line argument installs the DataClient as a Windows Service.
Starting the DataClient with the 'uninstall' command line argument uninstalls the DataClient's Windows Service.
Dependency Name (License)
- RestSharp (Apache 2.0)
- Json.NET (MIT)
- NLog (BSD 3-Clause)
- MTConnect.NET (Apache 2.0)
- TrakHound-Api (Apache 2.0)