Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

PostgreSQL client crash on connection pools #394

Closed
andrewhotlab opened this issue Dec 7, 2024 · 5 comments
Closed

PostgreSQL client crash on connection pools #394

andrewhotlab opened this issue Dec 7, 2024 · 5 comments
Assignees

Comments

@andrewhotlab
Copy link

andrewhotlab commented Dec 7, 2024

Trying to establish a connection pool via TCP/IP with a PGSQL server using a client installed from pkgsrc in a OmniOS r151052 pkgsrc zone, the client crashes and a core dump is generated:

root@jail04:~# /opt/local/bin/pgbench -c 1 -j 1 -h 192.168.0.2 -U synapse synapse                                      
Password: 
pgbench (14.15)
starting vacuum...end.
transaction type: <builtin: TPC-B (sort of)>
scaling factor: 1
query mode: simple
number of clients: 1
number of threads: 1
number of transactions per client: 10
number of transactions actually processed: 10/10
latency average = 13.081 ms
initial connection time = 45.227 ms
tps = 76.447339 (without initial connection time)

root@jail04:~# /opt/local/bin/pgbench -c 2 -j 2 -h 192.168.0.2 -U synapse synapse
Password: 
pgbench (14.15)
starting vacuum...end.
Assertion failed: section != NULL, file prof_tree.c, line 528, function profile_node_iterator
Abort (core dumped)

root@jail04:~# mdb core
Loading modules: [ libumem.so.1 libc.so.1 ld.so.1 ]
> ::status
debugging core file of pgbench (64-bit) from jail04
file: /opt/local/bin/pgbench
initial argv: /opt/local/bin/pgbench -c 2 -j 2 -h 192.168.0.2 -U synapse synapse
threading model: native threads
status: process terminated by SIGABRT (Abort), pid=11238 uid=0 code=-1
libc panic message: Assertion failed: section != NULL, file prof_tree.c, line 528, function profile_node_iterator
> $C
fffffc7feed7cee0 libc.so.1`_lwp_kill+0xa()
fffffc7feed7cf10 libc.so.1`raise+0x22(6)
fffffc7feed7cf60 libc.so.1`abort+0x58()
fffffc7feed7d1d0 0xfffffc7fef066d62()
fffffc7feed7d270 0xfffffc7f9eef1e78()
fffffc7feed7d300 libkrb5.so.3.0.3`profile_iterator+0x113(fffffc7feed7d318, 0, fffffc7feed7d320)
fffffc7feed7d380 libkrb5.so.3.0.3`profile_get_value+0xd7(507d90, fffffc7feed7d3a0, fffffc7feed7d398)
fffffc7feed7d430 libkrb5.so.3.0.3`profile_get_boolean+0x68(507d90, fffffc7f9ef27c38, fffffc7f9ef274c2, 0, 0, fffffc7feed7d454)
fffffc7feed7d4c0 libkrb5.so.3.0.3`krb5_init_context_profile+0xf4(0, 0, fffffc7feed7d508)
fffffc7feed7d5d0 libgssapi_krb5.so.2.0.2`acquire_cred_from.isra.0+0xac()
fffffc7feed7d720 libgssapi_krb5.so.2.0.2`gss_add_cred_from+0x5b3(fffffc7feed7d7c4, 504790, 0, 504760, 1, 0)
fffffc7feed7d880 libgssapi_krb5.so.2.0.2`gss_acquire_cred_from+0x250(fffffc7feed7d90c, 0, 0, 0, 1, 0)
fffffc7feed7d8e0 libgssapi_krb5.so.2.0.2`gss_acquire_cred+0x20(fffffc7feed7d90c, 0, 0, 0, 1, fffffc7feed7d910)
fffffc7feed7d940 libpq.so.5.14`pg_GSS_have_cred_cache+0x49(4817e0)
fffffc7feed7e010 libpq.so.5.14`PQconnectPoll+0x14aa(481310)
fffffc7feed7e080 libpq.so.5.14`connectDBComplete+0x135(481310)
fffffc7feed7e0c0 libpq.so.5.14`PQconnectdbParams+0x38(fffffc7feed7e100, fffffc7feed7e140, 1)
fffffc7feed7e190 doConnect+0xe9()
fffffc7feed7efb0 threadRun+0x1e2(509ed8)
fffffc7feed7efe0 libc.so.1`_thrp_setup+0x77(fffffc7feeb70240)
fffffc7feed7eff0 libc.so.1`_lwp_start()
>

I'm new to OmniOS and pkgsrc, and I'm not a dev, so I have no more clue how to better debug it.... thanks for any suggestion about this.
I can confirm that there is no problem by using the PostgreSQL client installed from IPS. I tried with several versions of both PostgreSQL client and server. The problem seems to be reproducible: it happened on two different servers.

@jperkin
Copy link
Collaborator

jperkin commented Dec 9, 2024

Thanks, I'll take a look. The crash is coming from mit-krb5, and it doesn't look like the OmniOS packages enable GSS/KRB5 support, so that probably explains the difference.

@jperkin jperkin self-assigned this Dec 9, 2024
@jperkin
Copy link
Collaborator

jperkin commented Dec 9, 2024

This turned out to be caused by an incorrect configure argument in our mit-krb5 build, and also explains why I was previously seeing a crash when using a different application. I've committed a fix for this now, and there should be an updated mit-krb5-1.21.3nb1 package available in the repository in due course.

@andrewhotlab
Copy link
Author

andrewhotlab commented Dec 9, 2024

Thank you so much. May I ask how much often upstream changes are committed to this fork of pkgsrc, and how often MNX rebuilds its package repository?

@jperkin
Copy link
Collaborator

jperkin commented Dec 9, 2024

I have GitHub actions that sync my feature trees every hour with upstream. Updates to the package repository are usually every few days, the limit is how fast I can build 25,000+ packages, and if updates trigger most packages then it can take around 2 days for the build to complete.

@andrewhotlab
Copy link
Author

Thanks, the new package revision has just reached me via pkgin upgrade, and PGSQL client works nicely over pooled connections!

github-actions bot pushed a commit that referenced this issue Jan 2, 2025
# dtplyr 1.3.1

* Fix for failing R CMD check.

* `dtplyr` no longer directly depends on `crayon`.

# dtplyr 1.3.0

## Breaking changes

* dplyr and tidyr verbs no longer dispatch to dtplyr translations when used
  directly on data.table objects. `lazy_dt()` must now explicitly be called by
  the user (#312).

## New features

* `across()` output can now be used as a data frame (#341).

* `.by`/`by` has been implemented for `mutate()`, `summarise()`, `filter()`,
  and the `slice()` family (#399).

* New translations for `add_count()`, `pick()` (#341), and `unite()`.

* `min_rank()`, `dense_rank()`, `percent_rank()`, & `cume_dist()` are now mapped
  to their `data.table` equivalents (#396).

## Performance improvements

* `arrange()` now utilizes `setorder()` when possible for improved performance
  (#364).

* `select()` now drops columns by reference when possible for improved
  performance (#367).

* `slice()` uses an intermediate variable to reduce computation time of row
  selection (#377).

## Minor improvements and bug fixes

* dtplyr no longer directly depends on `ellipsis`.

* Chained operations properly prevent modify-by-reference (#210).

* `across()`, `if_any()`, and `if_all()` evaluate the `.cols` argument
  in the environment from which the function was called.

* `count()` properly handles grouping variables (#356).

* `desc()` now supports use of `.data` pronoun inside in `arrange()` (#346).

* `full_join()` now produces output with correctly named columns when a
  non-default value for `suffix` is supplied. Previously the `suffix` argument
  was ignored (#382).

* `if_any()` and `if_all()` now work without specifying the `.fns` argument
  (@mgirlich, #325) and for a list of functions specified in the
  (@mgirlich, #335).

* `pivot_wider()`'s `names_glue` now works even when `names_from` contains
  `NA`s (#394).

* In `semi_join()` the `y` table is again coerced to a lazy table if
  `copy = TRUE` (@mgirlich, #322).

* `mutate()` can now use `.keep`.

* `mutate()`/`summarize()` correctly translates anonymous functions (#362).

* `mutate()`/`transmute()` now supports `glue::glue()` and `stringr::str_glue()`
   without specifying  `.envir`.

* `where()` now clearly errors because dtplyr doesn't support selection
  by predicate (#271).

# dtplyr 1.2.2

* Hot patch release to resolve R CMD check failures.
github-actions bot pushed a commit that referenced this issue Jan 4, 2025
Security fixes

    Upgrade to ruzstd v0.7.3 to fix RUSTSEC-2024-0400, see #396 (@zuisong)

Bug fixes

    Warn on combination of --continue and Range header, #394 (@blyxxyz)

Other

    Enable logging in rustls and tracing-using dependencies, see #390 (@blyxxyz)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants