Skip to content

Commit

Permalink
WIP - Trying to get a POC of parsl working. This part is mostly focus…
Browse files Browse the repository at this point in the history
…ed on getting consistent logging.
  • Loading branch information
drewoldag committed Jul 5, 2024
1 parent d902107 commit 255141d
Show file tree
Hide file tree
Showing 11 changed files with 140 additions and 39 deletions.
1 change: 1 addition & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ classifiers = [
dynamic = ["version"]
requires-python = ">=3.9"
dependencies = [
"parsl", # The primary workflow orchestration tool
]

[project.urls]
Expand Down
7 changes: 4 additions & 3 deletions src/kbmod_wf/__init__.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
from .example_module import greetings, meaning

__all__ = ["greetings", "meaning"]
from .configurations.dev_configuration import dev_config
from .workflow import workflow_runner
from .configurations.klone_configuration import klone_config
from .utilities.logger_utilities import configure_logger
4 changes: 4 additions & 0 deletions src/kbmod_wf/configurations/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
from .dev_configuration import dev_config
from .klone_configuration import klone_config

__all__ = ["dev_config", "klone_config"]
14 changes: 14 additions & 0 deletions src/kbmod_wf/configurations/dev_configuration.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
from parsl import Config
from parsl.executors import ThreadPoolExecutor


def dev_config():
return Config(
# run_dir='runinfo', # do some introspection here so that we can place the runinfo directory somewhere above src.
initialize_logging=False,
executors=[
ThreadPoolExecutor(
label="local_dev_testing",
)
],
)
30 changes: 30 additions & 0 deletions src/kbmod_wf/configurations/klone_configuration.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
from parsl import Config
from parsl.executors import HighThroughputExecutor
from parsl.providers import SlurmProvider

walltimes = {
"compute-bigmem": "01:00:00", # change this to be appropriate
}


def klone_config():
return Config(
executors=[
HighThroughputExecutor(
label="small_cpu",
provider=SlurmProvider(
partition="compute-bigmem",
account="astro",
min_blocks=0,
max_blocks=4,
init_blocks=1,
parallelism=1,
nodes_per_block=1,
cores_per_node=1, # perhaps should be 8???
mem_per_node=64, # In GB
exclusive=False,
walltime=walltimes["compute-bigmem"],
),
),
]
)
23 changes: 0 additions & 23 deletions src/kbmod_wf/example_module.py

This file was deleted.

1 change: 1 addition & 0 deletions src/kbmod_wf/runner.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# this file will be what we call to run the workflows
3 changes: 3 additions & 0 deletions src/kbmod_wf/utilities/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
from .logger_utilities import configure_logger

__all__ = ["configure_logger"]
24 changes: 24 additions & 0 deletions src/kbmod_wf/utilities/logger_utilities.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
DEFAULT_FORMAT = (
"%(created)f %(asctime)s %(processName)s-%(process)d "
"%(threadName)s-%(thread)d %(name)s:%(lineno)d %(funcName)s %(levelname)s: "
"%(message)s"
)


def configure_logger(name, file_path):
"""
Simple function that will create a logger object and configure it to write
to a file at the specified path.
Note: We import logging within the function because we expect this to be
called within a parsl app."""

import logging

logger = logging.getLogger(name)
handler = logging.FileHandler(file_path)
formatter = logging.Formatter(DEFAULT_FORMAT, datefmt="%Y-%m-%d %H:%M:%S")
handler.setFormatter(formatter)
logger.addHandler(handler)
logger.setLevel(logging.DEBUG)

return logger
59 changes: 59 additions & 0 deletions src/kbmod_wf/workflow.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
import os
import parsl
from datetime import datetime
from parsl import python_app, File
import parsl.executors

from kbmod_wf.configurations import *


@python_app(executors=["local_dev_testing"])
def uri_to_ic(inputs=[], outputs=[], logger=None):
from kbmod_wf.utilities.logger_utilities import configure_logger

logger = configure_logger("task:uri_to_ic", inputs[-1].filepath)

logger.info("Starting uri_to_ic")
logger.warning("You're the cool one.")
return 42


@python_app(executors=["local_dev_testing"])
def part2(inputs=[], outputs=[], logger=None):
from kbmod_wf.utilities.logger_utilities import configure_logger

logger = configure_logger("task:part2", inputs[-1].filepath)

logger.info("Starting part2")
return 43


def workflow_runner():
timestamp = datetime.now().strftime("%Y%m%d_%H%M%S")
logging_file = File(os.path.join(os.getcwd(), f"kbmod_wf_{timestamp}.log"))

logger = parsl.set_file_logger(logging_file.filepath)

with parsl.load(dev_config()):
uri_list = File(os.path.join(os.getcwd(), "uri_list.txt"))

uri_to_ic_future = uri_to_ic(
inputs=[uri_list, logging_file],
outputs=[File(os.path.join(os.getcwd(), "ic.ecsv")), logging_file],
)

part2_future = part2(
inputs=[logging_file],
outputs=[logging_file],
)

logger.warning("You are here")

print(uri_to_ic_future.result())
print(part2_future.result())

parsl.clear()


if __name__ == "__main__":
workflow_runner()
13 changes: 0 additions & 13 deletions tests/kbmod_wf/test_example_module.py

This file was deleted.

0 comments on commit 255141d

Please sign in to comment.