On Fri, Jan 18, 2019 at 3:58 PM Zsolt Ero <zsolt....@gmail.com> wrote:
>
> I thought I finally got to understand what does it mean to use a connection 
> pool /  QueuePool, but this performance problem puzzles me.
>
> If I run:
> for i in range(100):
>     with pg_engine.connect() as conn:
>         conn.execute('select 1').fetchall()
> it takes 47 seconds.
>
> If I run
> with pg_engine.connect() as conn:
>     for i in range(100):
>         conn.execute('select 1').fetchall()
> it takes 17 seconds.

you have some kind of major issue with your network and/or database.
 you'll want to do some ping tests and things like that, or perhaps
the SSL certificate setup you are using is adding some kind of extreme
latency, you'll want to test without it, perhaps there's a slow DNS
lookup or something occurring.   the code you have above normally
takes about 100 ms.   OK, took me 300ms over a local network:

$ python
Python 3.7.0 (default, Jun 28 2018, 10:59:55)
[GCC 8.1.1 20180502 (Red Hat 8.1.1-1)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from sqlalchemy import create_engine
>>> e = create_engine("postgresql://scott:tiger@pg10/test")
>>> import time
>>> def go():
...     now = time.time()
...     with e.connect() as conn:
...         for i in range(100):
...             conn.execute("select 1").fetchall()
...     total = time.time() - now
...     print("completed in %f sec" % (total, ))
...
>>> go()
completed in 0.335034 sec




>
> Isn't the whole point of Connection Pool that connections are 
> kept/cached/reused? If so, then why does the first version take 3 times 
> longer?
>
> pg_engine is set up the following way:
>
> pg_url = 
> f'postgresql+psycopg2://app:{pg_config["password"]}@{pg_config["host"]}/app'
> pg_certs = {
>     'sslcert': f'{config_dir}/client-cert.pem',
>     'sslkey': f'{config_dir}/client-key.pem',
>     'sslrootcert': f'{config_dir}/server-ca.pem',
> }
> pg_engine = create_engine(pg_url, connect_args=pg_certs)
>
> The server is a remote server quite far away, hence the connection issues are 
> greatly amplified, compared to localhost. Python is 3.7.
>
> --
> SQLAlchemy -
> The Python SQL Toolkit and Object Relational Mapper
>
> http://www.sqlalchemy.org/
>
> To post example code, please provide an MCVE: Minimal, Complete, and 
> Verifiable Example. See http://stackoverflow.com/help/mcve for a full 
> description.
> ---
> You received this message because you are subscribed to the Google Groups 
> "sqlalchemy" group.
> To unsubscribe from this group and stop receiving emails from it, send an 
> email to sqlalchemy+unsubscr...@googlegroups.com.
> To post to this group, send email to sqlalchemy@googlegroups.com.
> Visit this group at https://groups.google.com/group/sqlalchemy.
> For more options, visit https://groups.google.com/d/optout.

-- 
SQLAlchemy - 
The Python SQL Toolkit and Object Relational Mapper

http://www.sqlalchemy.org/

To post example code, please provide an MCVE: Minimal, Complete, and Verifiable 
Example.  See  http://stackoverflow.com/help/mcve for a full description.
--- 
You received this message because you are subscribed to the Google Groups 
"sqlalchemy" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to sqlalchemy+unsubscr...@googlegroups.com.
To post to this group, send email to sqlalchemy@googlegroups.com.
Visit this group at https://groups.google.com/group/sqlalchemy.
For more options, visit https://groups.google.com/d/optout.

Reply via email to