Git Product home page Git Product logo

Comments (16)

ttfkam avatar ttfkam commented on September 7, 2024

I'm seeing this as well when running the build tests.

from pgmoon.

ttfkam avatar ttfkam commented on September 7, 2024

Here's the culprit
c841be9#diff-ecfebe05627fcb262bfc1b60e5ea0306

I'm assuming it was an oversight since I don't see any extra logic at work.

from pgmoon.

thibaultcha avatar thibaultcha commented on September 7, 2024

It is an OpenResty paradigm to create one TCP socket in such a new() method, and not in connect() as pgmoon was previously doing. See https://github.com/openresty/lua-resty-redis for such an example, among others.

Maybe pgmoon shouldn't free the socket in :setkeepalive()? There could be some side-effects that I am not aware of.

from pgmoon.

ttfkam avatar ttfkam commented on September 7, 2024

Side effects worse than a nil reference by default? 😏

from pgmoon.

thibaultcha avatar thibaultcha commented on September 7, 2024

If you feel like this behavior is more desirable than the current one, feel free to propose a PR to this project.

from pgmoon.

ttfkam avatar ttfkam commented on September 7, 2024

Looking at lua-resty-redis as a reference,
https://github.com/openresty/lua-resty-redis/blob/403d2982ec1dacaa758301c788754a82c82b00d8/lib/resty/redis.lua#L99

it doesn't appear that the socket should be set to nil. I'll provide a PR soon.

from pgmoon.

gnois avatar gnois commented on September 7, 2024

I found the last paragraph of https://github.com/openresty/lua-resty-redis#set_keepalive gives a pointer that connect is allowed:

Any subsequent operations other than connect() on the current object will return the closed error.

Thanks @ttfkam and @thibaultcha

from pgmoon.

ttfkam avatar ttfkam commented on September 7, 2024

On the bright side, it turns out the failing tests were due to my build environment. The rockspec file really should have more dependencies defined.

On the downside, there are no tests for keepalive I can see. This probably makes sense since the connection behavior is different for OpenResty environments than for straight Lua usage.

I use pg_bouncer for my connection pooling, so I don't have a setup handy for it. @gnois, if you checkout my keepalive branch, I'd love to know that it works for you. The only two files you'd need to swap out are pgmoon/init.moon and pgmoon/init.lua

from pgmoon.

gnois avatar gnois commented on September 7, 2024

@ttfkam Works well enough for me. 👍

from pgmoon.

thibaultcha avatar thibaultcha commented on September 7, 2024

The rockspec file really should have more dependencies defined.

The rockspec is for production installations only, since the format does not support development-only dependencies yet. Development dependencies are to be manually installed; library maintainers have different ways of dealing with them and/or simply document them in the README. Feel free to send a PR improving the process for this library if you feel a need for it.

from pgmoon.

ttfkam avatar ttfkam commented on September 7, 2024

Still getting used to Lua. Thank you for the explanation.

from pgmoon.

ttfkam avatar ttfkam commented on September 7, 2024

Associating the pull request with this issue. #46

from pgmoon.

yzk0281 avatar yzk0281 commented on September 7, 2024

@ttfkam
How did this problem solved in the end ?
I came with the same problem.

from pgmoon.

ttfkam avatar ttfkam commented on September 7, 2024

I put up a pull request months ago with what I saw as the best solution at the time, but it's open source; you can't force anyone to actually accept the patch if they don't want to. Until @leafo accepts the patch or fixes on his own as he sees fit, you'll have to simply stop using pgmoon's implementation of keepalive().

As a workaround, you can use pgbouncer to manage connection pooling rather than relying on the database driver to do so.

from pgmoon.

yzk0281 avatar yzk0281 commented on September 7, 2024

@ttfkam
Hi Sir, is Your PR change the keepalive function to not set sock = nil?

from pgmoon.

ttfkam avatar ttfkam commented on September 7, 2024

Yes, #46

from pgmoon.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo 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.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.