Skip to content

fix: fix the deadlock caused by metrics gauge callback #1862

fix: fix the deadlock caused by metrics gauge callback

fix: fix the deadlock caused by metrics gauge callback #1862

# Copyright 2023 StreamNative, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
name: Build
on:
pull_request:
branches:
- main
push:
branches:
- main
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
env:
MAELSTROM_VERSION: "0.2.3"
jobs:
build:
name: Build & Test
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Set up Go
uses: actions/setup-go@v3
with:
go-version: 1.23
- name: Install protoc
uses: arduino/setup-protoc@v1
with:
repo-token: ${{ secrets.GITHUB_TOKEN }}
- name: Installing Go dependencies
run: |
go install google.golang.org/protobuf/cmd/[email protected]
go install google.golang.org/grpc/cmd/[email protected]
go install github.com/palantir/go-license@latest
- run: make license-check
- name: Build
run: make build
- name: golangci-lint
uses: golangci/[email protected]
with:
version: v1.61.0
args: --timeout=10m
- name: Test
run: make test
chaos-mesh:
name: Run chaos-mesh
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Build docker
uses: docker/build-push-action@v3
with:
context: .
push: false
tags: oxia:latest
cache-from: type=registry,ref=oxia:latest
cache-to: type=inline
- uses: helm/[email protected]
with:
cluster_name: kind
kubectl_version: v1.25.5
- name: Deploy oxia
run: |
kubectl create namespace oxia
kind load docker-image oxia:latest
helm -n oxia install oxia \
-f deploy/chaos-mesh/oxia-cluster.yaml \
deploy/charts/oxia-cluster
sleep 30
kubectl -n oxia run perf \
--image=oxia:latest --image-pull-policy=Never \
--command -- oxia perf -a oxia:6648
- name: Encode chaos-mesh config
run: echo "CFG_BASE64=$(base64 -w0 deploy/chaos-mesh/chaos-mesh.yaml)" >> $GITHUB_ENV
- name: Run chaos-mesh
uses: chaos-mesh/chaos-mesh-action@master # v0.5 is broken
env:
CHAOS_MESH_VERSION: v2.5.1
# CFG_BASE64: set by previous step
- name: Wait for workflow completion
run: sleep 120
- name: Print pods
run: kubectl -n oxia get pods
- name: Print coordinator logs
run: kubectl -n oxia logs -l app.kubernetes.io/component=coordinator
- name: Print perf logs
run: kubectl -n oxia logs perf
maelstrom:
name: Maelstrom
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Set up Go
uses: actions/setup-go@v3
with:
go-version: 1.23
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
distribution: temurin
java-version: 17
- name: Install Gnuplot
run: |
sudo apt-get update && sudo apt-get install -y gnuplot
- run: make
- run: make maelstrom
- name: Download Maelstrom
run: |
curl -O -L https://github.com/jepsen-io/maelstrom/releases/download/v${MAELSTROM_VERSION}/maelstrom.tar.bz2
tar xf maelstrom.tar.bz2
- name: Run Maelstrom test
run: |
cd maelstrom
./maelstrom test -w lin-kv --bin ../bin/oxia-maelstrom \
--time-limit 60 --concurrency 2n --latency 10 --latency-dist uniform
- name: Upload test results
uses: actions/upload-artifact@v4
if: failure()
with:
name: maelstrom-result
path: maelstrom/store