A Postgres-backed ContentsManager for IPython/Jupyter.
Project description
PGContents is a PostgreSQL-backed implementation of IPEP 27. It aims to a be a transparent, drop-in replacement for IPython’s standard filesystem-backed storage system. PGContents’ PostgresContentsManager class can be used to replace all local filesystem storage with database-backed storage, while its PostgresCheckpoints class can be used to replace just IPython’s checkpoint storage. These features are useful when running IPython in environments where you either don’t have access to—or don’t trust the reliability of—the local filesystem of your notebook server.
This repository is under development as part of the Quantopian Research Environment, currently in Open Beta.
Getting Started
- Prerequisites:
Write access to an empty PostgreSQL database.
A Python installation with IPython 3.x or Jupyter Notebook >= 4.0.
Installation:
Install pgcontents from PyPI via pip install pgcontents[ipy4]. (This will install pgcontents in a manner compatible with a recent Jupyter Notebook version. To install pgcontents with support for the legacy IPython 3.x series, run pip install pgcontents[ipy3]).
Run pgcontents init to configure your database. You will be prompted for a database URL for pgcontents to use for storage. (Alternatively, you can set the PGCONTENTS_DB_URL environment variable, or pass –db-url on the command line).
Configure IPython/Jupyter to use pgcontents as its storage backend. This can be done from the command line or by modifying your notebook config file. For IPython 3.x on a Unix-like system, your notebok config will be located located at ~/.ipython/profile_default/ipython_notebook_config.py. For Jupyter Notebook, it will will be located at ~/.jupyter/jupyter_notebook_config.py. See the examples directory for example configuration files.
Enjoy your filesystem-free IPython experience!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.