Skip to content

Commit

Permalink
feat: add Zilla Plus on Fargate guide (#267)
Browse files Browse the repository at this point in the history
  • Loading branch information
vordimous authored Oct 30, 2024
1 parent 5edb3f3 commit d64a451
Show file tree
Hide file tree
Showing 3 changed files with 256 additions and 0 deletions.
1 change: 1 addition & 0 deletions cspell.json
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@
"docsearch",
"etag",
"fanout",
"Fargate",
"fontawesome",
"gitea",
"Grammarly",
Expand Down
6 changes: 6 additions & 0 deletions src/.vuepress/sidebar/en.ts
Original file line number Diff line number Diff line change
Expand Up @@ -385,6 +385,12 @@ export const enSidebar = sidebar({
},
],
},
{
text: "Zilla Plus on AWS ECS Fargate",
icon: "aky-zilla-plus",
link: "how-tos/zilla-plus-aws-ecs-fargate.md",
children: [],
},
{
text: "Secure Public Access on AWS",
icon: "aky-zilla-plus",
Expand Down
249 changes: 249 additions & 0 deletions src/how-tos/zilla-plus-aws-ecs-fargate.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,249 @@
---
icon: aky-zilla-plus
description: This Guide will walk you through deploying a simple Zilla Plus service running on AWS ECS Fargate. Zilla Plus is an enterprise-ready, Kafka-native edge, and service proxy. It is a flexible, secure, and reliable way of creating stateless, multi-protocol API entry points into your Kafka cluster for both native and non-native Kafka clients.
---

# Deploying Zilla Plus on AWS ECS Fargate

[Available in <ZillaPlus/>](https://www.aklivity.io/products/zilla-plus)
{.zilla-plus-badge .hint-container .info}

::: info Estimated time to complete 10-15 minutes.
:::

## Overview

The [<ZillaPlus/>](https://aws.amazon.com/marketplace/pp/prodview-lqfqftufwpttm) is an enterprise-ready, Kafka-native edge, and service proxy. It is a flexible, secure, and reliable way of creating stateless, multi-protocol API entry points into your Kafka cluster for both native and non-native Kafka clients. With <ZillaPlus/>, you can create publicly reachable Kafka endpoints into a Kafka cluster. You can also expose topics inside your Kafka cluster via declaratively defined REST, SSE, gRPC, and MQTT APIs.

This Guide will walk you through deploying your first <ZillaPlus/> service on AWS ECS Fargate.

## Prerequisites

- An Amazon ECS cluster
- An Amazon ECR repository or another container repository
- A Subscription to the <ZillaPlus/> [product on Amazon Marketplace](https://aws.amazon.com/marketplace/pp/prodview-lqfqftufwpttm)

## Build The HTTP Echo solution FROM the Zilla Plus base image

> This will create a container image with the necessary config files inside.
- From the active <ZillaPlus/> [subscription page](https://aws.amazon.com/marketplace/server/procurement?productId=prod-amntslj4ggryw)

- Click `Continue to Configuration`
- Fulfillment option: `Zilla Plus`
- Software version: `Select the most recently released version`
- Click `Continue to Launch`
- Copy and run the `aws` login command from the Container images section to confirm you can pull the <ZillaPlus/> container image.
- Note the image name `709825985650.dkr.ecr.us-east-1.amazonaws.com/aklivity/zilla-plus-ecr:<version>` and one of the version tags stored in the `CONTAINER_IMAGES` variable, which will be used later.

- Create the below `Dockerfile` with the <ZillaPlus/> container image using the version tag you got from the previous steps. Use the `COPY` instruction to add the `zilla.yaml` below to your container image.

::: code-tabs

@tab Dockerfile

```Dockerfile
FROM 709825985650.dkr.ecr.us-east-1.amazonaws.com/aklivity/zilla-plus-ecr:<version>-alpine

COPY ./zilla.yaml /etc/zilla/zilla.yaml
```

@tab zilla.yaml

```yaml
---
name: http-echo
bindings:
north_tcp_server:
type: tcp
kind: server
options:
host: 0.0.0.0
port:
- 7114
routes:
- when:
- port: 7114
exit: north_http_server
north_http_server:
type: http
kind: server
routes:
- when:
- headers:
:scheme: http
exit: north_echo_server
north_echo_server:
type: echo
kind: server
telemetry:
exporters:
stdout_logs_exporter:
type: stdout
```
:::
::: note Adding other files
Any other files used in your `zilla.yaml` can be added to the container in the same directory as the `zilla.yaml` config.

```Dockerfile
COPY ./zilla.yaml /etc/zilla/zilla.yaml
COPY ./tls /etc/zilla/tls
COPY ./specs /etc/zilla/specs
```

:::

- Build your image to be pushed to [Amazon ECR](https://docs.aws.amazon.com/AmazonECR/latest/userguide/docker-push-ecr-image.html) or another registry.

```bash
docker build -t zp-example/http-echo:v1 .
```

::: important Build with the correct Architecture
Use the `docker build --platform` option to match the desired [cpuArchitecture](https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_RuntimePlatform.html#API_RuntimePlatform_Contents) that you can configure in your ECS task.
:::

- Tag your image with the remote repository name and tag.

```bash
docker tag zp-example/http-echo:v1 [your-registry-url]/zp-example/http-echo:v1
```

- Push your image to your remote repository.

```bash
docker push [your-registry-url]/zp-example/http-echo:v1
```

## Create an AWS ECS Fargate Task for your service

> This will create the AWS ECS Fargate Task that will be used to deploy your service.

- Create an IAM role for the Task. This role will be used by the running <ZillaPlus/> container.

::: tabs

@tab Task role

Name:

```text
ecsTaskRole_ZillaPlus
```

Policies:

```text
AWSMarketplaceMeteringFullAccess
AWSMarketplaceMeteringRegisterUsage
```

:::

- If you used the Amazon ECR as your image repository, create a role with the `AmazonECSTaskExecutionRolePolicy` permission and use it as the `Task execution role` when creating the Task.

::: tabs

@tab Task execution role

Name:

```text
ecsTaskExecutionRole
```

Policies:

```text
AmazonECSTaskExecutionRolePolicy
```

:::

- [Create a new Task Definition](https://us-east-1.console.aws.amazon.com/ecs/v2/create-task-definition-with-json) from JSON
- Substitute `<your-registry-url>`, `<ecsTaskRole_ZillaPlus ARN>`, and `<ecsTaskExecutionRole ARN>` for their respective values.

::: code-tabs

@tab Task Definition JSON

```json
{
"family": "zilla-plus-http-echo-fargate",
"networkMode": "awsvpc",
"containerDefinitions": [
{
"name": "zp-http-echo",
"image": "<your-registry-url>/zp-example/http-echo:v1",
"portMappings": [
{
"name": "http",
"containerPort": 7114,
"hostPort": 7114,
"protocol": "tcp",
"appProtocol": "http"
}
],
"essential": true,
"command": ["start", "-v", "-e"],
"logConfiguration": {
"logDriver": "awslogs",
"options": {
"awslogs-group": "/ecs/",
"mode": "non-blocking",
"awslogs-create-group": "true",
"max-buffer-size": "25m",
"awslogs-region": "us-east-1",
"awslogs-stream-prefix": "ecs"
}
}
}
],
"requiresCompatibilities": ["FARGATE"],
"taskRoleArn": "<ecsTaskRole_ZillaPlus ARN>",
"executionRoleArn": "<ecsTaskExecutionRole ARN>",
"cpu": "1 vCPU",
"memory": "3 GB"
}
```

:::

## Create a Service from your AWS ECS Fargate Task

> This will create a service based on the configuration in the Task.

- [Create a Service](https://us-east-1.console.aws.amazon.com/ecs/v2/clusters/my-ecs-cluster/create-service) from your new task.
- Deployment configuration:
- Family: `zilla-plus-http-echo-fargate`
- Service name: `Your Zilla Plus HTTP Echo service`
- Network configuration:
- Set the VPC to be the Same as your ECS Cluster.
- Make sure the security group allows traffic over the ports defined `portMappings` of the service.
- Select the Public subnets.
- Make sure the `Public IP` flag to true.
- `Create` the Service.

## Verify your service is running

> This will call the service and get an echoed response.

Once the service has started with all tasks succeeding, you will see the <ZillaPlus/> container log `"started"`.

- Get the Public IP of the running Task in your service.
- Call the HTTP Echo service.

```bash
curl -d "Hello, world" -H "Content-Type: text/plain" -X "POST" http://[Task Public IP]:7114
```

```output
Hello, world
```

- In your Task logs, you will see a `BINDING_HTTP_REQUEST_ACCEPTED` log from the above request

Congratulations! You have successfully deployed your first <ZillaPlus/> service using AWS ECS Fargate.

0 comments on commit d64a451

Please sign in to comment.