The following instructions assume you are running a reasonably modern
version of Debian or Ubuntu and have sudo
access.
Set up Icelandic locale is_IS.utf8
:
sudo dpkg-reconfigure locales
sudo locale-gen is_IS.UTF-8
sudo update-locale
NB: If PostgreSQL is already running on your machine, it needs to be restarted:
sudo systemctl restart postgresql
See below for instructions on installing PostgreSQL client libraries.
Install Python 3 and other packages required by Greynir:
sudo apt-get install python3
sudo apt-get install libgeos-dev libpq-dev
Make sure you have the latest version of pip
and virtualenv
.
sudo -H pip3 install --upgrade pip
pip3 install --upgrade virtualenv
Install git if it's not already installed:
sudo apt-get install git
Install PyPy 3.7 or later (available here). For example:
mkdir ~/pypy
cd ~/pypy
wget https://downloads.python.org/pypy/pypy3.7-v7.3.9-linux64.tar.bz2
tar --strip-components=1 -xvf pypy3.7-v7.3.9-linux64.tar.bz2
The PyPy binary should now be installed in ~/pypy/bin/pypy3
.
Speaking of PyPy, if you try to run Greynir and get an error message saying that
the library libgeos_c.so
cannot be loaded, you may need a symlink from your
pypy/lib
directory to the libgeos_c.so
file. Something like this:
cd ~/pypy/lib
ln -s /usr/lib/x86_64-linux-gnu/libgeos_c.so .
Now, check out the Greynir repo:
cd ~
git clone https://github.com/mideind/Greynir
cd ~/Greynir
Create and activate virtual environment, install required Python packages:
virtualenv -p ~/pypy/bin/pypy3 venv
source venv/bin/activate
pip install -r requirements.txt
Install PostgreSQL 9.5 or later (Greynir relies on the UPSERT feature introduced in version 9.5).
sudo apt-get install postgresql-contrib postgresql-client libpq-dev
Permit user access to PostgreSQL from localhost by editing pg_hba.conf
(replace 9.5
in the path with your version):
sudo nano /etc/postgresql/9.5/main/pg_hba.conf
Make sure that the config file contains the following entries:
# IPv4 local connections:
host all all 127.0.0.1/32 trust
# IPv6 local connections:
host all all ::1/128 trust
Restart PostgreSQL for the changes to take effect:
sudo systemctl reload postgresql
Change to the default PostgreSQL user postgres
:
sudo su - postgres
Launch PostgreSQL client and create database users (replace your_user_name with your username):
psql
create user reynir with password 'reynir';
create user your_user_name;
alter role your_user_name with superuser;
create database scraper with encoding 'UTF8' LC_COLLATE='is_IS.UTF-8' LC_CTYPE='is_IS.UTF-8' TEMPLATE=template0;
Enable uuid extension:
\c scraper
create extension if not exists "uuid-ossp";
Verify that the uuid extension is enabled:
select * from pg_extension;
and then \q
to quit the psql
client.
Finally, create the database tables used by Greynir (this will only create the tables if needed, and no existing data is erased):
cd ~/Greynir
python scraper.py --init
Change to the Greynir repository and activate the virtual environment:
cd ~/Greynir
source venv/bin/activate
You should now be able to run Greynir.
python main.py
Defaults to running on localhost:5000
but this
can be changed in config/Greynir.conf
.
python scraper.py
./shell.sh
Starts an IPython shell with a database session (s
),
the Greynir parser (r
) and all SQLAlchemy database models preloaded. For more
info, see Using the Greynir Shell.