Обсуждение: Server side session management using the SQLite (per session) database
Hi Dave/team,
As discussed, I have implemented the server side session management using the SQLite database.
Implementation:
* It creates/reuses the sqlite database per session.
* Stores the key (as text)/value (as blob) in the sqlite database.
* Needs to provide the session directory, where you want to store those sessions. If this directory does not exist, it creates the directory with 700 permission. (Default: <USER_HOME>/.pgadmin/sessions directory.)
* Also - sets default value for the log file to be stored in the '<USER_HOME>/.pgadmin' directory. This will allow us to keep separate configuration per user on any operation system, when running through runtime.
This implementation uses sqlite as session storage, it may affect because of explicit file system I/O operation. Though - performance should not be a big issue, as we're not targeting to support very huge parallel sessions.
Murtuza,
I have tested it on Python 2.7.
Can you please take a look at it, and do the needful to make it work on Python 3.x?
Вложения
Hi
-- 
			
		On Thu, Mar 17, 2016 at 5:46 PM, Ashesh Vashi <ashesh.vashi@enterprisedb.com> wrote:
 
Hi Dave/team,As discussed, I have implemented the server side session management using the SQLite database.Implementation:* It creates/reuses the sqlite database per session.* Stores the key (as text)/value (as blob) in the sqlite database.* Needs to provide the session directory, where you want to store those sessions. If this directory does not exist, it creates the directory with 700 permission. (Default: <USER_HOME>/.pgadmin/sessions directory.)* Also - sets default value for the log file to be stored in the '<USER_HOME>/.pgadmin' directory. This will allow us to keep separate configuration per user on any operation system, when running through runtime.This implementation uses sqlite as session storage, it may affect because of explicit file system I/O operation. Though - performance should not be a big issue, as we're not targeting to support very huge parallel sessions.
Thanks - applied.
I assume it's expected at this point that new connections still fail if the backend is restarted (that would come with graceful reconnections)?
Murtuza,I have tested it on Python 2.7.Can you please take a look at it, and do the needful to make it work on Python 3.x?
Please double-check Windows as well.
Thanks. 
Dave Page
Blog: http://pgsnake.blogspot.com
Twitter: @pgsnake
EnterpriseDB UK: http://www.enterprisedb.com
The Enterprise PostgreSQL Company
Blog: http://pgsnake.blogspot.com
Twitter: @pgsnake
EnterpriseDB UK: http://www.enterprisedb.com
The Enterprise PostgreSQL Company
On Tue, Mar 22, 2016 at 8:41 PM, Dave Page <dpage@pgadmin.org> wrote:
			
		HiOn Thu, Mar 17, 2016 at 5:46 PM, Ashesh Vashi <ashesh.vashi@enterprisedb.com> wrote:Hi Dave/team,As discussed, I have implemented the server side session management using the SQLite database.Implementation:* It creates/reuses the sqlite database per session.* Stores the key (as text)/value (as blob) in the sqlite database.* Needs to provide the session directory, where you want to store those sessions. If this directory does not exist, it creates the directory with 700 permission. (Default: <USER_HOME>/.pgadmin/sessions directory.)* Also - sets default value for the log file to be stored in the '<USER_HOME>/.pgadmin' directory. This will allow us to keep separate configuration per user on any operation system, when running through runtime.This implementation uses sqlite as session storage, it may affect because of explicit file system I/O operation. Though - performance should not be a big issue, as we're not targeting to support very huge parallel sessions.Thanks - applied.
Thanks. 
I assume it's expected at this point that new connections still fail if the backend is restarted (that would come with graceful reconnections)?
Hmm..
I did not get that.
Do you mean to say?
- New Connection to the server should not be established (if it was restarted).
- What about the existing connection, should it re-establish the connection after the backend restart (when allowed)?
Murtuza,I have tested it on Python 2.7.Can you please take a look at it, and do the needful to make it work on Python 3.x?Please double-check Windows as well.
Thanks - Murtuza for the python 3 support patch. 
Neel - can you please take a look at the Windows?
Thanks.--Dave Page
Blog: http://pgsnake.blogspot.com
Twitter: @pgsnake
EnterpriseDB UK: http://www.enterprisedb.com
The Enterprise PostgreSQL Company
Hi,
I just tested the latest code under windows environment with python 2.7 which is working fine without any errors.
Thanks,
Neel Patel
On Wed, Mar 23, 2016 at 1:02 PM, Ashesh Vashi <ashesh.vashi@enterprisedb.com> wrote:
On Tue, Mar 22, 2016 at 8:41 PM, Dave Page <dpage@pgadmin.org> wrote:HiOn Thu, Mar 17, 2016 at 5:46 PM, Ashesh Vashi <ashesh.vashi@enterprisedb.com> wrote:Hi Dave/team,As discussed, I have implemented the server side session management using the SQLite database.Implementation:* It creates/reuses the sqlite database per session.* Stores the key (as text)/value (as blob) in the sqlite database.* Needs to provide the session directory, where you want to store those sessions. If this directory does not exist, it creates the directory with 700 permission. (Default: <USER_HOME>/.pgadmin/sessions directory.)* Also - sets default value for the log file to be stored in the '<USER_HOME>/.pgadmin' directory. This will allow us to keep separate configuration per user on any operation system, when running through runtime.This implementation uses sqlite as session storage, it may affect because of explicit file system I/O operation. Though - performance should not be a big issue, as we're not targeting to support very huge parallel sessions.Thanks - applied.Thanks.I assume it's expected at this point that new connections still fail if the backend is restarted (that would come with graceful reconnections)?Hmm..I did not get that.Do you mean to say?- New Connection to the server should not be established (if it was restarted).- What about the existing connection, should it re-establish the connection after the backend restart (when allowed)?Murtuza,I have tested it on Python 2.7.Can you please take a look at it, and do the needful to make it work on Python 3.x?Please double-check Windows as well.Thanks - Murtuza for the python 3 support patch.Neel - can you please take a look at the Windows?Thanks.--Dave Page
Blog: http://pgsnake.blogspot.com
Twitter: @pgsnake
EnterpriseDB UK: http://www.enterprisedb.com
The Enterprise PostgreSQL Company
On Wed, Mar 23, 2016 at 2:04 PM, Neel Patel <neel.patel@enterprisedb.com> wrote:
Hi,I just tested the latest code under windows environment with python 2.7 which is working fine without any errors.
Thanks.
--
Thanks & Regards,
Ashesh Vashi
EnterpriseDB INDIA: Enterprise PostgreSQL Company
Thanks,Neel PatelOn Wed, Mar 23, 2016 at 1:02 PM, Ashesh Vashi <ashesh.vashi@enterprisedb.com> wrote:On Tue, Mar 22, 2016 at 8:41 PM, Dave Page <dpage@pgadmin.org> wrote:HiOn Thu, Mar 17, 2016 at 5:46 PM, Ashesh Vashi <ashesh.vashi@enterprisedb.com> wrote:Hi Dave/team,As discussed, I have implemented the server side session management using the SQLite database.Implementation:* It creates/reuses the sqlite database per session.* Stores the key (as text)/value (as blob) in the sqlite database.* Needs to provide the session directory, where you want to store those sessions. If this directory does not exist, it creates the directory with 700 permission. (Default: <USER_HOME>/.pgadmin/sessions directory.)* Also - sets default value for the log file to be stored in the '<USER_HOME>/.pgadmin' directory. This will allow us to keep separate configuration per user on any operation system, when running through runtime.This implementation uses sqlite as session storage, it may affect because of explicit file system I/O operation. Though - performance should not be a big issue, as we're not targeting to support very huge parallel sessions.Thanks - applied.Thanks.I assume it's expected at this point that new connections still fail if the backend is restarted (that would come with graceful reconnections)?Hmm..I did not get that.Do you mean to say?- New Connection to the server should not be established (if it was restarted).- What about the existing connection, should it re-establish the connection after the backend restart (when allowed)?Murtuza,I have tested it on Python 2.7.Can you please take a look at it, and do the needful to make it work on Python 3.x?Please double-check Windows as well.Thanks - Murtuza for the python 3 support patch.Neel - can you please take a look at the Windows?Thanks.--Dave Page
Blog: http://pgsnake.blogspot.com
Twitter: @pgsnake
EnterpriseDB UK: http://www.enterprisedb.com
The Enterprise PostgreSQL Company
On Wed, Mar 23, 2016 at 7:32 AM, Ashesh Vashi <ashesh.vashi@enterprisedb.com> wrote:
On Tue, Mar 22, 2016 at 8:41 PM, Dave Page <dpage@pgadmin.org> wrote:HiOn Thu, Mar 17, 2016 at 5:46 PM, Ashesh Vashi <ashesh.vashi@enterprisedb.com> wrote:Hi Dave/team,As discussed, I have implemented the server side session management using the SQLite database.Implementation:* It creates/reuses the sqlite database per session.* Stores the key (as text)/value (as blob) in the sqlite database.* Needs to provide the session directory, where you want to store those sessions. If this directory does not exist, it creates the directory with 700 permission. (Default: <USER_HOME>/.pgadmin/sessions directory.)* Also - sets default value for the log file to be stored in the '<USER_HOME>/.pgadmin' directory. This will allow us to keep separate configuration per user on any operation system, when running through runtime.This implementation uses sqlite as session storage, it may affect because of explicit file system I/O operation. Though - performance should not be a big issue, as we're not targeting to support very huge parallel sessions.Thanks - applied.Thanks.I assume it's expected at this point that new connections still fail if the backend is restarted (that would come with graceful reconnections)?Hmm..I did not get that.Do you mean to say?- New Connection to the server should not be established (if it was restarted).- What about the existing connection, should it re-establish the connection after the backend restart (when allowed)?
There are still some cases, even with the graceful reconnection patch, where reconnections don't happen and you get a red alert message on the UI. I've yet to figure out exactly what they are though - but I think whether the pgAdmin server or the Python server has restarted or dropped connections, they should gracefully be re-established. 
Dave Page
Blog: http://pgsnake.blogspot.com
Twitter: @pgsnake
EnterpriseDB UK: http://www.enterprisedb.com
The Enterprise PostgreSQL Company
Blog: http://pgsnake.blogspot.com
Twitter: @pgsnake
EnterpriseDB UK: http://www.enterprisedb.com
The Enterprise PostgreSQL Company
On Tue, Mar 22, 2016 at 4:11 PM, Dave Page <dpage@pgadmin.org> wrote:
Not saying it's wrong, absolutely not. Just expect a few laughs coming off that one :D
HiOn Thu, Mar 17, 2016 at 5:46 PM, Ashesh Vashi <ashesh.vashi@enterprisedb.com> wrote:Hi Dave/team,As discussed, I have implemented the server side session management using the SQLite database.Implementation:* It creates/reuses the sqlite database per session.* Stores the key (as text)/value (as blob) in the sqlite database.* Needs to provide the session directory, where you want to store those sessions. If this directory does not exist, it creates the directory with 700 permission. (Default: <USER_HOME>/.pgadmin/sessions directory.)* Also - sets default value for the log file to be stored in the '<USER_HOME>/.pgadmin' directory. This will allow us to keep separate configuration per user on any operation system, when running through runtime.This implementation uses sqlite as session storage, it may affect because of explicit file system I/O operation. Though - performance should not be a big issue, as we're not targeting to support very huge parallel sessions.Thanks - applied.I assume it's expected at this point that new connections still fail if the backend is restarted (that would come with graceful reconnections)?
Heh, does this actually make sqlite a dependency for pgadmin4? That's kind of hilarious :)
Not saying it's wrong, absolutely not. Just expect a few laughs coming off that one :D
On Wed, Mar 23, 2016 at 2:34 PM, Magnus Hagander <magnus@hagander.net> wrote:
On Tue, Mar 22, 2016 at 4:11 PM, Dave Page <dpage@pgadmin.org> wrote:HiOn Thu, Mar 17, 2016 at 5:46 PM, Ashesh Vashi <ashesh.vashi@enterprisedb.com> wrote:Hi Dave/team,As discussed, I have implemented the server side session management using the SQLite database.Implementation:* It creates/reuses the sqlite database per session.* Stores the key (as text)/value (as blob) in the sqlite database.* Needs to provide the session directory, where you want to store those sessions. If this directory does not exist, it creates the directory with 700 permission. (Default: <USER_HOME>/.pgadmin/sessions directory.)* Also - sets default value for the log file to be stored in the '<USER_HOME>/.pgadmin' directory. This will allow us to keep separate configuration per user on any operation system, when running through runtime.This implementation uses sqlite as session storage, it may affect because of explicit file system I/O operation. Though - performance should not be a big issue, as we're not targeting to support very huge parallel sessions.Thanks - applied.I assume it's expected at this point that new connections still fail if the backend is restarted (that would come with graceful reconnections)?Heh, does this actually make sqlite a dependency for pgadmin4? That's kind of hilarious :)
:)
We're already using sqlite for saving the local configurations instead of flat file, which caused a lot of problem in past with pgAdmin 3.
Not saying it's wrong, absolutely not. Just expect a few laughs coming off that one :D
Do not have time to implement another database. :P 
--
Thanks & Regards,
Ashesh Vashi
EnterpriseDB INDIA: Enterprise PostgreSQL Company
--
On Wed, Mar 23, 2016 at 9:04 AM, Magnus Hagander <magnus@hagander.net> wrote: > > > On Tue, Mar 22, 2016 at 4:11 PM, Dave Page <dpage@pgadmin.org> wrote: >> >> Hi >> >> On Thu, Mar 17, 2016 at 5:46 PM, Ashesh Vashi >> <ashesh.vashi@enterprisedb.com> wrote: >>> >>> Hi Dave/team, >>> >>> As discussed, I have implemented the server side session management using >>> the SQLite database. >>> >>> Implementation: >>> * It creates/reuses the sqlite database per session. >>> * Stores the key (as text)/value (as blob) in the sqlite database. >>> * Needs to provide the session directory, where you want to store those >>> sessions. If this directory does not exist, it creates the directory with >>> 700 permission. (Default: <USER_HOME>/.pgadmin/sessions directory.) >>> * Also - sets default value for the log file to be stored in the >>> '<USER_HOME>/.pgadmin' directory. This will allow us to keep separate >>> configuration per user on any operation system, when running through >>> runtime. >>> >>> This implementation uses sqlite as session storage, it may affect because >>> of explicit file system I/O operation. Though - performance should not be a >>> big issue, as we're not targeting to support very huge parallel sessions. >> >> >> Thanks - applied. >> >> I assume it's expected at this point that new connections still fail if >> the backend is restarted (that would come with graceful reconnections)? >> > > > > Heh, does this actually make sqlite a dependency for pgadmin4? That's kind > of hilarious :) It's actually been there for ages - we just now store session info in it as well as config settings. > Not saying it's wrong, absolutely not. Just expect a few laughs coming off > that one :D I'm aware of the irony :-). It's a perfectly fine embedded database though, and that's what we needed here. Running a Postgres instance for this is severe overkill - but I don't need to explain that to you. -- Dave Page Blog: http://pgsnake.blogspot.com Twitter: @pgsnake EnterpriseDB UK: http://www.enterprisedb.com The Enterprise PostgreSQL Company
On Wed, Mar 23, 2016 at 10:15 AM, Dave Page <dpage@pgadmin.org> wrote:
 
It's actually been there for ages - we just now store session info inOn Wed, Mar 23, 2016 at 9:04 AM, Magnus Hagander <magnus@hagander.net> wrote:
>
>
> On Tue, Mar 22, 2016 at 4:11 PM, Dave Page <dpage@pgadmin.org> wrote:
>>
>> Hi
>>
>> On Thu, Mar 17, 2016 at 5:46 PM, Ashesh Vashi
>> <ashesh.vashi@enterprisedb.com> wrote:
>>>
>>> Hi Dave/team,
>>>
>>> As discussed, I have implemented the server side session management using
>>> the SQLite database.
>>>
>>> Implementation:
>>> * It creates/reuses the sqlite database per session.
>>> * Stores the key (as text)/value (as blob) in the sqlite database.
>>> * Needs to provide the session directory, where you want to store those
>>> sessions. If this directory does not exist, it creates the directory with
>>> 700 permission. (Default: <USER_HOME>/.pgadmin/sessions directory.)
>>> * Also - sets default value for the log file to be stored in the
>>> '<USER_HOME>/.pgadmin' directory. This will allow us to keep separate
>>> configuration per user on any operation system, when running through
>>> runtime.
>>>
>>> This implementation uses sqlite as session storage, it may affect because
>>> of explicit file system I/O operation. Though - performance should not be a
>>> big issue, as we're not targeting to support very huge parallel sessions.
>>
>>
>> Thanks - applied.
>>
>> I assume it's expected at this point that new connections still fail if
>> the backend is restarted (that would come with graceful reconnections)?
>>
>
>
>
> Heh, does this actually make sqlite a dependency for pgadmin4? That's kind
> of hilarious :)
it as well as config settings.
Ha. That's what I get for not tracking the development properly.
> Not saying it's wrong, absolutely not. Just expect a few laughs coming off
> that one :D
I'm aware of the irony :-). It's a perfectly fine embedded database
though, and that's what we needed here. Running a Postgres instance
for this is severe overkill - but I don't need to explain that to you.
Oh, I fully agree with that :) It's just funny. 
