-
Notifications
You must be signed in to change notification settings - Fork 5
80 lines (73 loc) · 3.13 KB
/
self_runner_test.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
name: Dynamic Runner
on:
workflow_dispatch:
push:
jobs:
start-runner:
runs-on: flysql26-dispatch
outputs:
runner_name: ${{ steps.set-runner-name.outputs.runner_name }}
steps:
- name: Start Dockerized Runner
id: start_runner
run: |
RUNNER_NAME=$(bash /var/go/actions-runner-dispatch/runner-controller.sh start ${{ secrets.CREATE_RUNNER_TOKEN }} ${{ secrets.AWS_ACCESS_KEY_ID }} ${{ secrets.AWS_SECRET_ACCESS_KEY }})
echo "RUNNER_NAME=${RUNNER_NAME}" >> $GITHUB_ENV
echo "runner_name=${RUNNER_NAME}" >> $GITHUB_ENV
use-runner:
needs: start-runner
runs-on: ${{ needs.start-runner.outputs.runner_name }}
steps:
- name: Log in to ECR
env:
REG: "100225593120.dkr.ecr.us-east-1.amazonaws.com"
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
run: |
if echo "${{ env.REG }}" | egrep "ecr\..+\.amazonaws\.com"; then
DOCKER_LOGIN_CMD="docker run --rm -v ~/.aws:/root/.aws amazon/aws-cli"
DOCKER_LOGIN_CMD="${DOCKER_LOGIN_CMD} ecr get-login-password --region us-east-1 | docker login -u AWS --password-stdin https://${{ env.REG }}"
eval ${DOCKER_LOGIN_CMD}
fi
- name: Construct NEO_ENV_IMAGE
id: construct-image
env:
REGISTRY: 100225593120.dkr.ecr.us-east-1.amazonaws.com
DOCKER_PULL_TAG: "stage" # Adjust as needed
run: echo "NEO_ENV_IMAGE=${{ env.REGISTRY }}/agr_neo4j_env:${{ env.DOCKER_PULL_TAG }}" >> $GITHUB_ENV
- name: Pull Neo4j Env Image
run: docker pull $NEO_ENV_IMAGE
- name: Run Neo4j
env:
NEO_SERVER_NAME: "stage-neo4j.alliancegenome.org"
NEO_VOLUME_NAME: "/data"
NET: "host"
NEO_MAX_HEAP: "31GB"
NEO_OFF_HEAP_MAX: "0GB"
NEO_ON_OFF_HEAP: "OFF_HEAP"
NEO_TRANSACTION: "0"
NEO4J_AUTH: "none"
run: |
docker run --rm -d \
--name ${{ env.NEO_SERVER_NAME }} \
-p 7474:7474 \
-p 7687:7687 \
-v ${{ env.NEO_VOLUME_NAME }}:/var/lib/neo4j/import \
--network ${{ env.NET }} \
-e NEO4J_server_memory_heap_max__size=${{ env.NEO_MAX_HEAP }} \
-e NEO4J_server_memory_heap_initial__size=${{ env.NEO_MAX_HEAP }} \
-e NEO4J_server_memory_off__heap_max__size=${{ env.NEO_OFF_HEAP_MAX }} \
-e NEO4J_db_tx__state_memory__allocation=${{ env.NEO_ON_OFF_HEAP }} \
-e NEO4J_dbms_memory_transaction_total_max=${{ env.NEO_TRANSACTION }} \
-e NEO4J_db_memory_transaction_total_max=${{ env.NEO_TRANSACTION }} \
-e NEO4J_db_memory_transaction_max=${{ env.NEO_TRANSACTION }} \
-e NEO4J_AUTH=${{ env.NEO4J_AUTH }} \
$NEO_ENV_IMAGE
stop-runner:
needs: use-runner
runs-on: flysql26-dispatch
steps:
- name: Stop Dockerized Runner
run: |
RUNNER_NAME="${{ needs.start-runner.outputs.runner_name }}"
bash /var/go/actions-runner-dispatch/runner-controller.sh stop $RUNNER_NAME