mirror of
https://github.com/Lore09/Tesi-Magistrale.git
synced 2025-12-19 04:14:35 +00:00
Improved parallel building
This commit is contained in:
12
project/tasks/danano.go
Normal file
12
project/tasks/danano.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
|
||||||
|
)
|
||||||
|
|
||||||
|
func exec_task(arg string) string{
|
||||||
|
|
||||||
|
response := "Ciao danano " + arg
|
||||||
|
|
||||||
|
return response
|
||||||
|
}
|
||||||
@@ -1,11 +1,21 @@
|
|||||||
|
project_name: Test
|
||||||
tasks:
|
tasks:
|
||||||
- name: Data Aggregation # Displayed name
|
- name: Data Aggregation
|
||||||
type: processor_nats # Used to select template
|
type: producer_nats
|
||||||
code: task1.go # Go code file inside tasks/ dir
|
code: task1.go
|
||||||
target: # Where the component will be deployed
|
targets:
|
||||||
- edge
|
- edge
|
||||||
- cloud
|
- cloud
|
||||||
source_topic: temp_sensor # Source NATS topic
|
source_topic: temp_sensor
|
||||||
dest_topic: aggregated_data # Destination NATS topic
|
dest_topic: aggregated_data
|
||||||
component_name: data_aggregation # Component name displayed in the OCI artifact
|
component_name: data_aggregation
|
||||||
|
version: 1.0.0
|
||||||
|
- name: Daniele pelato
|
||||||
|
type: processor_nats
|
||||||
|
code: danano.go
|
||||||
|
targets:
|
||||||
|
- edge
|
||||||
|
source_topic: temp_sensor
|
||||||
|
dest_topic: sexo
|
||||||
|
component_name: liscio
|
||||||
version: 1.0.0
|
version: 1.0.0
|
||||||
@@ -10,6 +10,8 @@ def build_project(project_dir, reg_user, reg_pass, detached):
|
|||||||
logging.error(f"Project directory is not valid")
|
logging.error(f"Project directory is not valid")
|
||||||
return
|
return
|
||||||
|
|
||||||
|
print('Building WASM components')
|
||||||
|
|
||||||
# Docker client
|
# Docker client
|
||||||
client = docker.from_env()
|
client = docker.from_env()
|
||||||
|
|
||||||
@@ -17,6 +19,8 @@ def build_project(project_dir, reg_user, reg_pass, detached):
|
|||||||
try:
|
try:
|
||||||
client.images.get("wash-build-image:latest")
|
client.images.get("wash-build-image:latest")
|
||||||
except docker.errors.ImageNotFound:
|
except docker.errors.ImageNotFound:
|
||||||
|
|
||||||
|
print(' - Building wash-build-image from Dockerfile...')
|
||||||
client.images.build(
|
client.images.build(
|
||||||
path="src/wasm_builder/docker",
|
path="src/wasm_builder/docker",
|
||||||
dockerfile="build.Dockerfile",
|
dockerfile="build.Dockerfile",
|
||||||
@@ -24,21 +28,34 @@ def build_project(project_dir, reg_user, reg_pass, detached):
|
|||||||
)
|
)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
wait_list = []
|
||||||
|
|
||||||
for task in os.listdir(f"{project_dir}/gen"):
|
for task in os.listdir(f"{project_dir}/gen"):
|
||||||
__build_wasm(f"{project_dir}/gen/{task}", client, reg_user, reg_pass, detached)
|
__build_wasm(f"{project_dir}/gen/{task}", client, reg_user, reg_pass, detached, wait_list)
|
||||||
|
|
||||||
|
if detached == 'True':
|
||||||
|
|
||||||
|
print('Waiting for build to finish...')
|
||||||
|
for container in wait_list:
|
||||||
|
try:
|
||||||
|
client.containers.get(container).wait()
|
||||||
|
except Exception:
|
||||||
|
continue
|
||||||
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logging.error(f"Error building project: {e}")
|
logging.error(f"Error building project: {e}")
|
||||||
return
|
return
|
||||||
|
|
||||||
print("Project built successfully")
|
print("Project built successfully")
|
||||||
|
|
||||||
def __build_wasm(task_dir, client, reg_user, reg_pass, detached):
|
def __build_wasm(task_dir, client, reg_user, reg_pass, detached, wait_list):
|
||||||
|
|
||||||
wadm = __parse_yaml(f"{task_dir}/wadm.yaml")
|
wadm = __parse_yaml(f"{task_dir}/wadm.yaml")
|
||||||
|
|
||||||
path = os.path.abspath(task_dir)
|
path = os.path.abspath(task_dir)
|
||||||
|
|
||||||
oci_url = wadm['spec']['components'][0]['properties']['image']
|
oci_url = wadm['spec']['components'][0]['properties']['image']
|
||||||
|
name = wadm['spec']['components'][0]['name'] + '-build'
|
||||||
|
|
||||||
# Build the wasm module
|
# Build the wasm module
|
||||||
print(f" - Building WASM module {oci_url}")
|
print(f" - Building WASM module {oci_url}")
|
||||||
@@ -49,11 +66,14 @@ def __build_wasm(task_dir, client, reg_user, reg_pass, detached):
|
|||||||
f'WASH_REG_PASSWORD={reg_pass}'],
|
f'WASH_REG_PASSWORD={reg_pass}'],
|
||||||
volumes={path: {'bind': '/app', 'mode': 'rw'}},
|
volumes={path: {'bind': '/app', 'mode': 'rw'}},
|
||||||
remove=True,
|
remove=True,
|
||||||
detach=True
|
detach=True,
|
||||||
|
name=name
|
||||||
)
|
)
|
||||||
|
|
||||||
if detached == 'False':
|
if detached == 'False':
|
||||||
container.wait()
|
container.wait()
|
||||||
|
else:
|
||||||
|
wait_list.append(name)
|
||||||
|
|
||||||
|
|
||||||
def __parse_yaml(yaml_file):
|
def __parse_yaml(yaml_file):
|
||||||
|
|||||||
Reference in New Issue
Block a user