Julian Feinauer created PLC4X-132:
-------------------------------------

             Summary: [S7] Communication to S7 PLC dies in some situations
                 Key: PLC4X-132
                 URL: https://issues.apache.org/jira/browse/PLC4X-132
             Project: Apache PLC4X
          Issue Type: Bug
          Components: Driver-S7
    Affects Versions: 0.4.0
            Reporter: Julian Feinauer


The following is from the Mailing Thread [1]:

In the last weeks we observed multiple times strange behavior when connecting 
to Siemens S7 devices.
We have not yet been able to trace it down entirely but I have the assumption 
that it is an issue with the PooledPlcDriverManager.

Whats the issue?
When doing requests (either via OPM or the “regular” API) we come at a point 
where all subsequent requests simply fail (and in some cases we were no longer 
able to send requests to the PLC from other instances, so it looks like the 
internal server went down).

Whats the setup?
When I remember correctly, all situations where this occurred used the Pool as 
Basis.
We had it both with OPM and the normal API but NOT with the Scraper.

I remember that I spent like a hole day at the Hackathon in Mallorca to get all 
timeout things to work correctly, as the S7 does not like when you simply 
cancel your request futures.
Currently there are two “suspects” from my side.

First, the pool calls the “.connect()” method on a now Connection it 
establishes but by API convention you also have to do that in your code so it 
gets called multiple times, which could fuck up stuff.
Second, connection can also time out (but its no future in our API) so in the 
Scraper I implemented it as Future with timeout (as I’m unsure how everything 
behaes if the pool starts to initialize a connection but then the “waitTime” 
times out and it abandons this).

[1] 
https://lists.apache.org/thread.html/328a6780b34b4fd2e3298e9e70340293ebb397b1978a7b631030067e@%3Cdev.plc4x.apache.org%3E



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to