Co-authored-by: Hector Hurtado <hector.hurtado@bbva.com> Co-authored-by: pancho horrillo <pedrofelipe.horrillo@bbva.com>
142 lines
3.6 KiB
ReStructuredText
142 lines
3.6 KiB
ReStructuredText
User Profile
|
|
============
|
|
|
|
Before You Start
|
|
----------------
|
|
|
|
Needed Skills:
|
|
|
|
#. Basic Linux
|
|
#. Proficient shell
|
|
#. How HTTP works
|
|
|
|
Needed Tools:
|
|
|
|
#. Linux machine
|
|
#. Installed Kapow! distribution
|
|
|
|
Motive
|
|
------
|
|
|
|
Use Kapow! to expose some Linux Box internal metrics and actions as an HTTP API for third party users.
|
|
|
|
Scenario
|
|
--------
|
|
|
|
User is a DevOps at ACME Company.
|
|
|
|
ACME Company appears to be a conglomerate which produces and sells every product type imaginable.
|
|
|
|
ACME's Infrastructure
|
|
---------------------
|
|
|
|
- 2 Linux machines
|
|
|
|
- Corporate Server
|
|
- Backup Server
|
|
|
|
User Journey
|
|
------------
|
|
|
|
#. Actions over the server. Launch database backup script with an HTTP call.
|
|
|
|
- User Learns: Add a route that executes a command locally.
|
|
- Kapow! Concepts: `kapow route add`
|
|
- Problem/Motivation: Each time an ACME project is finished it is
|
|
desirable to make a backup of the entire database. Given that the
|
|
database server is a critical machine we don't want to grant SSH
|
|
access to lowly developers. The script is very fast because the
|
|
database is small (for now).
|
|
- Solution: Instead of launching the script via SSH shell we can
|
|
provide an HTTP endpoint to perform the task.
|
|
```
|
|
ssh user@server
|
|
$ ./backup_db.sh
|
|
```
|
|
- Final Kapow!:
|
|
```
|
|
curl -X PUT http://server:8080/db/backup
|
|
```
|
|
```
|
|
kapow route add -X PUT /db/backup -e ./backup_db.sh
|
|
```
|
|
|
|
#. Basic server monitoring
|
|
|
|
- User Learns: Execute local commands and output it results to the HTTP body.
|
|
- Kapow! Concepts: `kapow set /response/body`
|
|
- Problem/Motivation:
|
|
- Solution:
|
|
- Final Kapow!:
|
|
```
|
|
cat /var/log/backup_db.log | kapow set /response/body
|
|
```
|
|
|
|
#. Filter over basic monitoring
|
|
|
|
- User Learns: Get a parameter from the user and use it to select the
|
|
script.
|
|
- Kapow! Concepts: `kapow get /request/params`
|
|
- Problem/Motivation:
|
|
- Solution:
|
|
- Final Kapow!:
|
|
```
|
|
LINES="$(kapow get /request/params/lines)"
|
|
FILTER="$(kapow get /request/params/filter)"
|
|
grep "$FILTER" /var/log/backup_db.log \
|
|
| tail -n"$LINES" \
|
|
| kapow set /response/body
|
|
```
|
|
|
|
#. Advanced database monitoring
|
|
|
|
- User Learns: Compose complex HTTP responses with more than one local command.
|
|
- Kapow! Concepts: HEREDOC and subshells
|
|
- Problem/Motivation:
|
|
- Solution:
|
|
- Final Kapow!:
|
|
```
|
|
{
|
|
echo Memory:
|
|
free -m
|
|
echo ================================================================================
|
|
echo Load:
|
|
uptime
|
|
echo ================================================================================
|
|
echo Disk:
|
|
df -h
|
|
} | kapow set /response/body
|
|
```
|
|
|
|
#. Share your achievements
|
|
|
|
- User Learns: Format a complex HTTP response with JSON format to feed the corporate dashboard.
|
|
- Kapow! Concepts: backtick interpolation and `kapow set /response/headers`
|
|
- Problem/Motivation:
|
|
- Solution:
|
|
- Final Kapow!:
|
|
``` DON'T HANDWRITE JSON
|
|
echo "{memory: `free -m`, ...uups..}' | kapow set /response/body
|
|
```
|
|
|
|
``` USE JQ
|
|
MEMORY=$(free -m)
|
|
LOAD=$(uptime)
|
|
DISK=$(df -h)
|
|
jq -nc --arg memory "$MEMORY" '{"memory": $memory}'
|
|
```
|
|
|
|
Ideas
|
|
-----
|
|
|
|
- /request/params -> Filter the results of a backup query
|
|
- Use redirects to from one Kapow! server to another. I.e: 192.168.1.1/backups/{path:.*} --> 192.168.1.2/<path>
|
|
- /request/files -> Firma el fichero que sube el usuario y te lo devuelve firmado.
|
|
|
|
|
|
.. note::
|
|
|
|
Add this to serve the webpage that uses the implemented HTTP API
|
|
kapow route add / -c 'kapow set /resonse/headers/Content-Type text/html ; curl --output - http:// | kapow set /response/body'
|
|
|