-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
35 changed files
with
965 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
# `platys` - What's new? | ||
|
||
## What's new in 2.2.0 | ||
|
||
Platys 2.2.0 contains the following new functionalities and enhancements: | ||
|
||
### New Functionality | ||
|
||
* first version of a `clean` command | ||
|
||
### Enhancements | ||
|
||
* `--structure` flag moved from `gen` to `init` command | ||
|
||
## What's new in 2.1.0 | ||
|
||
Platys 2.1.0 contains the following new functionalities and enhancements: | ||
|
||
### New Functionality | ||
|
||
* supports CentOS 7 | ||
|
||
## What's new in 2.0.0 | ||
|
||
Platys 2.0.0 contains the following new functionalities and enhancements: | ||
|
||
### New Functionality | ||
|
||
* supports windows | ||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
# `platys` command-line reference | ||
|
||
The following pages describe the usage information for the `platys` subcommands. | ||
|
||
You can also see this information by running `platys [SUBCOMMAND] --help` from the command line. | ||
|
||
* [platys](overview-platys-command.md) | ||
* [init](platys-init-command.md) | ||
* [gen](platys-gen-command.md) | ||
* [clean](platys-clean-command.md) | ||
* [list_services](platys-list_services-command.md) | ||
|
||
## Where to go next | ||
|
||
* [Available Platform Stacks](../platform-stacks) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
# Creating and Maintaining a Platform Stack | ||
|
||
A Platform Stack has to be provided as a docker image. It contains the generator template, the config file as well as the static artefacts necessary for running the docker-compose.yml generated by the stack. | ||
|
||
A generator is based on the [Docker Compose Templer](https://github.com/Aisbergg/python-docker-compose-templer) project, a small utility that adds more dynamism to Docker Compose files by utilizing the Jinja2 template engine. We added some wrapper logic around it to make it easier to use. | ||
|
||
The implementation of a generator supporting a platform version and platform type is contained in a docker image itself, which is completly independent of the MDP tool itself. Currently there is only one pla | ||
|
||
## How to build | ||
The service generator is available as a docker image from where it can be run. | ||
|
||
It can be found on [Docker Hub](https://hub.docker.com/repository/docker/trivadis/modern-data-platform-stack-generator) under `trivadis/modern-data-platform-stack-generator`. | ||
|
||
If you want to build the docker image locally, perform (this is not necessary if you follow the installation instructions below). | ||
|
||
``` | ||
docker build -t trivadis/platys-modern-data-platform:1.3.0 . | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,143 @@ | ||
# Provision on AWS Lightsail | ||
|
||
Navigate to the [AWS Console](http://console.aws.amazon.com) and login with your user. Click on the [Lightsail service](https://lightsail.aws.amazon.com/ls/webapp/home/instances). | ||
|
||
data:image/s3,"s3://crabby-images/84878/84878fbec447ab3bd8c44a88c488c1da6ee46dc1" alt="Alt Image Text" | ||
|
||
## Provision instance | ||
|
||
Click **Create instance** to navigate to the **Create an instance** dialog. | ||
|
||
data:image/s3,"s3://crabby-images/6d2be/6d2be7767372f57f76a829eb00086fce84aa09b8" alt="Alt Image Text" | ||
|
||
Optionally change the **Instance Location** to a AWS region of your liking. | ||
Keep **Linux/Unix** for the **Select a platform** and click on **OS Only** and select **Ubuntu 18.04 LTS** for the **Select a blueprint**. | ||
|
||
data:image/s3,"s3://crabby-images/881fc/881fc7c2062bd32b5a601397bfbb4c7b906a47d2" alt="Alt Image Text" | ||
|
||
Scroll down to **Launch script** and add the following script | ||
|
||
``` | ||
# Install Docker and Docker Compose | ||
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - | ||
add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable edge" | ||
apt-get install -y docker-ce | ||
sudo usermod -a -G docker ubuntu | ||
# Install Docker Compose | ||
sudo curl -L "https://github.com/docker/compose/releases/download/1.24.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose | ||
chmod +x /usr/local/bin/docker-compose | ||
ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose | ||
# Install ctop | ||
sudo wget https://github.com/bcicen/ctop/releases/download/v0.7.2/ctop-0.7.2-linux-amd64 -O /usr/local/bin/ctop | ||
sudo chmod +x /usr/local/bin/ctop | ||
# Install wget | ||
apt-get install -y wget | ||
# Install kafkacat | ||
apt-get install -y kafkacat | ||
# needed for elasticsearch | ||
sudo sysctl -w vm.max_map_count=262144 | ||
# Prepare Environment Variables | ||
export PUBLIC_IP=$(curl ipinfo.io/ip) | ||
export DOCKER_HOST_IP=$(ip addr show eth0 | grep "inet\b" | awk '{print $2}' | cut -d/ -f1) | ||
export COMPOSE_HTTP_TIMEOUT=300 | ||
cd /home/ubuntu | ||
git clone https://github.com/TrivadisBDS/modern-data-analytics-stack.git | ||
cd modern-data-analytics-stack/full-stack/docker | ||
# Startup Environment | ||
docker-compose up | ||
``` | ||
|
||
into the **Launch Script** edit field | ||
|
||
data:image/s3,"s3://crabby-images/e68e1/e68e122e49a833452ec71a0a5e061dab36fa3b72" alt="Alt Image Text" | ||
|
||
Click on **Change SSH key pair** and leave the **Default** selected and then click on **Download** and save the file to a convenient location on your machine. Under **Choose your instance plan** click on the arrow on the right and select the **16 GB** instance. | ||
|
||
Under **Identify your instance** enter **Ubuntu-Analytics-Platform** into the edit field. | ||
|
||
data:image/s3,"s3://crabby-images/5ea0b/5ea0b74b50a749f81d494749c19a3a657306395d" alt="Alt Image Text" | ||
|
||
Click on **Create Instance** to start provisioning the instance. | ||
|
||
The new instance will show up in the Instances list on the Lightsail homepage. | ||
|
||
data:image/s3,"s3://crabby-images/d65d9/d65d915b9d515a7bba51a099cb6dd4d118ce9db5" alt="Alt Image Text" | ||
|
||
Click on the instance to navigate to the image details page. On the right you can find the Public IP address **18.196.124.212** of the newly created instance. | ||
|
||
data:image/s3,"s3://crabby-images/f5ad1/f5ad142eb8e9e54b4ecc51eb11356d3342c756bf" alt="Alt Image Text" | ||
|
||
Next we have to configure the Firewall to allow traffic into the Lightsail instance. | ||
|
||
Click on the **Networking** tab/link to navigate to the network settings and under **Firewall** click on **+ Add another**. | ||
We allow TCP traffic on ports 28000 - 28200 by selecting **Custom**, entering **28000 - 28200** into the **Port range** field and then click **Save**. | ||
|
||
data:image/s3,"s3://crabby-images/f5940/f59408355a48423323c21d202ed79b50b9aa2872" alt="Alt Image Text" | ||
|
||
Now let's see how the provisioning of the lightsail instance is doing. | ||
Navigate to the **Connect** tab and click **Connect using SSH** to open the console and enter the following command to watch the log file of the init script. | ||
|
||
``` | ||
tail -f /var/log/cloud-init-output.log --lines 1000 | ||
``` | ||
|
||
The initialisation is finished when you see the `Creating xxxxx .... done` lines after all the docker images have been downloaded, which takes a couple of minutes. | ||
|
||
data:image/s3,"s3://crabby-images/3a2a0/3a2a0a5b051251362b05bce2dd4aebfa889023a3" alt="Alt Image Text" | ||
|
||
Optionally you can also SSH into the Lightsail instance using the **SSH key pair** you have downloaded above. For that open a terminal window (on Mac / Linux) or Putty (on Windows) and connect as ubuntu to the Public IP address of the instance. | ||
|
||
``` | ||
ssh -i LightsailDefaultKey-eu-central-1.pem ubuntu@18.196.124.212 | ||
``` | ||
|
||
Your instance is now ready to use. Complete the post installation steps documented the [here](README.md). | ||
|
||
## Stop an Instance | ||
|
||
To stop the instance, navigate to the instance overview and click on the drop-down menu and select **Stop**. | ||
|
||
data:image/s3,"s3://crabby-images/71541/715416fa16df4d37cace623cd965f67ec2500ae6" alt="Alt Image Text" | ||
|
||
Click on **Stop** to confirm stopping the instance. | ||
|
||
data:image/s3,"s3://crabby-images/79793/797936c771e58c11a04e3dc46c6e1a1615db08d7" alt="Alt Image Text" | ||
|
||
A stopped instance will still incur charges, you have to delete the instance completely to stop charges. | ||
|
||
## Delete an Instance | ||
|
||
t.b.d. | ||
|
||
## Create a snapshot of an Instance | ||
|
||
When an instance is stopped, you can create a snapshot, which you can keep, even if later drop the instance to reduce costs. | ||
|
||
data:image/s3,"s3://crabby-images/267ab/267ab8d5fa8a73eee807876343f43047f76a6ecd" alt="Alt Image Text" | ||
|
||
You can always recreate an instance based on a snapshot. | ||
|
||
# De-provision the environment | ||
|
||
To stop the environment, execute the following command: | ||
|
||
``` | ||
docker-compose stop | ||
``` | ||
|
||
after that it can be re-started using `docker-compose start`. | ||
|
||
To stop and remove all running container, execute the following command: | ||
|
||
``` | ||
docker-compose down | ||
``` | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,72 @@ | ||
# Provision on Local Docker Environment | ||
|
||
Make sure that you have Docker and Docker Compose running on your local environment. To run docker on windows you need to have Windows 10. | ||
|
||
* Mac: <https://docs.docker.com/docker-for-mac/> | ||
* Windows 10: <https://docs.docker.com/docker-for-windows/install/> | ||
|
||
## Prepare Environment | ||
|
||
In the Virtual Machine, start a terminal window and execute the following commands. | ||
|
||
First let's add the environment variables. Make sure to adapt the network interface (**ens33** according to your environment. You can retrieve the interface name by using **ipconfig** on windows or **ifconfig* on Mac/Linux. | ||
|
||
``` | ||
# Set environment variables to match the IP address of the local machine | ||
export PUBLIC_IP=10.1.215.134 | ||
export DOCKER_HOST_IP=10.1.215.134 | ||
``` | ||
|
||
Now for Elasticsearch to run properly, we have to increase the `vm.max_map_count` parameter like shown below. | ||
|
||
``` | ||
# needed for elasticsearch | ||
sudo sysctl -w vm.max_map_count=262144 | ||
``` | ||
|
||
Now let's checkout the NoSQL Workshop project from GitHub: | ||
|
||
Navigate to your local folder, where you want to keep the workshop and execute the `git clone` command | ||
|
||
``` | ||
# Get the project | ||
git clone https://github.com/TrivadisBDS/modern-data-analytics-stack.git | ||
cd modern-data-analytics-stack/base-stack/docker | ||
``` | ||
|
||
## Start Environment | ||
|
||
And finally let's start the environment: | ||
|
||
``` | ||
# Make sure that the environment is not running | ||
docker-compose down | ||
# Startup Environment | ||
docker-compose up -d | ||
``` | ||
|
||
The environment should start immediately, as all the necessary images should already be available in the local docker image registry. | ||
|
||
The output should be similar to the one below. | ||
|
||
data:image/s3,"s3://crabby-images/86e84/86e845e042a8e0e1c2cb0f9fb67024be5b323c5f" alt="Alt Image Text" | ||
|
||
Your instance is now ready to use. Complete the post installation steps documented the [here](README.md). | ||
|
||
## Stop environment | ||
|
||
To stop the environment, execute the following command: | ||
|
||
``` | ||
docker-compose stop | ||
``` | ||
|
||
after that it can be re-started using `docker-compose start`. | ||
|
||
To stop and remove all running container, execute the following command: | ||
|
||
``` | ||
docker-compose down | ||
``` | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
# Provision on Local Virtual Machine Environment | ||
|
||
Open and start the virtual machine either by using **VMWare Workstation** on Windows or **VMWare Fusion** on Mac or **Virtual Box**. | ||
|
||
Currently the VM is configured to use 14 GB of Memory. If you have less than 16 GB in total available on your system, make sure to reduce it before starting the virtual machine. | ||
|
||
## Prepare Environment | ||
|
||
In the Virtual Machine, start a terminal window and execute the following commands. | ||
|
||
First let's add the environment variables. Make sure to adapt the network interface (**ens33** according to your environment. You can retrieve the interface name by using **ipconfig** on windows or **ifconfig* on Mac/Linux. | ||
|
||
``` | ||
# Prepare Environment Variables | ||
export PUBLIC_IP=$(curl ipinfo.io/ip) | ||
export DOCKER_HOST_IP=$(ip addr show ens33 | grep "inet\b" | awk '{print $2}' | cut -d/ -f1) | ||
``` | ||
|
||
Now for Elasticsearch to run properly, we have to increase the `vm.max_map_count` parameter like shown below. | ||
|
||
``` | ||
# needed for elasticsearch | ||
sudo sysctl -w vm.max_map_count=262144 | ||
``` | ||
|
||
Now let's checkout the NoSQL Workshop project from GitHub: | ||
|
||
``` | ||
# Get the project | ||
cd /home/bigdata | ||
git clone https://github.com/TrivadisBDS/modern-data-analytics-stack.git | ||
cd modern-data-analytics-stack/base-stack/docker | ||
``` | ||
|
||
## Start Environment | ||
|
||
And finally let's start the environment: | ||
|
||
``` | ||
# Make sure that the environment is not running | ||
docker-compose down | ||
# Startup Environment | ||
docker-compose up -d | ||
``` | ||
|
||
The environment should start immediately, as all the necessary images should already be available in the local docker image registry. | ||
|
||
The output should be similar to the one below. | ||
|
||
data:image/s3,"s3://crabby-images/86e84/86e845e042a8e0e1c2cb0f9fb67024be5b323c5f" alt="Alt Image Text" | ||
|
||
Your instance is now ready to use. Complete the post installation steps documented the [here](README.md). | ||
|
||
## Stop environment | ||
|
||
To stop the environment, execute the following command: | ||
|
||
``` | ||
docker-compose stop | ||
``` | ||
|
||
after that it can be re-started using `docker-compose start`. | ||
|
||
To stop and remove all running container, execute the following command: | ||
|
||
``` | ||
docker-compose down | ||
``` | ||
|
||
|
Oops, something went wrong.