Hi David,
How many different table/objects do you read from and do you use bind
variables?
Each postmaster process keeps internal dictionary on objects and queries
ran - If you have too many objects or queries planned you might take up too
much ram.

If this is indeed your situation, you might benefit from shorter lived
connections.

Regards,
 - Jony

On Fri, Apr 15, 2016 at 12:14 AM, Day, David <d...@redcom.com> wrote:

> Hello,
>
>
> Understanding postgresql memory usage ?
>
> While traffic loading our application that uses a postgres 9.3.11 database
> instance, we observe higher RAM usage then expected.  The system bogs down
> as free memory decreases to minimal values.  The most RAM usage seems to be
> with postgres backends.   I am looking for clarity on how postgress backend
> connections use RAM.  I suspect our tuning is bad for 2 GB RAM pool.  We
> likely need to add memory.
>
> Please look at the "top" output below and offer an opinion that the "top
> RES" values could be that high for the configuration parameters postgres is
> running on.
>
> There are no error messages in postgres log of relevance.
>
> Regards and thank you for consideration on the matter.
>
>
> Dave Day
>
> ------
>
>
> Details:
>
>
> Postgresql.conf  ( relevant subset )
>
> max_connections = 100
> shared_buffers = 64MB
> #temp_buffers = 8MB
> work_mem = 1MB
> maintenance_work_mem=16MB
> max_stack_depth=2MB
> #wal_level=minimal
> #fsync=on
> #synchronous_commit=on
> #full_page_writes = on
> #wal_buffers = -1
> #autovacuum = on
> log_destination='syslog'
> update_process_title=off
>
> ------
>
> Here are all the backend connections via "top" taken after offered load
> has been running a while.
>
> I annotated some of the "top" data as to connection ownership sorted by
> RES and user.
> Within the DBM connections I correlate the pid to the client session.
> Connections
> 0-3 are somewhat specialized towards read operations ( selects )  whiles
> connections 4-9 are
> More write oriented. ( Insert/updates ).
> ----
>
> top capture:
>
> 97 processes:  1 running, 91 sleeping, 5 zombie
> CPU:  1.6% user,  0.0% nice,  9.4% system,  0.4% interrupt, 88.6% idle
> Mem: 1474M Active, 79M Inact, 387M Wired, 19M Cache, 10M Free
> ARC: 156M Total, 44M MFU, 38M MRU, 1885K Anon, 2619K Header, 70M Other
> Swap: 2048M Total, 761M Used, 1287M Free, 37% Inuse, 144K In
>
>   PID USERNAME       THR PRI NICE   SIZE    RES STATE   C   TIME    WCPU
> COMMAND   DBM connection
> DBM
>  9099 pgsql            1  20    0   373M   205M sbwait  1   4:02   0.00%
> postgres  6
>  9094 pgsql            1  20    0   365M   204M sbwait  1   3:53   0.00%
> postgres  4
>  9089 pgsql            1  20    0   325M   162M sbwait  1   8:14   0.00%
> postgres  9
>  9097 pgsql            1  20    0   309M   145M sbwait  1   3:40   0.00%
> postgres  5
>  9096 pgsql            1  20    0   301M   138M sbwait  0   3:24   0.00%
> postgres  8
>  9095 pgsql            1  20    0   233M 72648K sbwait  1   1:03   0.00%
> postgres  0
>  9092 pgsql            1  20    0   217M 53852K sbwait  1   0:44   0.00%
> postgres  2
>  9100 pgsql            1  20    0   217M 53708K sbwait  0   0:44   0.00%
> postgres  3
>  9098 pgsql            1  20    0   217M 53552K sbwait  0   0:43   0.00%
> postgres  1
>  9093 pgsql            1  20    0   373M 32328K sbwait  1   4:02   0.00%
> postgres  7
>
>  9084 pgsql            1  20    0   112M 21284K select  0   0:37   0.00%
> postgres
>
> glassfish
> 72033 pgsql            1  20    0   112M 13624K sbwait  0   0:00   0.00%
> postgres
> 72034 pgsql            1  20    0   112M 13456K sbwait  1   0:00   0.00%
> postgres
> 70428 pgsql            1  20    0   112M 13244K sbwait  0   0:00   0.00%
> postgres
> 70430 pgsql            1  20    0   112M 13244K sbwait  1   0:00   0.00%
> postgres
> 70429 pgsql            1  20    0   112M 13244K sbwait  1   0:00   0.00%
> postgres
> 70431 pgsql            1  20    0   112M 13244K sbwait  0   0:00   0.00%
> postgres
> 70432 pgsql            1  20    0   112M 13240K sbwait  0   0:00   0.00%
> postgres
> 70427 pgsql            1  20    0   112M 13224K sbwait  1   0:00   0.00%
> postgres
>
>  9087 pgsql            1  20    0   112M 10772K select  1   0:10   0.00%
> postgres
>  9085 pgsql            1  20    0   112M 10736K select  0   0:04   0.00%
> postgres
>  9082 pgsql            1  20    0   112M 10648K select  0   0:04   0.00%
> postgres
>  9086 pgsql            1  20    0   112M 10496K select  0   0:24   0.00%
> postgres
>  9088 pgsql            1  20    0 39808K  5384K select  1   0:24   0.00%
> postgres
>
> collectd
>  9140 pgsql            1  20    0   112M  4408K sbwait  0   0:13   0.00%
> postgres
>
>
> Machine details:  Oracle Virtual Box VM  - guest on Windows.
>
> Copyright (c) 1992-2014 The FreeBSD Project.
> Copyright (c) 1979, 1980, 1983, 1986, 1988, 1989, 1991, 1992, 1993, 1994
>         The Regents of the University of California. All rights reserved.
> FreeBSD is a registered trademark of The FreeBSD Foundation.
> FreeBSD 10.1-RELEASE-p31 #6 r28476: Fri Apr  8 02:58:45 EDT 2016
>     
> r...@build-ace-1-2.redcom.com:/usr/obj/space/jenkins/customws/1.2.0/amd64/src/sys/GENERIC
> amd64
> FreeBSD clang version 3.4.1 (tags/RELEASE_34/dot1-final 208032) 20140512
> CPU: AMD Opteron(tm) Processor 4386                  (3100.04-MHz K8-class
> CPU)
>   Origin = "AuthenticAMD"  Id = 0x600f20  Family = 0x15  Model = 0x2
> Stepping = 0
>
> Features=0x1783fbff<FPU,VME,DE,PSE,TSC,MSR,PAE,MCE,CX8,APIC,SEP,MTRR,PGE,MCA,CMOV,PAT,PSE36,MMX,FXSR,SSE,SSE2,HTT>
>
> Features2=0x9e983203<SSE3,PCLMULQDQ,SSSE3,FMA,CX16,SSE4.1,SSE4.2,POPCNT,AESNI,XSAVE,OSXSAVE,AVX,HV>
>   AMD Features=0x2a500800<SYSCALL,NX,MMX+,FFXSR,RDTSCP,LM>
>   AMD Features2=0x10be9<LAHF,ExtAPIC,ABM,SSE4A,MAS,Prefetch,OSVW,XOP,FMA4>
>   TSC: P-state invariant
> real memory  = 2147483648 (2048 MB)
> avail memory = 2050375680 (1955 MB)
> Event timer "LAPIC" quality 400
>
> Postgres package details:
>
> pkg info postgresql93-server-9.3.11
> postgresql93-server-9.3.11
> Name           : postgresql93-server
> Version        : 9.3.11
> Installed on   : Mon Apr 11 15:16:52 2016 EDT
> Origin         : databases/postgresql93-server
> Architecture   : freebsd:10:x86:64
> Prefix         : /usr/local
> Categories     : databases
> Licenses       :
> Maintainer     : pg...@freebsd.org
> WWW            : http://www.postgresql.org/
> Comment        : The most advanced open-source database available anywhere
> Options        :
>         DEBUG          : off
>         DTRACE         : off
>         GSSAPI         : off
>         HEIMDAL_KRB5   : off
>         ICU            : off
>         INTDATE        : on
>         LDAP           : off
>         MIT_KRB5       : off
>         NLS            : on
>         OPTIMIZED_CFLAGS: off
>         PAM            : off
>         SSL            : on
>         TZDATA         : on
>         XML            : on
> Shared Libs required:
>         libintl.so.8
>         libxml2.so.2
>         libpq.so.5
> Annotations    :
>         cpe            :
> cpe:2.3:a:postgresql:postgresql:9.3.11:::::freebsd10:x64
>         repo_type      : binary
>         repository     : redcom
>
>
>
>
>
>
>
>
>
> --
> Sent via pgsql-general mailing list (pgsql-general@postgresql.org)
> To make changes to your subscription:
> http://www.postgresql.org/mailpref/pgsql-general
>

Reply via email to