Skip to main content

📊 CKAN Setup

In this section we'll go over how to install CKAN v2.10.6 and get it running on your Ubuntu VM.

📝 Written Tutorial

Prerequisites:

  • New installation of Ubuntu 22.04 (virtual machine, VPS, local device, etc.) connected to the Internet.

For these installation notes we'll assume the username in Ubuntu is rzmk, so change it to yours when applicable.

Upgrade packages

sudo apt update -y && sudo apt upgrade -y

Set up SSH (optional)

If you're using a VM then it may be easier when developing to SSH into the VM from a code editor such as VSCode, VSCodium, or Zed.

To enable SSH on the VM install openssh-server, and to identify the VM IP address to use when using SSH install net-tools:

sudo apt install openssh-server net-tools -y

Run the ifconfig command to identify your IP address, then use SSH on your local device and code editor to access the environment:

ssh rzmk@IPADDRESSHERE

Install Docker

Notes for this section based on https://www.digitalocean.com/community/tutorials/how-to-install-and-use-docker-on-ubuntu-22-04.

sudo apt update
sudo apt install apt-transport-https ca-certificates curl software-properties-common -y
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt update
apt-cache policy docker-ce
sudo apt install docker-ce -y

Also add your user to the sudo group to run Docker without sudo:

sudo usermod -aG docker ${USER}
su - ${USER}

Install docker-compose

We use docker-compose to set up and run ckan-compose.

sudo apt install docker-compose -y

Download Ahoy and add to $PATH

We'll be using ckan-compose to handle the PostgreSQL, Redis, and SOLR setup. One of the prerequisites for using ckan-compose is installing Ahoy.

Go to https://github.com/ahoy-cli/ahoy/releases/latest and download the ahoy-bin-linux-amd64 file and move it to your $PATH named as ahoy.

sudo mv ~/Downloads/ahoy-bin-linux-amd64 /usr/local/bin/ahoy
sudo chmod +x /usr/local/bin/ahoy

Set up ckan-compose

cd ~/
sudo apt install docker-compose -y
git clone https://github.com/tino097/ckan-compose.git
cd ckan-compose
ahoy generate-env
ahoy up

You may get asked after ahoy generate-env to provide a PROJECT_NAME, this can be anything so we'll put myproject. You may also use the defaults for DATASTORE_READONLY_PASSWORD and POSTGRES_PASSWORD for development.

CKAN steps 1-4 with caveats

sudo apt-get install python3-dev libpq-dev python3-pip python3-venv git-core redis-server -y
sudo mkdir -p /usr/lib/ckan/default
sudo chown `whoami` /usr/lib/ckan/default
python3 -m venv /usr/lib/ckan/default
. /usr/lib/ckan/default/bin/activate
pip install --upgrade pip
pip install -e 'git+https://github.com/ckan/ckan.git@ckan-2.10.6#egg=ckan[requirements]'
deactivate
. /usr/lib/ckan/default/bin/activate
sudo mkdir -p /etc/ckan/default
sudo chown -R `whoami` /etc/ckan/
ckan generate config /etc/ckan/default/ckan.ini
ln -s /usr/lib/ckan/default/src/ckan/who.ini /etc/ckan/default/who.ini

Next you must modify the CKAN config at /etc/ckan/default/ckan.ini:

debug = true
ckan.debug_supress_header = False

Also replace the following values to this:

ckan.devserver.threaded = true
ckan.max_resource_size = 10000
ckan.max_image_size = 5

Continue to step 7 while in the virtual environment (replace rzmk with your group then username for the chown command and your CKAN details for the CKAN sysadmin account generation command). You may be prompted to add a sysadmin username and password (the password may need to be at least 8 characters).

cd /usr/lib/ckan/default/src/ckan
pip install flask-debugtoolbar==0.14.1
cd /var/lib
sudo mkdir -p ckan/default
sudo chown rzmk.rzmk ckan/default
ckan -c /etc/ckan/default/ckan.ini db init
ckan -c /etc/ckan/default/ckan.ini sysadmin add rzmk email=rzmk@localhost name=rzmk
ckan -c /etc/ckan/default/ckan.ini run

Now you should be able to view your locally running CKAN instance at http://localhost:5000.

When restarting your server

If you shut down your Ubuntu instance and then start it again, you may want to run the following commands to get the CKAN instance running again:

/etc/init.d/redis-server stop
cd ckan-compose
ahoy up

Then run the following (e.g., after you SSH from your preferred terminal):

cd /usr/lib/ckan/default/
. ./bin/activate
cd src/ckan
ckan -c /etc/ckan/default/ckan.ini run