Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Confirm your Snowflake resources (databases, stored procedures, user defined functions, roles, warehouses, etc) have been successfully created by the script execution.

IoT Bridge Setup

Log into the Chariot Web UI and navigate to 'Certificates' under IOT Bridge for Snowflake as shown below:

Image Added

Click 'UPLOAD FILE' and upload the private key previously generated (rsa_key.p8). Confirm it is uploaded as shown below:

Image Added

Now navigate to 'Servers' under IOT Bridge for Snowflake as shown below:

Image AddedNow click 'Add Server' which will bring up the following dialog:

Image Added


Change the following fields leaving all others default:

  • Name = Chariot MQTT Server
  • Username = admin
  • Password = changeme
    • If you have changed the password of the Chariot MQTT Server username, use whatever you set it to
  • URL = tcp://localhost:1883
    • Note we're using a local non-secure connection for this tutorial. If this were a production system connecting to a remote MQTT Server, TLS should be used.
  • Sparkplug Client ID = IBSNOW-testing-client
  • Verify Hostname = false

Save the configuration and confirm a new Server appears in the list as shown below:

Image Added

Now navigate to 'IoT Bridge for Snowflake → Configuration' on the left navigation panel as shown below:

Image Added

Modify the following properties leaving all others default:

  • General → Snowflake Sparkplug MQTT Application Enabled = true
  • General → Primary Host = IamHost
  • Notify → Notify Database Name = cl_bridge_node_demo_db
  • Notify → Notify Warehouse Name = cl_bridge_ingest_demo_wh
  • Streaming Profile → User = IBSNOW_DEMO_INGEST
  • Streaming Profile → URL = https://ACCOUNT_ID.snowflakecomputing.com:443
    • Replace ACCOUNT_ID with your Snowflake account ID
  • Streaming Profile → Account = ACCOUNT_ID
    • Replace ACCOUNT_ID with your Snowflake account ID
  • Streaming Profile → Private Key = PRIVATE_KEY_FILE_NAME
    • Replace PRIVATE_KEY_FILE_NAME with the filename of your private key file (i.e. rsa_key.p8)
  • Streaming Profile → Host = ACCOUNT_ID.snowflakecomputing.com
    • Replace ACCOUNT_ID with your Snowflake account ID
  • Streaming Profile → Database = cl_bridge_stage_demo_db
  • Streaming Profile → Connect String = jdbc:snowflake://ACCOUNT_ID.snowflakecomputing.com:443
    • Replace ACCOUNT_ID with your Snowflake account ID
  • Streaming Profile → Warehouse = cl_bridge_ingest_DEMO_wh
  • Streaming Profile → Role = cl_bridge_process_DEMO_rl

Once you've made these changes, save the configuration and navigate to the 'Status' tab under IoT Bridge for Snowflake.

At this point, make sure the trial license is running or you've purchased a license for the system. Also, ensure you've restarted IoT Bridge for Snowflake. If you have not done so, the 'RESTART SNOWFLAKE' banner will be present as shown below.

Image Added


Once the trial is running and the configuration is saved, you should see the IoT Bridge for Snowfalke is connected to the Chariot MQTT Server as shown below.

Image Added


Edge Setup with Ignition and MQTT Transmission

Install Ignition and MQTT Transmission module

At this point IoT Bridge is configured and ready to receive data. To get data flowing into IBSNOW we'll set up Inductive Automation's Ignition platform along with the MQTT Transmission module from Cirrus Link.

Installation of Ignition is very straightforward following the instructions in the Installing and Upgrading Ignition guide.

With Ignition installed, the Cirrus Link MQTT Transmission module must be installed as a plugin to Ignition. Follow the instructions in our Module Installation guide

Import UDTs and tags

Launch the Ignition Designer to connect to your Ignition instance.

Once it is launched, navigate to the 'default' tag provider in the Tag Browser, expand the tag tree to see the automatically created tags as shown below and delete tags Example Tag and MQTT Quickstart.Image Added

from the Designer import these tags IBSNOW_Quickstart_tags.json to MQTT Tags > PLC 1 create a UDT Definition and instance.


Review the Ignition Exporting and Importing Tags document if needed

You can view the imported UDT Definition and instance in the tag browser:

Image AddedImage Added

At this point, our tags are configured. A UDT definition will map to a model in Snowflake and UDT instances in Ignition will map to Snowflake.

But, before this will happen we need to point MQTT Transmission to the Chariot MQTT Server. To do so, browse back to the Ignition Gateway Web UI and select MQTT Transmission → Settings from the left navigation panel.

Now select the 'Transmitters' tab as shown below.Image Added

Now click the 'edit' button to the right of the 'Example Transmitter'. Scroll down to the 'Convert UDTs' option and uncheck it as shown below. This will also un-grey the 'Publish UDT Definitions' option. Leave it selected as shown below.Image Added

Now switch to the 'Servers' and 'Settings' tab. Delete the existing 'Chariot SCADA' pre-seeded MQTT Server Definition. Then create a new one with the following configuration.

  • Name
    • Chariot MQTT Server
  • URL
  • Username
    • Your username for the Chariot MQTT Server connection
    • If using Chariot MQTT Server, the default username is 'admin'
  • Password
    • Your password for the Chariot MQTT Server connection
    • If using Chariot MQTT Server, the default password is 'changeme'

When complete, you should see something similar to the following. However, the 'Connected' state should show '1 of 1' if everything was configured properly.Image Added

At this point, data should be flowing into Snowflake.

By tailing the log in IBSNOW you should see something similar to what is shown below which shows IBSNOW receiving the messages published from Ignition/MQTT Transmission.

When IBSNOW receives the Sparkplug MQTT messages, it creates and updates asset models and assets in Snowflake. The log below is also a useful debugging tool if things don't appear to work as they should.



Successful Insert

<TBD>

Data will also be visible in Snowflake at this point. By changing data values in the UDT tags in Ignition DDATA Sparkplug messages will be produced. Every time the Edge Node connects, it will produce NBIRTH and DBIRTH messages. All of these will now appear in Snowflake with their values, timestamps, and qualities.

Review the IBSNOW: Viewing the data in Snowflake document for details on the DB tables and views available