Table of Contents |
---|
Prerequisites |
Recommendations |
Docker Networking |
Project Prebuild |
Database and File Backups |
Build Containers |
Installing Applications |
How to Use |
Postgres Version Upgrade |
- WSL2 if using Windows
- Docker
- docker-compose
- Git
- You will also need your git configuration to be accessible to your user, located by default at
~/.gitconfig
. This will be attached to the Docker container so that the build scripts can pull the repositories. - If using WSL2, you will need to have this config set up inside of WSL2 for your WSL2 user.
- You will also need your git configuration to be accessible to your user, located by default at
It is highly recommended to use the OG CLI tool to manage docker-og projects.
The OG CLI tool will give you an easier command-line interface to view, manage, and run Docker projects that use docker-og.
It will also allow you simpler git tooling and debugging.
The docker-og scripts use port and IP octet renting from a pool of pre-defined ports and octets.
Ports: 57000 - 57999 IP Addresses: 172.25.1.0/24 - 172.25.254.0/24
You can see the project's important variables in the .env
file after running the pre-build script.
Note: If using the og-cli
tool, you do not need to run the pre-build.sh
script.
Otherwise:
- Run the pre build script with a Project ID:
./pre-build.sh example
If you do not have any backups in the root backup
directory, the installation scripts will look for the backup files in /opt/tbs/docker/backup
- Create the directory
sudo mkdir -p /opt/tbs/docker/backup
- Set permissions
sudo chmod 777 -R /opt/tbs/docker/backup
- /opt/tbs/docker/backup directory. In it, place the following files:
- For Drupal:
drupal_db.pgdump
(Required) <- the database backup for the Drupal site.drupal_files.tgz
(Required) <- the compressed folder of the public files from the Drupal site.
- For CKAN:
ckan_portal_db.pgdump
(Optional) <- the database backup for the CKAN Portal app.ckan_portal_ds_db.pgdump
(Optional) <- the database backup for the CKAN Portal Datastore.ckan_registry_db.pgdump
(Optional) <- the database backup for the CKAN Registry app.ckan_registry_ds_db.pgdump
(Optional) <- the database backup for the CKAN Registry Datastore.
- For Solr:
inventory.csv
(Optional) <- Open Data Inventory data set csv file.
- For Drupal:
To override the use of the global backups during the installation scripts, place any of the above files into the root backup
directory.
- Build the container:
docker-compose build
- The initial build will take a long time.
- If you are rebuilding and receive errors such as
max depth exceeded
, you may need to destroy all of the docker images (docker image prune -a
) and then run the above build command. Please note that this will also destroy any other docker images you have on your machine. - If your build fails with errors regarding failure of resolving domains, restart your docker service (
sudo service docker restart
).
- Bring up the app and detach the shell:
docker-compose up -d
to make sure that all the containers can start correctly.- The initial up may take a long time.
- To stop all the containers:
docker-compose down
Though there is an initialization script to create the databases on the initial up of the postgres
container, this script only runs once. After you have built the containers once, this script will no longer run. To fix any issues with missing databases, users, or password:
- Bring up the Drupal or CKAN docker container:
docker-compose up -d <drupal or ckan>
- Run the install script in the docker container:
docker-compose exec <drupal or ckan> bash
and then./install.sh
- Select
Databases (fixes missing databases, privileges, and users)
- Select
Test Databases (clones existing databases into empty ones)
(Optional for destructive, unit tests)
- Select
- Bring up the Drupal docker container:
docker-compose up -d drupal
- Run the install script in the docker container:
docker-compose exec drupal bash
and then./install.sh
- Select
Drupal
- Select what you want to install for Drupal:
Database
: will destroy the currentog_drupal_local
database and import a fresh one frombackup/drupal_db.pgdump
Repositories
: will destroy all files inside of thedrupal
directory and pull all required repositories related to Drupal.Local Files
: will destroy all Drupal local files and extract the directory frombackup/drupal_files.tgz
.Set File Permissions (also creates missing directories)
: will download default settings files, copydrupal-local-settings.php
create the private files directory, and set the correct file and directory ownerships and permissions.Create Local User
: will create a local admin user for Drupal.All
: will execute all of the above, use this for first time install or if you wish to re-install everything.Exit
: will exit the installation script.
- Select
- Login here:
https://open.local/en/user/login
- Username:
admin.local
- Password:
12345678
- Username:
- Bring up the CKAN Registry docker container:
docker-compose up -d ckan
- Run the install script in the docker container:
docker-compose exec ckan bash
and then./install.sh
- Select
CKAN (registry)
- Select what you want to install for CKAN Registry:
Registry Database
: will destroy the currentog_ckan_registry_local
database and import a fresh one frombackup/ckan_registry_db.pgdump
- Importing a database is optional, if the file does not exist, this step will be skipped automatically.
- The database for CKAN Registry is not too large, however it has a lot of tables so importing the database will take a long time.
- You may recieve warnings during the pg_restore:
out of shared memory
, this can be ignored, the import will just take longer.
Registry Datastore Database
: will destroy the currentog_ckan_registry_ds_local
database and import a fresh one frombackup/ckan_registry_ds_db.pgdump
- Importing a database is optional, if the file does not exist, this step will be skipped automatically.
- The database for CKAN Registry is not too large, however it has a lot of tables so importing the database will take a long time.
- You may recieve warnings during the pg_restore:
out of shared memory
, this can be ignored, the import will just take longer.
Repositories
: will destroy all files inside of theckan/registry
directory, and pull & install all required repositories related to CKAN and install them into the Python environment (along with their requirements).Downlod Wet-Boew Files
: will destroy all files inside of theckan/static_files
direcotry, and download and extract:wet-boew-cdn
intockan/static_files/wet-boew
themes-cdn
intockan/static_files/GCWeb
Set File Permissions
: will set the correct file and directory ownerships and permissions.- This will also set the correct database permissions for CKAN.
Create Local User
: will create a local admin user for CKAN Registry.Import Organizations
: will dump the most recent Organizations from the ckanapi and import them into the database.Import Datasets
: will download the most recent dataset file and import them into the datase.- This will import all 30k+ resources. This may take a long time.
All
: will execute all of the above, use this for first time install or if you wish to re-install everything.Exit
: will exit the installation script.
- Select
- Bring up the CKAN Portal docker container:
docker-compose up -d ckanapi
- Run the install script in the docker container:
docker-compose exec ckanapi bash
and then./install.sh
- Select
CKAN (portal)
- Select what you want to install for CKAN Portal:
Portal Database
: will destroy the currentog_ckan_portal_local
database and import a fresh one frombackup/ckan_portal_db.pgdump
- Importing a database is optional, if the file does not exist, this step will be skipped automatically.
- The database for CKAN is large, so importing the database will take a long time.
- You may recieve warnings during the pg_restore:
out of shared memory
, this can be ignored, the import will just take longer.
Portal Datastore Database
: will destroy the currentog_ckan_portal_ds_local
database and import a fresh one frombackup/ckan_portal_ds_db.pgdump
- Importing a database is optional, if the file does not exist, this step will be skipped automatically.
- The database for CKAN is large, so importing the database will take a long time.
- You may recieve warnings during the pg_restore:
out of shared memory
, this can be ignored, the import will just take longer.
Repositories
: will destroy all files inside of theckan/portal
directory, and pull & install all required repositories related to CKAN and install them into the Python environment (along with their requirements).Downlod Wet-Boew Files
: will destroy all files inside of theckan/static_files
direcotry, and download and extract:wet-boew-cdn
intockan/static_files/wet-boew
themes-cdn
intockan/static_files/GCWeb
Set File Permissions
: will set the correct file and directory ownerships and permissions.- This will also set the correct database permissions for CKAN.
Create Local User
: will create a local admin user for CKAN Portal.Import Organizations
: will dump the most recent Organizations from the ckanapi and import them into the database.Import Datasets
: will download the most recent dataset file and import them into the datase.- This will import all 30k+ resources. This may take a long time.
All
: will execute all of the above, use this for first time install or if you wish to re-install everything.Exit
: will exit the installation script.
- Select
- Bring up the Django docker container:
docker-compose up -d django
- Run the install script in the docker container:
docker-compose exec django ./install.sh
- Select
Django
- Select what you want to install for Django:
OGC Django Search App (version 1)
: will destory the current Python virtual environment (if it exists) and install a fresh one, pull the ogc_search repository and copysearch-settings.py
to the environment.- This will also download the required CKAN yaml and json files.
Static Files
: will download the required files, including the GCWeb theme and GCWeb Static release from the CDTS repository.- It will also copy files to the correct locations for serving them correctly.
Set File Permissions
: will set the correct file and directory ownerships and permissions.All
: will execute all of the above, use this for first time install or if you wish to re-install everything.Exit
: will exit the installation script.
- Select
- Bring up the Drupal docker container:
docker-compose up -d drupal
- Open a browser into:
http://open.local:<project port>
- Login here:
http://open.local:<project port>/en/user/login
- Username:
admin.local
- Password:
12345678
- Username:
Multisites are also available at:
http://blog.open.local:<project port>
http://guides.open.local:<project port>
The Solr container will automatically be brought up with the CKAN and Drupal containers.
- Bring up the Solr docker container:
docker-compose up -d solr
- Open a browser into:
http://solr.open.local:<project port>
The Postgres container will automatically be brought up with the CKAN and Drupal containers.
- Bring up the Postgres docker container:
docker-compose up -d postgres
- You can use the pgAdmin software to connect to the Postgres container and query the databases.
- For the connection info:
- Hostname/address:
127.0.0.1
- Port:
<project database port>
- Username:
homestead
- Maintenance database:
postgres
- Hostname/address:
- Bring up the CKAN Registry docker container:
docker-compose up -d ckan
- Open a browser into:
http://registry.open.local:<project port>
- Login here:
http://registry.open.local:<project port>/en/user/login
- Normal User:
- Username:
user_local
- Password:
12345678
- Username:
- Sys Admin User:
- Username:
admin_local
- Password:
12345678
- Username:
- Normal User:
- Login here:
- Build the indices (Optional):
- Inventory:
ckan inventory rebuild --lenient -c $REGISTRY_CONFIG -f /srv/app/backup/inventory.csv
- Inventory:
- Bring up the CKAN Portal docker container:
docker-compose up -d ckanapi
- Open a browser into:
http://open.local:<project port>/data/en/dataset
- Bring up the Django docker container:
docker-compose up -d django
- Open a browser into:
http://search.open.local:<project port>
If you need to upgrade major versions of PostgreSQL, you can dump all of the databases via the install script, and restore them all after the PostgreSQL major version upgrade.
-
While still on your current version of PostgreSQL (viewable in the Dockerfile at
docker/postgres/Dockefile
).FROM postgres:9.6
-
Bring up the Drupal or CKAN docker container:
docker-compose up -d <drupal or ckan>
-
Run the install script in the docker container:
docker-compose exec <drupal or ckan> bash
and then./install.sh
- Select
Postgres Upgrade (dump and load existing databases for psql version upgrade)
- Select
Dump all existing databases (do PRIOR to Postgres version upgrade)
(Do this prior to upgrading the Postgres major version)
- Select
-
Bring down all the containers:
docker-compose down
-
Modify the Dockerfile
docker/postgres/Dockefile
:FROM postgres:13.14
-
Rebuild the postgres container:
docker-compose build postgres
-
Run the install script in the docker container:
docker-compose exec <drupal or ckan> bash
and then./install.sh
- Select
Postgres Upgrade (dump and load existing databases for psql version upgrade)
- Select
Restore all databases (do AFTER Postgres version upgrade)
(Do this after upgrading the Postgres major version)
- Select