0586b12fe4
per report from sheng yan |
||
---|---|---|
docker | ||
ext | ||
layout | ||
lib | ||
public | ||
scripts | ||
sql | ||
t | ||
templates | ||
.dockerignore | ||
.gitattributes | ||
.gitignore | ||
.gitmodules | ||
cpanfile | ||
explain-json-notes.txt | ||
explain.development.json | ||
explain.json | ||
explain.pl | ||
explain.pp | ||
hypnotoad.conf | ||
LICENSE | ||
README.md | ||
run.dev.sh | ||
vagrant_bootstrap.sh | ||
Vagrantfile |
explain.depesz.com
Setup
There are three ways to install your own copy:
- Using Vagrant [ VirtualBox machine, fully automated ]
- Calling
puppet apply
- Manually
First get the source code:
git clone --recurse-submodules https://gitlab.com/depesz/explain.depesz.com.git
Vagrant setup
WARNING:
The first call of vagrant up
fetches a ~400MB vbox image from the Internet.
- Call
vagrant up
Point your browser on http://192.168.44.55 (or use /etc/hosts
entry explain.depesz.loc)
Puppet setup
- Install puppet on your machine, e.g. Debian installation described here.
- Open
explain.pp
and fix line 5 with correct project dir value - Call
sudo puppet apply --logdest console explain.pp
on your working copy directory.
Docker Compose setup
NOTE This setup should be considered for quick analysis purposes only - while docker-compose does keep DBs around from run to run, don't rely on it to store your history long term.
cd docker
docker-compose up --build
Manual setup
1) Mojolicious
You have to have Mojolicious installed on your server. Mojolicious is a web framework for Perl. http://mojolicio.us/
Installation can be accomplished with one command line:
curl -L cpanmin.us | perl - -n Mojolicious
See the Installation
section at http://mojolicio.us/ for details.
2) Perl Dependencies:
You will need the following packages installed in your version of Perl:
DBD::Pg
DBI
Date::Simple
Digest::MD5
Email::Sender::Simple
Email::Simple
Email::Valid
Mojolicious
Number::Bytes::Human
Pg::Explain
Install the above packages using cpan
then -i Date::Simple
, -i Email::Sender
, &etc.
Note that in case of most current Linux distributions, you can install most of these from binary package repositories. For example, in case of Ubuntu and Debian, you can:
apt-get install libmojolicious-perl \
libemail-sender-perl \
libdate-simple-perl \
libemail-valid-perl \
libxml-simple-perl \
libdbd-pg-perl
And then only add missing modules via CPAN.
Alternatively, if you have cpanm
program you should be able to install all
dependencies using:
cpanm --installdeps .
3) PostgreSQL
You'll need to have PostgreSQL installed in order to record all the explain plans into history. Consult the PostgreSQL Wiki for more information
3A) Create a new database explain
This will be were the explain server will store the users
and plans
tables
in the default schema public
.
3B) Run SQL scripts
Log in to the explain
database and execute the SQL scripts located in this
project's sql
directory.
You should start with create.sql:
\i create.sql
And then load all patch-NNN.sql files in their numerical order:
\i patch-001.sql
\i patch-002.sql
...
The create.sql
will create tables in the explain
database public
schema,
i.e. plans
and users
.
3C) Create a user role
I use explaind
[explain daemon], for example. Remember to provide it a
password and then configure the explain.json
file to reflect this new role and
password.
CREATE USER explaind WITH PASSWORD 'explain';
3D) Grant all rights to the tables in explain
to your role:
GRANT ALL ON plans, users TO explaind;
3E) modify pg_hba.conf
so that it has the server as "127.0.0.1"
local all all 127.0.0.1 trust
If you do not want to alter pg_hba.conf
, then you might be able to modify the
explain.json.dsn
setting to specify the name of the value in the server column
from your pg_hba.conf
file, e.g. "localhost". This alternative approach has
not been tested. It would be desirable to install this project with the minimal
amount of configuration changes, so I encourage someone to come up with a
solution that removes this step "E".
4) Configure explain.json
Make sure you have the correct values for your database connection.
See companion documentation file explain-json-notes.txt
5) Shell
The explain server runs on port 3000. Make sure port 3000 is available and not in use by another process. You may have to specify a different port (e.g. 3200). I do not know where you do that, probably in Mojolicious.
In the trunk directory for this project, run in a shell:
./explain.pl daemon
6) Browser
Then access the web page http://localhost:3000
When you access the web page,
remember to login and create an account for yourself so that your explain plans
will be associated with your account.