forked from open-telemetry/opentelemetry-demo
-
Notifications
You must be signed in to change notification settings - Fork 19
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add EC2 based example for using OpenSearch OTEL demo on AWS hosted ma… (
#165) * add EC2 based example for using OpenSearch OTEL demo on AWS hosted machine Signed-off-by: YANGDB <[email protected]> --------- Signed-off-by: YANGDB <[email protected]>
- Loading branch information
Showing
14 changed files
with
141 additions
and
1 deletion.
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,140 @@ | ||
# Getting Started | ||
Getting started with the OTEL demo including running the OpenSearch Server and Dashboard. | ||
This Getting started tutorial will help you install a live OpenTelemetry Demo on top of an AWS EC2 instance. | ||
|
||
### Additional Resources | ||
- [DemoLandingPage.md](DemoLandingPage.md) | ||
- [GettingStarted.md](GettingStarted.md) | ||
- [Observability Introduction.md](Observability-Introduction.md) | ||
|
||
## Intro | ||
The OpenTelemetry Demo is a microservice distributed system intended to illustrate the implementation of OpenTelemetry in a near real-world environment. | ||
It provides a realistic example of a distributed system that can be used to demonstrate OpenTelemetry instrumentation and observability. | ||
|
||
> OpenTelemetry Demo is composed of microservices written in different programming languages that talk to each other over gRPC and HTTP | ||
data:image/s3,"s3://crabby-images/f33c2/f33c2a88edaaaad532779cb025b097534095b860" alt="" | ||
https://opentelemetry.io/docs/demo/architecture/ | ||
|
||
--- | ||
We use the above sample demo environment and solve simple questions that can be asked by an OS Observability Assistant user. Some initial questions we are working can be seen below: | ||
|
||
1. What is the current response time of the product catalog service? | ||
2. How many requests are being processed by the payment service per second? | ||
3. What is the average latency of the shopping cart service? | ||
4. Are there any errors being reported by the payment service? | ||
5. How many requests have been processed by the shopping cart service in the last hour? | ||
|
||
By analyzing the User interaction flow we can address these question among many others and investigate anomalies in the system | ||
|
||
data:image/s3,"s3://crabby-images/24cfc/24cfce6504477bdc8a9748e22097cba60a4fe11e" alt="" | ||
|
||
--- | ||
## Installation Using AWS | ||
This specific tutorial will help users to install the OpenSearch OpenTelemetry Demo on an EC2 instance and start experimenting with OpenSearch's Observability solutions. | ||
|
||
### Prerequisites | ||
- AWS account | ||
- GitHub Access | ||
- Some basic knowledge of Git & Docker | ||
|
||
### Step 1 | ||
|
||
_Setup an AWS account:_ | ||
|
||
data:image/s3,"s3://crabby-images/2c9ce/2c9ce84b17073f1e01cf29d9b1ab7592c6803881" alt="" | ||
|
||
Login in to your AWS account using the root user & Navigate to EC2 instance | ||
|
||
data:image/s3,"s3://crabby-images/b7914/b7914cd2186e403297ad7efffa3398c9b67aa23e" alt="" | ||
|
||
Create a security group for the OTEL-Demo instance | ||
data:image/s3,"s3://crabby-images/7bc15/7bc156d1ace34ffbce612d8d9b429139bc1ca7bc" alt="" | ||
|
||
Add inbound rules so that the different demo services will be accessible from the outside (not protected) | ||
data:image/s3,"s3://crabby-images/3dc67/3dc6777ba3a4e518affe3222ebdab7087ea6bdb3" alt="" | ||
|
||
### Ports We Open: | ||
- OpenSearch Dashboards 5601 | ||
- OpenSearch Node 9200 | ||
- FrontEnd web 8080 | ||
- FrontEnd Nginx Proxy 90 | ||
- Prometheus DB 9090 | ||
- locust Data Loader 8089 | ||
|
||
|
||
Create the key-pair that we will use to access the server from the terminal | ||
data:image/s3,"s3://crabby-images/b6baf/b6baf844fb5332e7f8921b9bab128d28345e7411" alt="" | ||
|
||
Initialize an AMI/Ubuntu instance using the security group and key pair that we created earlier, the memory (RAM) must not be less than 16 GB so T2 x large is recommended. | ||
data:image/s3,"s3://crabby-images/8d166/8d166728d89205d6c7dbcf711c99bfa71d103c2e" alt="" | ||
data:image/s3,"s3://crabby-images/c3805/c38050c55bf4a173554e8696ef14f5e57664bb02" alt="" | ||
|
||
Wait until instance is ready and connect to the terminal using the key-pair previously created | ||
data:image/s3,"s3://crabby-images/05b75/05b7509ee59c0a51af4cd5c4d881d0c3fc9c95d8" alt="" | ||
|
||
Connect into the Instance's terminal | ||
data:image/s3,"s3://crabby-images/3a154/3a154d680c9ed2006b5244aaa50bb254d3d9e233" alt="" | ||
|
||
### Terminal Setup | ||
Once in terminal - install the following: | ||
|
||
### Docker | ||
```bash | ||
sudo yum update -y | ||
sudo yum install docker -y | ||
sudo service docker start | ||
sudo usermod -a -G docker ec2-user | ||
``` | ||
Validate docker was installed correctly: | ||
```bash | ||
docker --version | ||
sudo docker run hello-world` | ||
``` | ||
Now install `docker-compose` | ||
```bash | ||
sudo curl -L "https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose | ||
sudo chmod +x /usr/local/bin/docker-compose | ||
``` | ||
Validate docker-compose was installed correctly: | ||
```bash | ||
docker-compose --version | ||
``` | ||
|
||
### OpenSearch OpenTelemetry-Demo | ||
Install `git` package | ||
```bash | ||
sudo yum install git -y | ||
``` | ||
now clone the opensearch open-telemetry demo project: | ||
```bash | ||
git clone https://github.com/opensearch-project/opentelemetry-demo.git | ||
``` | ||
|
||
### Running the Demo | ||
Go into the downloaded repo | ||
```bash | ||
cd opentelemetry-demo/ | ||
``` | ||
update the memory areas `vm.max_map_count` to support OpenSearch engine vm requirements | ||
```bash | ||
sudo sysctl -w vm.max_map_count=262144 | ||
``` | ||
|
||
Now run the docker-compose command: | ||
```bash | ||
docker-compose up -d | ||
``` | ||
Once the docker images are being downloaded and complete the build process and running, | ||
The terminal should look as follows: | ||
|
||
data:image/s3,"s3://crabby-images/4b850/4b850cae6efcff8e368ef460c33f0ed09527b009" alt="" | ||
|
||
--- | ||
|
||
Once All The services are running we can access the EC2's public domain name with the Security group's open ports. | ||
|
||
data:image/s3,"s3://crabby-images/27fce/27fce351dd21dd6fa9401ef1148aab8e75fdb20c" alt="" | ||
|
||
For This step please use the [Getting Started](GettingStarted.md) tutorial that contains login and operation instructions for using OpenSearch Observability | ||
User Experience. |
File renamed without changes.
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
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.