Skip to content

Commit

Permalink
Nove data transfer back to the DTNs and don't use bash -c
Browse files Browse the repository at this point in the history
DTN workaround orkaround provided by NERSC staff

They also suggested not using bash -c as it's considered a security flag
  • Loading branch information
MrCreosote committed Dec 20, 2024
1 parent 9e18e84 commit 98a9711
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 24 deletions.
41 changes: 21 additions & 20 deletions cdmtaskservice/nersc/manager.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,9 +36,9 @@
# TODO CLEANUP clean up old code versions @NERSC somehow. Not particularly important

_DT_TARGET = Machine.dtns
# TDOO NERSCUIPDATE delete the following line when DTN downloads work.
# TDOO NERSCUIPDATE delete the following line when DTN downloads work normally.
# See https://nersc.servicenowservices.com/sp?sys_id=ad33e85f1b5a5610ac81a820f54bcba0&view=sp&id=ticket&table=incident
_DT_TARGET = Machine.perlmutter
_DT_WORKAROUND = "source /etc/bashrc"

_COMMAND_PATH = "utilities/command"

Expand Down Expand Up @@ -178,24 +178,25 @@ async def _setup_remote_code(self, jaws_token: str, jaws_group: str):
),
chmod = "600"
))
res = tg.create_task(dt.run('bash -c "echo $SCRATCH"'))
res = tg.create_task(dt.run(f"{_DT_WORKAROUND}; echo $SCRATCH"))

Check warning on line 181 in cdmtaskservice/nersc/manager.py

View check run for this annotation

Codecov / codecov/patch

cdmtaskservice/nersc/manager.py#L181

Added line #L181 was not covered by tests
if _PIP_DEPENDENCIES:
deps = " ".join(
# may need to do something else if module doesn't have __version__
[f"{mod.__name__}=={mod.__version__}" for mod in _PIP_DEPENDENCIES])
command = (
'bash -c "'
+ f"{_PYTHON_LOAD_HACK}; "
+ f"module load python; "
# Unlikely, but this could cause problems if multiple versions
# of the server are running at once. Don't worry about it for now
+ f"pip install {deps}" # adding notapackage causes a failure
+ '"')
tg.create_task(perlmutter.run(command))
f"{_DT_WORKAROUND}; "
+ f"{_PYTHON_LOAD_HACK}; "
+ f"module load python; "
# Unlikely, but this could cause problems if multiple versions
# of the server are running at once. Don't worry about it for now
+ f"pip install {deps}" # adding notapackage causes a failure
)
tg.create_task(dt.run(command))

Check warning on line 194 in cdmtaskservice/nersc/manager.py

View check run for this annotation

Codecov / codecov/patch

cdmtaskservice/nersc/manager.py#L194

Added line #L194 was not covered by tests
scratch = res.result().strip()
if not scratch:
raise ValueError("Unable to determine $SCRATCH variable for NERSC dtns")
self._dtn_scratch = Path(scratch)
logging.getLogger(__name__).info(f"NERSC DTN scratch path: {self._dtn_scratch}")

Check warning on line 199 in cdmtaskservice/nersc/manager.py

View check run for this annotation

Codecov / codecov/patch

cdmtaskservice/nersc/manager.py#L199

Added line #L199 was not covered by tests

async def _run_command(self, client: AsyncClient, machine: Machine, exe: str):
# TODO ERRORHANDlING deal with errors
Expand All @@ -209,8 +210,9 @@ async def _upload_file_to_nersc(
bio: io.BytesIO = None,
chmod: str = None,
):
dtw = f"{_DT_WORKAROUND}; " if compute.name == Machine.dtns else ""

Check warning on line 213 in cdmtaskservice/nersc/manager.py

View check run for this annotation

Codecov / codecov/patch

cdmtaskservice/nersc/manager.py#L213

Added line #L213 was not covered by tests
if target.parent != Path("."):
cmd = f'bash -c "mkdir -p {target.parent}"'
cmd = f"{dtw}mkdir -p {target.parent}"

Check warning on line 215 in cdmtaskservice/nersc/manager.py

View check run for this annotation

Codecov / codecov/patch

cdmtaskservice/nersc/manager.py#L215

Added line #L215 was not covered by tests
await compute.run(cmd)
# skip some API calls vs. the upload example in the NERSC docs
# don't use a directory as the target or it makes an API call
Expand All @@ -223,7 +225,7 @@ async def _upload_file_to_nersc(
else:
await asrp.upload(bio)
if chmod:
cmd = f'bash -c "chmod {chmod} {target}"'
cmd = f"{dtw}chmod {chmod} {target}"

Check warning on line 228 in cdmtaskservice/nersc/manager.py

View check run for this annotation

Codecov / codecov/patch

cdmtaskservice/nersc/manager.py#L228

Added line #L228 was not covered by tests
await compute.run(cmd)

async def download_s3_files(
Expand Down Expand Up @@ -293,13 +295,12 @@ async def _process_manifest(
# TODO CLEANUP manifests after some period of time
await self._upload_file_to_nersc(dt, path, bio=manifest)
command = (
"bash -c '"
+ f"export CTS_CODE_LOCATION={self._nersc_code_path}; "
+ f"export CTS_MANIFEST_LOCATION={path}; "
+ f"export CTS_CALLBACK_URL={callback_url}; "
+ f"export SCRATCH=$SCRATCH; "
+ f'"$CTS_CODE_LOCATION"/{_PROCESS_DATA_XFER_MANIFEST_FILENAME}'
+ "'"
f"{_DT_WORKAROUND}; "
+ f"export CTS_CODE_LOCATION={self._nersc_code_path}; "
+ f"export CTS_MANIFEST_LOCATION={path}; "
+ f"export CTS_CALLBACK_URL={callback_url}; "
+ f"export SCRATCH=$SCRATCH; "
+ f'"$CTS_CODE_LOCATION"/{_PROCESS_DATA_XFER_MANIFEST_FILENAME}'
)
task_id = (await self._run_command(cli, _DT_TARGET, command))["task_id"]
# TODO LOGGING figure out how to handle logging, see other logging todos
Expand Down
9 changes: 5 additions & 4 deletions cdmtaskservice_config.toml.jinja
Original file line number Diff line number Diff line change
Expand Up @@ -27,10 +27,11 @@ has_nersc_account_role = "{{ KBCTS_HAS_NERSC_ACCOUNT_ROLE or "HAS_NERSC_ACCOUNT"
# reloads the contents if changed.
sfapi_cred_path = "{{ KBCTS_SFAPI_CRED_PATH or "" }}"

# The user associated with the client credentials. If the client credentials are updated but
# the user doesn't match they will not be accepted. It is advised to create a collaboration
# user for the service. The jaws.conf file will be created in the user's home directory on
# service startup.
# The user associated with the client credentials. The user's default shell must be bash.
# If the client credentials are updated but the user doesn't match they will not be accepted.
# It is advised to create a collaboration user for the service.
# The jaws.conf file will be created in the user's home directory on service startup, overwriting
# any extant file.
sfapi_user = "{{ KBCTS_SFAPI_USER or "" }}"

# Where to store remote code at NERSC. This must be writeable by the service account.
Expand Down

0 comments on commit 98a9711

Please sign in to comment.