Comments (5)
I added working code in the commit 251d54d to branch lost-conn. I haven't merged it in yet as I'm not sure how I feel about it. On the plus side, it should definitely work. Keep-alive and Exec'ing a nop in the WaitForNotification loop did not detect lost connections (in a reasonable amount of time) on my linux workstation when physically pulling the network cable. This goes back to the previous discussion about TCP keep-alive being highly variable across platforms. This new approach uses read deadlines and should behave correctly and consistently across platforms.
It works as is, but I'm curious if what is really needed is package wide lost connection / timeout management. Because it is still possible in Query/Exec to block until keep-alive finally did its thing. I'm not sure exactly what that would look like, so maybe this should just be merged in for the time being. It doesn't expose any public methods/values so it can be changed freely later...
from pgx.
Oh, I also updated https://github.com/jackc/pgx_notify_lost_connection to use this new version and it does show it working.
from pgx.
What are your concerns about this code?
from pgx.
No functional concerns, just wasn't sure how it felt stylistically. Wasn't sure if I liked having to adjust the SetReadDeadline in the middle like that. I'll probably merge it in a day or two, just wanted to let it sit a little and come back later with fresh eyes.
from pgx.
Rebased and merged in 5edd660.
from pgx.
Related Issues (20)
- How to connect to Redshift using pgx?
- Ever Increasing number of Go routines with Pgx v5.5.5 and CockroachDB HOT 5
- Allow registering a callback after current transaction commits HOT 2
- Support scanning time type into string HOT 2
- Param overriding doesn't work for some fields HOT 1
- Allow defining `tls.Config.CipherSuites` HOT 1
- Custom JSON marshal/unmarshal HOT 3
- change of tenant for multi tenancy using pgxpool is not working HOT 4
- Should pgxpool be closed after each use during the life time of the program? HOT 2
- Running Query Is Not Cancelled on Context Cancelled HOT 4
- Request for guidance on tracing and logging HOT 5
- Prepare doesn't support named arguments HOT 3
- Why the row affected still have no zero even field in column are not updated actually same value
- Accessing replies in pipeline mode without a sync HOT 3
- Cannot scan into custom composite type (CockroachDB) HOT 1
- Provide improved support for loading types HOT 4
- allow configuring the Config directly, without having to call `ParseConfig` HOT 3
- time.Time and timestamp HOT 5
- panic on scanning to slice of custom types HOT 2
- Interval of 0s is invalid HOT 4
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from pgx.