Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/gotoren/k6-operator-playground

Load test simulation using k6-operator.
https://github.com/gotoren/k6-operator-playground

go javascript k6 kubernetes

Last synced: 19 days ago
JSON representation

Load test simulation using k6-operator.

Awesome Lists containing this project

README

        

# k6-operator-playground

Load test simulation using k6 / k6-operator.

## 使用ツール

- マニフェスト管理

- Kustomize

Kustomize

- モニタリング

- kube-prometheus-stack

kube-prometheus-stack

- 負荷試験
- k6-operator

k6-operator

## ディレクトリ構成

```
.
├── docs ・・・ ドキュメント
├── load ・・・ Kubernetes 上で負荷試験を実行する際に必要となるシナリオとマニフェストを配置
├── locals ・・・ Docker Compose を使用して k6 を検証する場合に必要となるリソースを配置(Kubernetes を使用しない場合)
└── manifests
├── platform ・・・ 負荷試験に必要となるプラットフォーム用のマニフェスト(Helm on Kustomize)を配置
└── services ・・・ 負荷試験の対象となるサービスを配置
```

## 負荷試験アーキテクチャ

![k6-operator-architecture](https://github.com/GotoRen/k6-operator-playground/assets/63791288/8c65d565-b920-4b0b-8a95-797267e82a41)

- **負荷試験クラスタ(このリポジトリ)**
- 負荷試験を実行する側のクラスタ
- 負荷試験レポートは Prometheus または InfluxDB に流す(二経路準備しておく)
- Prometheus:大規模負荷試験においてより高度な耐久性を得られる
- InfluxDB:シンプルな構成で軽い負荷試験が容易
- **ターゲットクラスタ(別途準備)**
- 負荷試験を受ける側のクラスタ
- LB(基本的には L7SLB)に向けて実行する
- パブリッククラウド:事前に暖気申請等を行なっておく
- プライベートクラウド(MetalLB 等のベアメタル):パケット分散率及びおよび負荷状況に合わせて LB 専用のインスタンスを準備する

## 使い方

1. [manifests ディレクトリ](./manifests/README.md) を参考に Kubernetes に負荷試験に必要なリソースを構築する
2. [k6-operator による負荷試験の実施](./docs/03_k6-operator.md) を参考に負荷試験を実施する