Modbus Server Driver

I finally got around to doing version 2.0 of the Modbus library I maintain, and in the course of developing a more usable server API than the 1.0 version had I figured it would be useful to "dogfood" the API.

So here's a Modbus Server driver for Ignition: https://github.com/kevinherron/modbus-server-driver

There's a signed module available in the releases section: https://github.com/kevinherron/modbus-server-driver/releases/tag/v1.0.0-RC1

This isn't an official IA module. Aside from some unit and integration tests I've done some cursory poking at it, but nothing like the QA it would receive as an official module, so caveat emptor. It may have more value simply serving as a more complete example of how to use the Device API.

9 Likes

I like this.

How well will this map to v8.3?

I appreciate that you dropped one-based addressing... :grin:

2 Likes

It will require some changes to be 8.3 compatible, I'll make an 8.3 branch that demonstrates the necessary changes and how to do config migration (whenever we are "public" or "beta").

If your drivers still use the Driver interface, however, this is not at all representative of the amount of work you have ahead of you. The Driver interface is no longer public in 8.3, and the extension points supporting them have been removed. All drivers must use the Device interface.

Yes, I'm aware. I've blocked out Q4 for v8.3 module updates. I intend to go directly from v8.1 Driver to v8.3 Device.

1 Like

I don't think it's actually all that hard. Just different method signatures and implementations of what are otherwise the same core concepts: browse, read, write, subscribe

Neat, nice tests :wink:

2 Likes

Amazing !
I think I have a usecase, perhaps out of scope
We have an existing application from another scada that we convert to Ignition.

This application is connected to some modbus PLC, and those PLC accept only one TCP connection.

We would like to connect Ignition to the PLC on the same time to be able the check both HMI have the right data.

Perhaps we could connect Ignition to the PLC with the Modbus client driver
and connect the other SCADA to Ignition Modbus server.
Do you have planned to "connect" this module with ignition modbus client driver to be able to share the data ?

Other SCADA (master)
|
Modbus TCP
|
Ignition (master and slave)
|
Modbus TCP
|
PLC (slave)

You could accomplish that now with some tag change scripts, not sure what it would look like to try and do it automatically.

If you don't mind a little programming a better solution might be to use the Modbus library I linked and build your own "Modbus TCP to TCP Gateway"... it would be pretty trivial I think. On one side you maintain a single client connection to the PLC, on the other you receive as many Modbus TCP connections as you want, and you just proxy/pass the requests on down to the slave. Could be wrapped up and deployed via docker in no time.

2 Likes

Ok I see, that will be the best solution. The only drawback is it will double the numbers of request to the PLC.

The most straightforward implementation would, yes.

You can get as creative as you like, though. If you know ahead of time all the registers that both SCADA systems will read then your gateway could read them at whatever pace you define, update a cache, and then server the incoming client requests out of that cache. Lots of options.

Or can you just weave it all together with the server driver :man_shrugging:

1 Like

A complete implementation of your use case with my alternate driver is shown over here:

Does not require double tags. Optionally takes advantage of the common address patterns between the IA driver and my server driver to minimize the configuration required.

One of its users has precisely the same motivation as you: expose a device that accepts only one connection to multiple consumers.

3 Likes

Any kepware salesfolk saddened by this thread, I'll buy you a beer at ICC to cheer you up.

1 Like