Comments (4)
EnumCodec
(and any Codec
for that matter) is not expected to be concurrency safe. How is this being used?
from pgx.
Hi, sorry for the long delay here.
We're getting this error when reading from a table that has a column who's type is a custom enum (created with create type T as enum (X, Y, Z)
. Attached is a slightly longer stack trace showing that the error is originating from a DB read (ReadPaymentInstrument
just does a select * from table where ...
), which calls pgxpool.Pool.QueryRow
.
From the trace, it looks like reading from a table that has a custom enum column calls EnumCodec.DecodeValue
, which calls the non-concurrency-safe method lookupAndCacheString
. Our service performs multiple reads concurrently - do you know of anything between QueryRow
and lookupAndCacheString
that would prevent concurrent calling of the latter?
Thanks
from pgx.
Every connection gets its own type map and set of codecs. EnumCodec is not concurrency safe -- but I wouldn't have expected it to be possible for it to be used concurrently. 🤔
from pgx.
Okay thanks that's interesting information. I'll dig a bit more into our setup and see if I can reproduce a minimal example
from pgx.
Related Issues (20)
- Discussion: Improve pgx.CollectRows to dynamically allocate sufficient slice capacity to avoid memory reallocations HOT 2
- pgtype.ArrayCodec should support non-comma delimiter HOT 2
- Support for require_auth configuration parameter HOT 1
- Security: Uncaught Exception Violation found by Snyk HOT 3
- RowToStructByName, Lax and Pos not working with `db:"-"` tag HOT 1
- Examples or documentation for "WHERE field IN $1" - should be "WHERE field IN ($1)" HOT 1
- Tracelog truncation can make output longer.
- dangling transactions after 'failed to deallocate cached statement' errors HOT 1
- Clarify ErrIsClosed return type in docs HOT 1
- v4.18.3 Security vulnerability CVE-2024-27289 HOT 2
- Running lib/pq and pgx in the same code base? HOT 1
- Cannot scan/insert user defined UUIDs.
- Memory Leak doing INSERT on High-Load service HOT 1
- Transaction is committed when ctx times out HOT 11
- Constructor function for pgtype.Interval or additional comments HOT 4
- pgtype: enable deep copy of pgtype.Map HOT 1
- Scanning a timestamp with timezone converts to local timezone HOT 3
- cannot scan timestamp (OID 1114) in binary format into *string HOT 1
- Query execution stuck until idle-in-transaction timeout
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.