Skip to content

Commit 50a3ad1

Browse files
authored
Merge pull request #35 from earthcube/dev
EC to GleanerIO
2 parents c4d1607 + 0e8d217 commit 50a3ad1

File tree

512 files changed

+65332
-44111
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

512 files changed

+65332
-44111
lines changed

.github/workflows/contanerize.yaml

+99-4
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,7 @@ on:
1010
- main
1111
- dev
1212
- dev_eco
13-
- dv_docker
13+
# - dev_dagster142
1414
tags:
1515
- "v*.*.*"
1616

@@ -22,7 +22,7 @@ defaults:
2222

2323
jobs:
2424
build:
25-
name: Dockerize Scheduler for Project
25+
name: Dockerize Scheduler
2626
runs-on: ubuntu-latest
2727
strategy:
2828
matrix:
@@ -33,7 +33,7 @@ jobs:
3333
steps:
3434
- name: Set variables
3535
run: |
36-
REGISTRY_IMAGE=nsfearthcube/dagster-${{ matrix.project }}
36+
REGISTRY_IMAGE=nsfearthcube/dagster-gleanerio
3737
echo "REGISTRY_IMAGE=$REGISTRY_IMAGE" >> $GITHUB_ENV
3838
working-directory: /
3939
- name: Checkout Repo
@@ -106,7 +106,102 @@ jobs:
106106
build-args:
107107
implnet=${{ matrix.project }}
108108
#file: ./dagster/implnets/build/Dockerfile
109-
file: ./build/Dockerfile_ci
109+
file: ./build/Dockerfile_dagster
110+
context: "{{defaultContext}}:dagster/implnets"
111+
tags: ${{ steps.meta.outputs.tags }}
112+
# tags: nsfearthcube/ec_facets_client:latest
113+
labels: ${{ steps.meta.outputs.labels }}
114+
#platforms: ${{ matrix.platform }}
115+
#outputs: type=image,name=${{ env.REGISTRY_IMAGE }},push-by-digest=true,name-canonical=true,push=true
116+
117+
- name: Image digest
118+
run: echo ${{ steps.build.outputs.digest }}
119+
build_code:
120+
name: Dockerize Scheduler CODE for Project
121+
runs-on: ubuntu-latest
122+
strategy:
123+
matrix:
124+
# project: [ "eco" ]
125+
project: [ "eco", "iow", "oih" ]
126+
#platform: ["linux/amd64","linux/arm64"]
127+
#platform: ["linux/amd64"] #linux/arm64 issues with building
128+
steps:
129+
- name: Set variables
130+
run: |
131+
REGISTRY_IMAGE=nsfearthcube/dagster-gleanerio-${{ matrix.project }}
132+
echo "REGISTRY_IMAGE=$REGISTRY_IMAGE" >> $GITHUB_ENV
133+
working-directory: /
134+
- name: Checkout Repo
135+
uses: actions/checkout@v3
136+
- name: Set up QEMU
137+
uses: docker/setup-qemu-action@v2
138+
- name: Set up Docker Buildx
139+
uses: docker/setup-buildx-action@v2
140+
- name: Login to DockerHub
141+
uses: docker/login-action@v2
142+
with:
143+
username: ${{ secrets.DOCKERHUB_USERNAME }}
144+
password: ${{ secrets.DOCKERHUB_TOKEN }}
145+
- name: Extract metadata (tags, labels) for Docker
146+
id: meta
147+
uses: docker/metadata-action@v4
148+
with:
149+
images: ${{ env.REGISTRY_IMAGE }}
150+
flavor: |
151+
latest=true
152+
tags: |
153+
type=ref,event=tag
154+
type=ref,event=branch
155+
type=semver,pattern={{version}}
156+
type=sha
157+
158+
# - name: Set up Python 3.10
159+
# uses: actions/setup-python@v4
160+
# with:
161+
# python-version: '3.10'
162+
# - name: Install dependencies
163+
# run: |
164+
# python -m pip install --upgrade pip
165+
# if [ -f requirements.txt ]; then pip install -r requirements.txt; fi
166+
# long version with lint,
167+
# run: |
168+
# python -m pip install --upgrade pip
169+
# pip install flake8 pytest
170+
# if [ -f requirements.txt ]; then pip install -r requirements.txt; fi
171+
# pip install build
172+
# - name: Lint with flake8
173+
# run: |
174+
# # stop the build if there are Python syntax errors or undefined names
175+
# flake8 . --count --select=E9,F63,F7,F82 --show-source --statistics
176+
# # exit-zero treats all errors as warnings. The GitHub editor is 127 chars wide
177+
# flake8 . --count --exit-zero --max-complexity=10 --max-line-length=127 --statistics
178+
# - name: Build package
179+
# run: python -m build
180+
# - name: Build tooling
181+
# run: |
182+
# cd ./tooling/cfgBuilder/${{ matrix.project }}
183+
# python cfgBuilder.py -s https://foo.us/sitemap.xml
184+
# - name: Generate
185+
# working-directory: dagster/implnets
186+
# run: |
187+
# python pygen.py -cf ./configs/${{ matrix.project }}/gleanerconfig.yaml -od /temp/generatedDocker/implnet-${{ matrix.project }}/output -td ./templates/v1 -d 7
188+
# - name: check
189+
# working-directory: dagster/implnets
190+
# run: |
191+
# cat ./generatedCode/implnet-${{ matrix.project }}/output/ops/implnet_ops_amgeo.py
192+
193+
- name: Build and push
194+
id: build
195+
uses: docker/build-push-action@v4
196+
with:
197+
#context: ./dagster/implnets
198+
# grr https://github.com/docker/build-push-action#git-context
199+
#context: "{{defaultContext}}"
200+
push: true
201+
build-args:
202+
implnet=${{ matrix.project }}
203+
#file: ./dagster/implnets/build/Dockerfile
204+
file: ./build/Dockerfile_code
110205
context: "{{defaultContext}}:dagster/implnets"
111206
tags: ${{ steps.meta.outputs.tags }}
112207
# tags: nsfearthcube/ec_facets_client:latest

NOTES.md

+23
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,29 @@
11
# Notes
22

3+
## Development
34

5+
At the top level (dagster/implents) you can run
6+
7+
`dagster dev`
8+
9+
You need to set the environment based on dagster/implnets/deployment/envFile.env
10+
11+
It should run workflows/tasks/tasks
12+
13+
defined in the pyproject.toml
14+
15+
```
16+
[tool.dagster]
17+
module_name = "workflows.tasks.tasks"
18+
```
19+
20+
### testing tasks
21+
22+
cd dagster/implnets/workflows/tasks
23+
You need to set the environment based on dagster/implnets/deployment/envFile.env
24+
25+
`dagster dev`
26+
will run just the task, and in editable form, i think.
427

528
## Some articles to review
629

dagster/implnets/Makefile

+2-2
Original file line numberDiff line numberDiff line change
@@ -47,7 +47,7 @@ oih-clean:
4747
cd ./generatedCode/implnet-oih && rm -rf ./output/*
4848

4949
oih-generate:
50-
python pygen.py -cf ./configs/oih/gleanerconfig.yaml -od ./generatedCode/implnet-oih/output -td ./templates/v1 -d 7
50+
python pygen.py -cf ./configs/oih/gleanerconfig.yaml -od ./generatedCode/implnet-oih/output -td ./templates/v1 -d 14
5151

5252
oih-build:
5353
podman build --tag="docker.io/fils/dagster_oih:$(VERSION)" --build-arg implnet=oih --file=./build/Dockerfile .
@@ -64,7 +64,7 @@ iow-clean:
6464
cd ./generatedCode/implnet-iow && rm -rf ./output/*
6565

6666
iow-generate:
67-
python pygen.py -cf ./configs/iow/gleanerconfig.yaml -od ./generatedCode/implnet-iow/output -td ./templates/v1 -d 21
67+
python pygen.py -cf ./configs/iow/gleanerconfig.yaml -od ./generatedCode/implnet-iow/output -td ./templates/v1 -d 27
6868

6969
iow-build:
7070
podman build --tag="docker.io/fils/dagster_iow:$(VERSION)" --build-arg implnet=iow --file=./build/Dockerfile .

dagster/implnets/README_DEV.md

+26
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
2+
Note: Moved the dagster.yaml that defines the container based configuraiton to deployment.
3+
4+
5+
To start a dev instance, you can type
6+
7+
set the environment variables in deploymnet/envFile.env
8+
*
9+
* if using jetbrains/pycharm, use a shell script, and add the env variables.
10+
11+
12+
`dagster dev --workspace workspace_dev.yaml`
13+
14+
15+
You can go to deployment, and get the code reloaded by reloading the definitions.
16+
17+
## Using local deployment and containers
18+
19+
in deploy, you can use the dagster_local.sh
20+
21+
when combined with the proper env, it will use the workflows.yaml in config/$PROJECT/workflows.yam
22+
a
23+
In prep for using a service that can mount the gleaner/nabu configs, the local
24+
also creates 'file' configs using config/$PROJECT/gleanerconfig.yaml and config/$PROJECT/nabuconfig.yaml
25+
26+

dagster/implnets/build/Dockerfile

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
FROM python:3.10-slim
1+
FROM python:3.11-slim
22

33
# Read the ARG implnet to set who to build for.
44

dagster/implnets/build/Dockerfile_ci

+7-4
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,8 @@ FROM python:3.11-slim
55
# docker buildandpush pulls the repo, so we need to put the code at a different location
66
# this fails becaus the dagster/implnets files are not in the docker
77
ARG implnet=eco
8-
RUN mkdir -p /usr/src/app/
8+
RUN mkdir -p /usr/src/app/project/${implnet}
9+
RUN mkdir -p /usr/src/app/workflows
910

1011
RUN pip install --upgrade pip
1112
## this is a base for the project. Build this 'layer' first
@@ -16,20 +17,22 @@ RUN pip install -r requirements.txt
1617
COPY . scheduler
1718
COPY ./configs/${implnet}/gleanerconfig.yaml scheduler/gleanerconfig.yaml
1819

19-
COPY dagster.yaml /usr/src/app/
20+
COPY ./deployment/dagster.yaml /usr/src/app/
2021

2122
WORKDIR scheduler
2223

2324

2425
RUN pip install -r requirements.txt
25-
RUN python pygen.py -cf ./gleanerconfig.yaml -od /usr/src/app/ -td ./templates/v1 -d 7
26+
RUN python pygen.py -cf ./gleanerconfig.yaml -od /usr/src/app/project/${implnet} -td ./templates/v1 -d 7
2627

2728

29+
COPY ./workflows/ /usr/src/app/workflows
30+
2831

2932

3033
# Change working directory
3134
WORKDIR /usr/src/app
3235
ENV DAGSTER_HOME=/usr/src/app
3336

3437

35-
CMD ["dagit", "-w", "workspace.yaml", "-h", "0.0.0.0", "-p", "3000"]
38+
CMD ["dagster-webserver", "-w", "./project/${implnet}/workspace.yaml", "-h", "0.0.0.0", "-p", "3000"]
+40
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
FROM python:3.11-slim
2+
3+
# we may want to get an unreleased version of code, so this is needed
4+
RUN apt-get update && apt-get install -y git
5+
# Read the ARG implnet to set who to build for.
6+
7+
# docker buildandpush pulls the repo, so we need to put the code at a different location
8+
# this fails becaus the dagster/implnets files are not in the docker
9+
ARG implnet=eco
10+
RUN mkdir -p /usr/src/app/project/${implnet}
11+
RUN mkdir -p /usr/src/app/workflows
12+
13+
RUN pip install --upgrade pip
14+
## this is a base for the project. Build this 'layer' first
15+
COPY ./requirements_code.txt requirements.txt
16+
RUN pip install -r requirements.txt
17+
18+
# this add the code
19+
COPY . scheduler
20+
COPY ./configs/${implnet}/gleanerconfig.yaml scheduler/gleanerconfig.yaml
21+
22+
COPY ./deployment/dagster.yaml /usr/src/app/
23+
24+
WORKDIR scheduler
25+
26+
27+
RUN pip install -r requirements.txt
28+
RUN python pygen.py -cf ./gleanerconfig.yaml -od /usr/src/app/project/${implnet} -td ./templates/v1 -d 7
29+
30+
31+
COPY ./workflows/ /usr/src/app/workflows
32+
33+
34+
35+
# Change working directory
36+
WORKDIR /usr/src/app
37+
ENV DAGSTER_HOME=/usr/src/app
38+
39+
40+
CMD [ "dagster", "api","grpc", "-h", "0.0.0.0", "-p", "4000", "--python-file", "/usr/src/app/project/${PROJECT:-eco}/repositories/repository.py", "-d", "/usr/src/app/project/${PROJECT:-eco}/"]
+36
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,36 @@
1+
FROM python:3.11-slim
2+
3+
# Read the ARG implnet to set who to build for.
4+
5+
# docker buildandpush pulls the repo, so we need to put the code at a different location
6+
# this fails becaus the dagster/implnets files are not in the docker
7+
8+
9+
RUN pip install --upgrade pip
10+
## this is a base for the project. Build this 'layer' first
11+
COPY ./requirements_dagster.txt requirements.txt
12+
RUN pip install -r requirements.txt
13+
14+
## this add the code
15+
#COPY . scheduler
16+
#COPY ./configs/${implnet}/gleanerconfig.yaml scheduler/gleanerconfig.yaml
17+
#
18+
COPY ./deployment/dagster.yaml /usr/src/app/
19+
#
20+
#WORKDIR scheduler
21+
#
22+
#
23+
#RUN pip install -r requirements.txt
24+
#RUN python pygen.py -cf ./gleanerconfig.yaml -od /usr/src/app/project/${implnet} -td ./templates/v1 -d 7
25+
#
26+
#
27+
#COPY ./workflows/ /usr/src/app/workflows
28+
29+
30+
31+
# Change working directory
32+
WORKDIR /usr/src/app
33+
ENV DAGSTER_HOME=/usr/src/app
34+
35+
36+
CMD ["dagster-webserver", "-w", "workspace.yaml", "-h", "0.0.0.0", "-p", "3000"]

dagster/implnets/build/Dockerfile_local

+4-3
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,8 @@ FROM python:3.11-slim
33
# for local, code is compiled. to generatedCode/implnet-PROJECT
44

55
ARG implnet=eco
6-
RUN mkdir -p /usr/src/app/output
6+
RUN mkdir -p /usr/src/app/project
7+
RUN mkdir -p /usr/src/app/workflows
78

89
COPY ./requirements.txt .
910

@@ -16,12 +17,12 @@ COPY . scheduler
1617
COPY ./configs/${implnet}/gleanerconfig.yaml scheduler/gleanerconfig.yaml
1718

1819
#COPY ./dagster.yaml /usr/src/app/output/dagster.yaml
19-
COPY ./dagster.yaml /usr/src/app/dagster.yaml
20+
COPY ./deployment/dagster.yaml /usr/src/app/
2021
# Change working directory
2122

2223

2324
WORKDIR /usr/src/app
2425
ENV DAGSTER_HOME=/usr/src/app
2526

2627

27-
CMD ["dagit", "-w", "./output/workspace.yaml", "-h", "0.0.0.0", "-p", "3000"]
28+
CMD ["dagster-webserver", "-w", "./project/${implnet}/workspace.yaml", "-h", "0.0.0.0", "-p", "3000"]
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,48 @@
1+
FROM python:3.11-slim as base
2+
3+
# Read the ARG implnet to set who to build for.
4+
5+
# docker buildandpush pulls the repo, so we need to put the code at a different location
6+
# this fails becaus the dagster/implnets files are not in the docker
7+
ARG implnet=eco
8+
RUN mkdir -p /usr/src/app/project/${implnet}
9+
RUN mkdir -p /usr/src/app/workflows
10+
11+
RUN pip install --upgrade pip
12+
## this is a base for the project. Build this 'layer' first
13+
COPY ./requirements.txt .
14+
RUN pip install -r requirements.txt
15+
16+
17+
# Change working directory
18+
WORKDIR /usr/src/app
19+
ENV DAGSTER_HOME=/usr/src/app
20+
21+
22+
CMD ["dagster-webserver", "-w", "./project/${implnet}/workspace.yaml", "-h", "0.0.0.0", "-p", "3000"]
23+
24+
FROM base as dagster
25+
WORKDIR /usr/src/app
26+
ENV DAGSTER_HOME=/usr/src/app
27+
28+
29+
CMD ["dagster-webserver", "-w", "./project/${implnet}/workspace.yaml", "-h", "0.0.0.0", "-p", "3000"]
30+
31+
32+
FROM base AS dagstercode
33+
# this add the code
34+
COPY . scheduler
35+
COPY ./configs/${implnet}/gleanerconfig.yaml scheduler/gleanerconfig.yaml
36+
37+
COPY ./deployment/dagster.yaml /usr/src/app/
38+
39+
WORKDIR scheduler
40+
41+
42+
RUN pip install -r requirements.txt
43+
RUN python pygen.py -cf ./gleanerconfig.yaml -od /usr/src/app/project/${implnet} -td ./templates/v1 -d 7
44+
45+
46+
COPY ./workflows/ /usr/src/app/workflows
47+
48+

0 commit comments

Comments
 (0)