-
Notifications
You must be signed in to change notification settings - Fork 2
Operations
This document provides details of several features assocated with tagbase-server operations.
It is written primarily for system administrators rather than developers or users.
tagbase-server uses a very traditional logging convention where application, HTTP server events and logs are captured. Upon initialization, the tagbase-server stack will begin to capture events and log them in the application container. If this were all that were configured then these logs would be lost if the tagbase-server application container were destroyed! Don't worry, keep reading below.
With log preservation in mind, we therefore configured a volume mount within the docker-compose.yml configuration file which persists an exact copy of the logging artifacts to the physical host machine running tagbase-server virtual host. See below for more details on the logging artifacts.
When you start tagbase-server, on the physical host machine you will now see a logs
directory which contains
logs % tree
.
├── gunicorn_access_log.txt <<<<< gunicorn WSGI HTTP server access requests
├── gunicorn_error_log.txt <<<<< gunicorn WSGI HTTP server errors
└── tagbase_server_log.txt <<<<< tagbase-server Flask application logs
This log separation is aimed to provide an intuitive and simple mechanism for understanding how tagbase-server is being used, what the application is being asked to do, how it is doing it and maybe most importantly what is going wrong!
If you have suggestions or requests concerning logging, please open an issue.
You will be glad to know that similar to how logs (see above) are streamed to a persistent volume claim on the physical host, so is all PostgreSQL data. A physical duplicate is created upon the PostgreSQL container initialization and is stored on the physical host in a directory named postgres-data
which contains similar to the following...
postgres-data % tree -L 2
.
└── pgdata
├── PG_VERSION
├── base
├── global
├── pg_commit_ts
├── pg_dynshmem
├── pg_hba.conf
├── pg_ident.conf
├── pg_logical
├── pg_multixact
├── pg_notify
├── pg_replslot
├── pg_serial
├── pg_snapshots
├── pg_stat
├── pg_stat_tmp
├── pg_subtrans
├── pg_tblspc
├── pg_twophase
├── pg_wal
├── pg_xact
├── postgresql.auto.conf
├── postgresql.conf
├── postmaster.opts
└── postmaster.pid
18 directories, 7 files
We cannot stress enough how important it is to create another duplicate copy of the physical postgres-data
and logs
directories. Ideally they would be stored on a separate physical machine or maybe in the cloud. It would be wise to back up these artifacts frequently to avoid data loss. For example, one could easily write a cron job which uses scp to duplicate the artifacts to another machine every hour. This will give you confidence, improve your operational readiness and give you a fighting chance of recovering quickly in a disaster recovery situation.
tagbase-server can be (optionally) very easily configured to post real-time notifications to a Slack workspace channel. With Slack now being the defacto workplace messaging platform, integration with tagbase-server can really streamline operations tasks because
- all tagbase errors are sent to a centralized Slack channel which Admins can also join
- events and associated notifications are sent in real-time and can be acted upon in a prompt fashion
The following steps will allow you to integrate tagbase-server and Slack
If you don't already have one, create a Slack workspace. Also create the channel you wish to use for Ops i.e. tagbase-server-ops
or similar.
Create and install an app; specifically follow the prompts
Add features and functionality; always save your work so it doesn't get lost!
If you wish, you can grab the Tagbase logo
Note the App Credentials
You need to add at least one feature or permission scope before you can install your app. Until you do that the Install to Workspace button will be grey as follows, Simply follow the permission scope hyperlink
Add the following scopes to the Scopes section
Once you do this you will be rewarded with a OAUTH TOKEN as below. Make note of the one you generate as you will use it later on.
The Install to Workspace button will now be green so click it and add the app to the relevant channel you created earlier.
In your Slack client, on the left hand side, you will now see that your App is registered
Invite your app to the channel specified above. Simply use the @
in the channel and look for the app name then tag the app. This will prompt you to add the app to the channel as follows
Send a test message to make sure everything is working fine.
import os
from slack_sdk import WebClient
from slack_sdk.errors import SlackApiError
slack_token = os.environ["SLACK_BOT_TOKEN"] <<<<<<<<< OAUTH token you created above
client = WebClient(token=slack_token)
try:
response = client.chat_postMessage(
channel="C0XXXXXX", <<<<<<<<<<< target channel you wish to post to
text="Hello from your app! :tada:"
)
except SlackApiError as e:
# You will get a SlackApiError if "ok" is False
assert e.response["error"] # str like 'invalid_auth', 'channel_not_found'
If everything went well you will see something similar to the following
Simply add the following parameters to the .env
configuration file
-
SLACK_BOT_TOKEN
- OAUTH token (from above) -
SLACK_BOT_CHANNEL
- Slack channel you wish to post your messages to
Obtain the container identifier
tagbase-server % docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
...
3962ed298641 tagbase-server_postgres "docker-entrypoint.s…" 2 minutes ago Up 2 minutes (healthy) 0.0.0.0:5432->5432/tcp tagbase-server_postgres_1
SSH into the container
docker exec -it 3962ed298641 /bin/bash
You can now access PostgreSQL via the psql interactive terminal.
To access any other PostgreSQL database you can simply use the -h (hostname) parameters.