Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Eventcatalog docs #9

Merged
merged 4 commits into from
Dec 12, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion charts/eventcatalog/Chart.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ apiVersion: v2
name: eventcatalog
description: A Helm chart for deploying EventCatalog's static site
type: application
version: 0.1.0
version: 0.1.1
appVersion: "1.0.1"
maintainers:
- name: oso
153 changes: 153 additions & 0 deletions charts/eventcatalog/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,153 @@
# EventCatalog Helm Chart Instructions

This guide provides detailed instructions for deploying EventCatalog using the Helm chart. You can use the default configuration or customize the deployment to suit your needs, including examples with and without a domain.

## Table of Contents

1. [Introduction](#introduction)
2. [Adding the Helm Repository](#adding-the-helm-repository)
3. [Installing the EventCatalog Chart](#installing-the-eventcatalog-chart)
4. [Available Values to Override](#available-values-to-override)
5. [Example Configurations - values.yaml](#example-configurations---valuesyaml)
- [Without a Domain](#without-a-domain)
- [With a Domain](#with-a-domain)
6. [Building a Custom EventCatalog Image](#building-a-custom-eventcatalog-image)
7. [Default Image and Demo UI](#default-image-and-demo-ui)
8. [Additional Resources](#additional-resources)

## Introduction

EventCatalog helps you document, manage, and visualize the events in your microservices architecture. This guide walks you through deploying the Helm chart, configuring ingress, and setting up your instance with a default or custom image.

The deployment uses the **cert-manager** and **ingress-nginx** Helm charts for managing TLS certificates and ingress resources, respectively.

## Adding the Helm Repository

Add the Helm repository:

```bash
helm repo add oso-devops https://osodevops.github.io/helm-charts/
```

## Installing the EventCatalog Chart

Install the Helm chart using the following command:

```bash
helm install eventcatalog oso-devops/eventcatalog -f values.yaml
```

## Available Values to Override

Below are the default values provided by the Helm chart that can be overridden in your `values.yaml` file:

```yaml
replicaCount: 1

image:
name: eventcatalog
# Container image with static EventCatalog demo built
repository: quay.io/osodevops/eventcatalog
# If not specified, defaults to .Chart.AppVersion
tag: ""
pullPolicy: IfNotPresent

service:
type: ClusterIP
# Default port for the service
port: 80

ingress:
enabled: true
domain: true
ingressClass: nginx
annotations:
nginx.ingress.kubernetes.io/rewrite-target: /
cert-manager.io/cluster-issuer: letsencrypt-prod
hosts:
- host: example.com
paths:
- path: /
pathType: ImplementationSpecific
tls:
- secretName: test-eventcatalog
hosts:
- example.com

resources:
requests:
memory: "256Mi"
cpu: "500m"
limits:
memory: "512Mi"
cpu: "1"
```

### Example Configurations - values.yaml
#### Without a Domain
Use the following configuration for deployments without a domain using the default demo image. The application will be accessible via a LoadBalancer:
```yaml
ingress:
enabled: true
domain: false
ingressClass: nginx
annotations:
nginx.ingress.kubernetes.io/rewrite-target: /
hosts:
- paths:
- path: /eventcatalog
pathType: Prefix
tls: []

```

#### With a Domain
Use this configuration to deploy EventCatalog with a custom domain, using the default demo image:

```yaml
ingress:
enabled: true
domain: true
ingressClass: nginx
annotations:
nginx.ingress.kubernetes.io/rewrite-target: /
cert-manager.io/cluster-issuer: letsencrypt-prod
hosts:
- host: example-domain.com
paths:
- path: /
pathType: ImplementationSpecific
tls:
- secretName: test-eventcatalog
hosts:
- example-domain.com
```

## Building a Custom EventCatalog Image
You can build your own EventCatalog image if required. The following example demonstrates a multi-architecture image build:

We used this to provide the default demo image.

```bash
docker buildx build --platform linux/amd64,linux/arm64 -t quay.io/osodevops/eventcatalog:1.0.1 --push .
```

This image can then be referenced in your Helm values file for deployment.

### Default Image and Demo UI
The Helm chart uses a default EventCatalog image that provides a demo experience. The UI is expected to resemble the [EventCatalog demo](https://demo.eventcatalog.dev).

For testing locally, you can forward the service:

```bash
kubectl port-forward svc/eventcatalog 8080:80
```

## Additional Resources
- **Deployment and Hosting Documentation:** https://www.eventcatalog.dev/docs/development/deployment
- **Getting Started on GitHub:** https://github.com/event-catalog/eventcatalog
- **Create a Local Instance:** Start a local instance of EventCatalog with:

```bash
npx @eventcatalog/create-eventcatalog@latest my-catalog
```
4 changes: 2 additions & 2 deletions charts/eventcatalog/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,8 @@ service:
# Default port for the service
port: 80
ingress:
enabled: true
domain: true
enabled: false
domain: false
ingressClass: nginx
annotations:
nginx.ingress.kubernetes.io/rewrite-target: /
Expand Down
Loading