parsl 2025.3.10__py3-none-any.whl → 2025.3.24__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- parsl/dataflow/dflow.py +1 -3
- parsl/executors/base.py +13 -37
- parsl/executors/flux/executor.py +1 -0
- parsl/executors/globus_compute.py +1 -1
- parsl/executors/high_throughput/executor.py +18 -0
- parsl/executors/high_throughput/mpi_resource_management.py +2 -0
- parsl/executors/high_throughput/process_worker_pool.py +89 -82
- parsl/executors/radical/executor.py +1 -0
- parsl/executors/status_handling.py +8 -0
- parsl/executors/taskvine/executor.py +1 -0
- parsl/executors/workqueue/executor.py +1 -0
- parsl/monitoring/db_manager.py +16 -10
- parsl/monitoring/errors.py +5 -0
- parsl/monitoring/monitoring.py +61 -117
- parsl/monitoring/radios/filesystem_router.py +4 -2
- parsl/monitoring/radios/udp_router.py +1 -3
- parsl/monitoring/radios/zmq_router.py +80 -25
- parsl/multiprocessing.py +42 -2
- parsl/tests/test_monitoring/test_exit_helper.py +54 -0
- parsl/tests/test_monitoring/test_fuzz_zmq.py +1 -1
- parsl/tests/test_monitoring/test_radio_zmq.py +27 -0
- parsl/tests/test_monitoring/test_stdouterr.py +3 -0
- parsl/tests/test_shutdown/test_kill_monitoring.py +1 -1
- parsl/usage_tracking/usage.py +2 -2
- parsl/version.py +1 -1
- {parsl-2025.3.10.data → parsl-2025.3.24.data}/scripts/process_worker_pool.py +89 -82
- {parsl-2025.3.10.dist-info → parsl-2025.3.24.dist-info}/METADATA +4 -4
- {parsl-2025.3.10.dist-info → parsl-2025.3.24.dist-info}/RECORD +35 -33
- {parsl-2025.3.10.data → parsl-2025.3.24.data}/scripts/exec_parsl_function.py +0 -0
- {parsl-2025.3.10.data → parsl-2025.3.24.data}/scripts/interchange.py +0 -0
- {parsl-2025.3.10.data → parsl-2025.3.24.data}/scripts/parsl_coprocess.py +0 -0
- {parsl-2025.3.10.dist-info → parsl-2025.3.24.dist-info}/LICENSE +0 -0
- {parsl-2025.3.10.dist-info → parsl-2025.3.24.dist-info}/WHEEL +0 -0
- {parsl-2025.3.10.dist-info → parsl-2025.3.24.dist-info}/entry_points.txt +0 -0
- {parsl-2025.3.10.dist-info → parsl-2025.3.24.dist-info}/top_level.txt +0 -0
parsl/usage_tracking/usage.py
CHANGED
@@ -8,7 +8,7 @@ import uuid
|
|
8
8
|
|
9
9
|
from parsl.dataflow.states import States
|
10
10
|
from parsl.errors import ConfigurationError
|
11
|
-
from parsl.multiprocessing import
|
11
|
+
from parsl.multiprocessing import SpawnProcess
|
12
12
|
from parsl.usage_tracking.api import get_parsl_usage
|
13
13
|
from parsl.usage_tracking.levels import DISABLED as USAGE_TRACKING_DISABLED
|
14
14
|
from parsl.usage_tracking.levels import LEVEL_3 as USAGE_TRACKING_LEVEL_3
|
@@ -35,7 +35,7 @@ def async_process(fn: Callable[P, None]) -> Callable[P, None]:
|
|
35
35
|
""" Decorator function to launch a function as a separate process """
|
36
36
|
|
37
37
|
def run(*args, **kwargs):
|
38
|
-
proc =
|
38
|
+
proc = SpawnProcess(target=fn, args=args, kwargs=kwargs, name="Usage-Tracking")
|
39
39
|
proc.start()
|
40
40
|
return proc
|
41
41
|
|
parsl/version.py
CHANGED
@@ -15,6 +15,7 @@ import threading
|
|
15
15
|
import time
|
16
16
|
import uuid
|
17
17
|
from importlib.metadata import distributions
|
18
|
+
from multiprocessing.context import SpawnProcess
|
18
19
|
from multiprocessing.managers import DictProxy
|
19
20
|
from multiprocessing.sharedctypes import Synchronized
|
20
21
|
from typing import Dict, List, Optional, Sequence
|
@@ -403,52 +404,34 @@ class Manager:
|
|
403
404
|
result_outgoing.connect(self._result_q_url)
|
404
405
|
logger.info("Manager result pipe connected to interchange")
|
405
406
|
|
406
|
-
push_poll_period = max(10, self.poll_period) / 1000 # push_poll_period must be atleast 10 ms
|
407
|
-
logger.debug("push poll period: {}".format(push_poll_period))
|
408
|
-
|
409
|
-
last_beat = time.time()
|
410
|
-
last_result_beat = time.time()
|
411
|
-
items = []
|
412
|
-
|
413
407
|
while not self._stop_event.is_set():
|
408
|
+
logger.debug("Starting pending_result_queue get")
|
414
409
|
try:
|
415
|
-
|
416
|
-
r
|
417
|
-
|
418
|
-
|
419
|
-
|
420
|
-
logger.debug("
|
421
|
-
except Exception
|
422
|
-
logger.exception("
|
423
|
-
|
424
|
-
if time.time() > last_result_beat + self.heartbeat_period:
|
425
|
-
heartbeat_message = f"last_result_beat={last_result_beat} heartbeat_period={self.heartbeat_period} seconds"
|
426
|
-
logger.info(f"Sending heartbeat via results connection: {heartbeat_message}")
|
427
|
-
last_result_beat = time.time()
|
428
|
-
items.append(pickle.dumps({'type': 'heartbeat'}))
|
429
|
-
|
430
|
-
if len(items) >= self.max_queue_size or time.time() > last_beat + push_poll_period:
|
431
|
-
last_beat = time.time()
|
432
|
-
if items:
|
433
|
-
logger.debug(f"Result send: Pushing {len(items)} items")
|
434
|
-
result_outgoing.send_multipart(items)
|
435
|
-
logger.debug("Result send: Pushed")
|
436
|
-
items = []
|
437
|
-
else:
|
438
|
-
logger.debug("Result send: No items to push")
|
439
|
-
else:
|
440
|
-
logger.debug(f"Result send: check condition not met - deferring {len(items)} result items")
|
410
|
+
r = self.task_scheduler.get_result()
|
411
|
+
if r is None:
|
412
|
+
continue
|
413
|
+
logger.debug("Result received from worker: %s", id(r))
|
414
|
+
result_outgoing.send(r)
|
415
|
+
logger.debug("Result sent to interchange: %s", id(r))
|
416
|
+
except Exception:
|
417
|
+
logger.exception("Failed to send result to interchange")
|
441
418
|
|
442
419
|
result_outgoing.close()
|
443
|
-
logger.
|
420
|
+
logger.debug("Exiting")
|
444
421
|
|
445
422
|
@wrap_with_logs
|
446
|
-
def
|
423
|
+
def heartbeater(self):
|
424
|
+
while not self._stop_event.wait(self.heartbeat_period):
|
425
|
+
heartbeat_message = f"heartbeat_period={self.heartbeat_period} seconds"
|
426
|
+
logger.info(f"Sending heartbeat via results connection: {heartbeat_message}")
|
427
|
+
self.pending_result_queue.put(pickle.dumps({'type': 'heartbeat'}))
|
428
|
+
|
429
|
+
def worker_watchdog(self, procs: dict[int, SpawnProcess]):
|
447
430
|
"""Keeps workers alive."""
|
448
431
|
logger.debug("Starting worker watchdog")
|
449
432
|
|
450
433
|
while not self._stop_event.wait(self.heartbeat_period):
|
451
|
-
for worker_id, p in
|
434
|
+
for worker_id, p in procs.items():
|
452
435
|
if not p.is_alive():
|
453
436
|
logger.error("Worker {} has died".format(worker_id))
|
454
437
|
try:
|
@@ -466,11 +449,10 @@ class Manager:
|
|
466
449
|
except KeyError:
|
467
450
|
logger.info("Worker {} was not busy when it died".format(worker_id))
|
468
451
|
|
469
|
-
|
470
|
-
self.procs[worker_id] = p
|
452
|
+
procs[worker_id] = self._start_worker(worker_id)
|
471
453
|
logger.info("Worker {} has been restarted".format(worker_id))
|
472
454
|
|
473
|
-
logger.
|
455
|
+
logger.debug("Exiting")
|
474
456
|
|
475
457
|
@wrap_with_logs
|
476
458
|
def handle_monitoring_messages(self):
|
@@ -485,32 +467,28 @@ class Manager:
|
|
485
467
|
"""
|
486
468
|
logger.debug("Starting monitoring handler thread")
|
487
469
|
|
488
|
-
poll_period_s = max(10, self.poll_period) / 1000 # Must be at least 10 ms
|
489
|
-
|
490
470
|
while not self._stop_event.is_set():
|
491
471
|
try:
|
492
472
|
logger.debug("Starting monitor_queue.get()")
|
493
|
-
msg = self.monitoring_queue.get(block=True
|
494
|
-
|
495
|
-
|
496
|
-
except Exception as e:
|
497
|
-
logger.exception(f"Got an exception: {e}")
|
498
|
-
else:
|
473
|
+
msg = self.monitoring_queue.get(block=True)
|
474
|
+
if msg is None:
|
475
|
+
continue
|
499
476
|
logger.debug("Got a monitoring message")
|
500
477
|
self.pending_result_queue.put(msg)
|
501
478
|
logger.debug("Put monitoring message on pending_result_queue")
|
479
|
+
except Exception:
|
480
|
+
logger.exception("Failed to forward monitoring message")
|
502
481
|
|
503
|
-
logger.
|
482
|
+
logger.debug("Exiting")
|
504
483
|
|
505
484
|
def start(self):
|
506
485
|
""" Start the worker processes.
|
507
486
|
|
508
487
|
TODO: Move task receiving to a thread
|
509
488
|
"""
|
510
|
-
|
489
|
+
procs: dict[int, SpawnProcess] = {}
|
511
490
|
for worker_id in range(self.worker_count):
|
512
|
-
|
513
|
-
self.procs[worker_id] = p
|
491
|
+
procs[worker_id] = self._start_worker(worker_id)
|
514
492
|
|
515
493
|
logger.debug("Workers started")
|
516
494
|
|
@@ -519,40 +497,69 @@ class Manager:
|
|
519
497
|
target=self.push_results, name="Result-Pusher"
|
520
498
|
)
|
521
499
|
thr_worker_watchdog = threading.Thread(
|
522
|
-
target=self.worker_watchdog, name="worker-watchdog"
|
500
|
+
target=self.worker_watchdog, args=(procs,), name="worker-watchdog"
|
523
501
|
)
|
524
502
|
thr_monitoring_handler = threading.Thread(
|
525
503
|
target=self.handle_monitoring_messages, name="Monitoring-Handler"
|
526
504
|
)
|
505
|
+
thr_heartbeater = threading.Thread(target=self.heartbeater, name="Heartbeater")
|
527
506
|
|
528
507
|
thr_task_puller.start()
|
529
508
|
thr_result_pusher.start()
|
530
509
|
thr_worker_watchdog.start()
|
531
510
|
thr_monitoring_handler.start()
|
511
|
+
thr_heartbeater.start()
|
532
512
|
|
533
513
|
logger.info("Manager threads started")
|
534
514
|
|
535
515
|
# This might need a multiprocessing event to signal back.
|
536
516
|
self._stop_event.wait()
|
537
|
-
logger.
|
517
|
+
logger.info("Stop event set; terminating worker processes")
|
518
|
+
|
519
|
+
# Invite blocking threads to quit
|
520
|
+
self.monitoring_queue.put(None)
|
521
|
+
self.pending_result_queue.put(None)
|
538
522
|
|
523
|
+
thr_heartbeater.join()
|
539
524
|
thr_task_puller.join()
|
540
525
|
thr_result_pusher.join()
|
541
526
|
thr_worker_watchdog.join()
|
542
527
|
thr_monitoring_handler.join()
|
543
|
-
|
544
|
-
|
545
|
-
|
546
|
-
|
547
|
-
|
548
|
-
|
528
|
+
|
529
|
+
for worker_id in procs:
|
530
|
+
p = procs[worker_id]
|
531
|
+
proc_info = f"(PID: {p.pid}, Worker ID: {worker_id})"
|
532
|
+
logger.debug(f"Signaling worker {p.name} (TERM). {proc_info}")
|
533
|
+
p.terminate()
|
549
534
|
|
550
535
|
self.zmq_context.term()
|
536
|
+
|
537
|
+
# give processes 1 second to gracefully shut themselves down, based on the
|
538
|
+
# SIGTERM (.terminate()) just sent; after then, we pull the plug.
|
539
|
+
force_child_shutdown_at = time.monotonic() + 1
|
540
|
+
while procs:
|
541
|
+
worker_id, p = procs.popitem()
|
542
|
+
timeout = max(force_child_shutdown_at - time.monotonic(), 0.000001)
|
543
|
+
p.join(timeout=timeout)
|
544
|
+
proc_info = f"(PID: {p.pid}, Worker ID: {worker_id})"
|
545
|
+
if p.exitcode is not None:
|
546
|
+
logger.debug(
|
547
|
+
"Worker joined successfully. %s (exitcode: %s)", proc_info, p.exitcode
|
548
|
+
)
|
549
|
+
|
550
|
+
else:
|
551
|
+
logger.warning(
|
552
|
+
f"Worker {p.name} ({worker_id}) failed to terminate in a timely"
|
553
|
+
f" manner; sending KILL signal to process. {proc_info}"
|
554
|
+
)
|
555
|
+
p.kill()
|
556
|
+
p.join()
|
557
|
+
p.close()
|
558
|
+
|
551
559
|
delta = time.time() - self._start_time
|
552
560
|
logger.info("process_worker_pool ran for {} seconds".format(delta))
|
553
|
-
return
|
554
561
|
|
555
|
-
def _start_worker(self, worker_id: int):
|
562
|
+
def _start_worker(self, worker_id: int) -> SpawnProcess:
|
556
563
|
p = SpawnContext.Process(
|
557
564
|
target=worker,
|
558
565
|
args=(
|
@@ -939,27 +946,27 @@ if __name__ == "__main__":
|
|
939
946
|
)
|
940
947
|
logger.info(
|
941
948
|
f"\n Python version: {sys.version}"
|
942
|
-
f" Debug logging: {args.debug}"
|
943
|
-
f" Certificates dir: {args.cert_dir}"
|
944
|
-
f" Log dir: {args.logdir}"
|
945
|
-
f" Manager ID: {args.uid}"
|
946
|
-
f" Block ID: {args.block_id}"
|
947
|
-
f" cores_per_worker: {args.cores_per_worker}"
|
948
|
-
f" mem_per_worker: {args.mem_per_worker}"
|
949
|
-
f" task_port: {args.task_port}"
|
950
|
-
f" result_port: {args.result_port}"
|
951
|
-
f" addresses: {args.addresses}"
|
952
|
-
f" max_workers_per_node: {args.max_workers_per_node}"
|
953
|
-
f" poll_period: {args.poll}"
|
954
|
-
f" address_probe_timeout: {args.address_probe_timeout}"
|
955
|
-
f" Prefetch capacity: {args.prefetch_capacity}"
|
956
|
-
f" Heartbeat threshold: {args.hb_threshold}"
|
957
|
-
f" Heartbeat period: {args.hb_period}"
|
958
|
-
f" Drain period: {args.drain_period}"
|
959
|
-
f" CPU affinity: {args.cpu_affinity}"
|
960
|
-
f" Accelerators: {' '.join(args.available_accelerators)}"
|
961
|
-
f" enable_mpi_mode: {args.enable_mpi_mode}"
|
962
|
-
f" mpi_launcher: {args.mpi_launcher}"
|
949
|
+
f"\n Debug logging: {args.debug}"
|
950
|
+
f"\n Certificates dir: {args.cert_dir}"
|
951
|
+
f"\n Log dir: {args.logdir}"
|
952
|
+
f"\n Manager ID: {args.uid}"
|
953
|
+
f"\n Block ID: {args.block_id}"
|
954
|
+
f"\n cores_per_worker: {args.cores_per_worker}"
|
955
|
+
f"\n mem_per_worker: {args.mem_per_worker}"
|
956
|
+
f"\n task_port: {args.task_port}"
|
957
|
+
f"\n result_port: {args.result_port}"
|
958
|
+
f"\n addresses: {args.addresses}"
|
959
|
+
f"\n max_workers_per_node: {args.max_workers_per_node}"
|
960
|
+
f"\n poll_period: {args.poll}"
|
961
|
+
f"\n address_probe_timeout: {args.address_probe_timeout}"
|
962
|
+
f"\n Prefetch capacity: {args.prefetch_capacity}"
|
963
|
+
f"\n Heartbeat threshold: {args.hb_threshold}"
|
964
|
+
f"\n Heartbeat period: {args.hb_period}"
|
965
|
+
f"\n Drain period: {args.drain_period}"
|
966
|
+
f"\n CPU affinity: {args.cpu_affinity}"
|
967
|
+
f"\n Accelerators: {' '.join(args.available_accelerators)}"
|
968
|
+
f"\n enable_mpi_mode: {args.enable_mpi_mode}"
|
969
|
+
f"\n mpi_launcher: {args.mpi_launcher}"
|
963
970
|
)
|
964
971
|
try:
|
965
972
|
manager = Manager(task_port=args.task_port,
|
@@ -1,9 +1,9 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: parsl
|
3
|
-
Version: 2025.3.
|
3
|
+
Version: 2025.3.24
|
4
4
|
Summary: Simple data dependent workflows in Python
|
5
5
|
Home-page: https://github.com/Parsl/parsl
|
6
|
-
Download-URL: https://github.com/Parsl/parsl/archive/2025.03.
|
6
|
+
Download-URL: https://github.com/Parsl/parsl/archive/2025.03.24.tar.gz
|
7
7
|
Author: The Parsl Team
|
8
8
|
Author-email: parsl@googlegroups.com
|
9
9
|
License: Apache 2.0
|
@@ -40,7 +40,7 @@ Requires-Dist: boto3; extra == "all"
|
|
40
40
|
Requires-Dist: kubernetes; extra == "all"
|
41
41
|
Requires-Dist: ipython<=8.6.0; extra == "all"
|
42
42
|
Requires-Dist: nbsphinx; extra == "all"
|
43
|
-
Requires-Dist: sphinx<
|
43
|
+
Requires-Dist: sphinx<8,>=7.4; extra == "all"
|
44
44
|
Requires-Dist: sphinx-rtd-theme; extra == "all"
|
45
45
|
Requires-Dist: google-auth; extra == "all"
|
46
46
|
Requires-Dist: google-api-python-client; extra == "all"
|
@@ -63,7 +63,7 @@ Requires-Dist: msrestazure; extra == "azure"
|
|
63
63
|
Provides-Extra: docs
|
64
64
|
Requires-Dist: ipython<=8.6.0; extra == "docs"
|
65
65
|
Requires-Dist: nbsphinx; extra == "docs"
|
66
|
-
Requires-Dist: sphinx<
|
66
|
+
Requires-Dist: sphinx<8,>=7.4; extra == "docs"
|
67
67
|
Requires-Dist: sphinx-rtd-theme; extra == "docs"
|
68
68
|
Provides-Extra: flux
|
69
69
|
Requires-Dist: pyyaml; extra == "flux"
|
@@ -4,11 +4,11 @@ parsl/config.py,sha256=p5HQoxLj5aMagUAYfngcXG2kw0s6SJoc6u7vH2sVhPU,9635
|
|
4
4
|
parsl/curvezmq.py,sha256=6Zi7RqTP_eKWi3DFgapfK2t-Jw8vJS-ZtN1bsrByPeo,7073
|
5
5
|
parsl/errors.py,sha256=SzINzQFZDBDbj9l-DPQznD0TbGkNhHIRAPkcBCogf_A,1019
|
6
6
|
parsl/log_utils.py,sha256=u14Fkl5eDfS4HMpl0JjseNNPdbvPaugWPRQj1_af_Zo,3273
|
7
|
-
parsl/multiprocessing.py,sha256=
|
7
|
+
parsl/multiprocessing.py,sha256=JNAfgdZvQSsxVyUp229OOUqWwf_ZUhpmw8X9CdF3i6k,3614
|
8
8
|
parsl/process_loggers.py,sha256=uQ7Gd0W72Jz7rrcYlOMfLsAEhkRltxXJL2MgdduJjEw,1136
|
9
9
|
parsl/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
10
10
|
parsl/utils.py,sha256=codTX6_KLhgeTwNkRzc1lo4bgc1M93eJ-lkqOO98fvk,14331
|
11
|
-
parsl/version.py,sha256=
|
11
|
+
parsl/version.py,sha256=RGffnfvs_gOc_lEWgnZpd1jy_cuz-F39xp5lsIo6OyU,131
|
12
12
|
parsl/app/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
13
13
|
parsl/app/app.py,sha256=0gbM4AH2OtFOLsv07I5nglpElcwMSOi-FzdZZfrk7So,8532
|
14
14
|
parsl/app/bash.py,sha256=jm2AvePlCT9DZR7H_4ANDWxatp5dN_22FUlT_gWhZ-g,5528
|
@@ -53,7 +53,7 @@ parsl/data_provider/staging.py,sha256=ZDZuuFg38pjUStegKPcvPsfGp3iMeReMzfU6DSwtJj
|
|
53
53
|
parsl/data_provider/zip.py,sha256=S4kVuH9lxAegRURYbvIUR7EYYBOccyslaqyCrVWUBhw,4497
|
54
54
|
parsl/dataflow/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
55
55
|
parsl/dataflow/dependency_resolvers.py,sha256=Om8Dgh7a0ZwgXAc6TlhxLSzvxXHDlNNV1aBNiD3JTNY,3325
|
56
|
-
parsl/dataflow/dflow.py,sha256=
|
56
|
+
parsl/dataflow/dflow.py,sha256=kAEziQPm9rpGKzqhOuHSnnIXQ3KgrRaeRbYReww7Amw,61620
|
57
57
|
parsl/dataflow/errors.py,sha256=daVfr2BWs1zRsGD6JtosEMttWHvK1df1Npiu_MUvFKg,3998
|
58
58
|
parsl/dataflow/futures.py,sha256=08LuP-HFiHBIZmeKCjlsazw_WpQ5fwevrU2_WbidkYw,6080
|
59
59
|
parsl/dataflow/memoization.py,sha256=QUkTduZ_gdr8i08VWNWrqhfEvoMGsPDZegWUE2_7sGQ,12579
|
@@ -61,37 +61,37 @@ parsl/dataflow/rundirs.py,sha256=JZdzybVGubY35jL2YiKcDo65ZmRl1WyOApc8ajYxztc,108
|
|
61
61
|
parsl/dataflow/states.py,sha256=hV6mfv-y4A6xrujeQglcomnfEs7y3Xm2g6JFwC6dvgQ,2612
|
62
62
|
parsl/dataflow/taskrecord.py,sha256=qIW7T6hn9dYTuNPdUura3HQwwUpUJACwPP5REm5COf4,3042
|
63
63
|
parsl/executors/__init__.py,sha256=PEuXYrnVqwlaz_nt82s9D_YNaVsX7ET29DeIZRUR8hw,577
|
64
|
-
parsl/executors/base.py,sha256=
|
64
|
+
parsl/executors/base.py,sha256=_X-huuXKCoQatT_TYx9ApEuXiVVvUYI0S7uKlVMHP-U,4488
|
65
65
|
parsl/executors/errors.py,sha256=ZxL3nK5samPos8Xixo_jpRtPIiRJfZ5D397_qaXj2g0,2515
|
66
66
|
parsl/executors/execute_task.py,sha256=PtqHxk778UQaNah1AN-TJV5emZbOcU5TGtWDxFn3_F4,1079
|
67
|
-
parsl/executors/globus_compute.py,sha256=
|
68
|
-
parsl/executors/status_handling.py,sha256=
|
67
|
+
parsl/executors/globus_compute.py,sha256=818XKRobNRCs5-h30x2NP2XSLkoWlWoNeBZtv9hF-ec,4851
|
68
|
+
parsl/executors/status_handling.py,sha256=oiy6SQUQWwVciZd9MxF0sna9miqkMfaKv6ZTrj3h-Pc,15772
|
69
69
|
parsl/executors/threads.py,sha256=_LA5NA3GSvtjDend-1HVpjoDoNHHW13rAD0CET99fjQ,3463
|
70
70
|
parsl/executors/flux/__init__.py,sha256=P9grTTeRPXfqXurFhlSS7XhmE6tTbnCnyQ1f9b-oYHE,136
|
71
71
|
parsl/executors/flux/execute_parsl_task.py,sha256=zHP5M7ILGiwnoalZ8WsfVVdZM7uP4iQo2ThVh4crxpM,1530
|
72
|
-
parsl/executors/flux/executor.py,sha256=
|
72
|
+
parsl/executors/flux/executor.py,sha256=ii1i5V7uQnhf1BDq5nnMscmmpXJkCWtrFCuBbDaPyWI,17041
|
73
73
|
parsl/executors/flux/flux_instance_manager.py,sha256=5T3Rp7ZM-mlT0Pf0Gxgs5_YmnaPrSF9ec7zvRfLfYJw,2129
|
74
74
|
parsl/executors/high_throughput/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
75
75
|
parsl/executors/high_throughput/errors.py,sha256=k2XuvvFdUfNs2foHFnxmS-BToRMfdXpYEa4EF3ELKq4,1554
|
76
|
-
parsl/executors/high_throughput/executor.py,sha256=
|
76
|
+
parsl/executors/high_throughput/executor.py,sha256=VVKe3gveCqa3rERAqhVNsWifSrLqyMcUwpdyHCsYdz8,39663
|
77
77
|
parsl/executors/high_throughput/interchange.py,sha256=7sKIvxP3a7HSzqEq25ZCpABx-1Q2f585pFDGzUvo7_4,29459
|
78
78
|
parsl/executors/high_throughput/manager_record.py,sha256=ZMsqFxvreGLRXAw3N-JnODDa9Qfizw2tMmcBhm4lco4,490
|
79
79
|
parsl/executors/high_throughput/manager_selector.py,sha256=UKcUE6v0tO7PDMTThpKSKxVpOpOUilxDL7UbNgpZCxo,2116
|
80
80
|
parsl/executors/high_throughput/monitoring_info.py,sha256=HC0drp6nlXQpAop5PTUKNjdXMgtZVvrBL0JzZJebPP4,298
|
81
81
|
parsl/executors/high_throughput/mpi_executor.py,sha256=U-aatbLF_Mu1p6lP0HmT7Yn1Swn3cc7hPmDfuUb9TpI,4797
|
82
82
|
parsl/executors/high_throughput/mpi_prefix_composer.py,sha256=DmpKugANNa1bdYlqQBLHkrFc15fJpefPPhW9hkAlh1s,4308
|
83
|
-
parsl/executors/high_throughput/mpi_resource_management.py,sha256=
|
83
|
+
parsl/executors/high_throughput/mpi_resource_management.py,sha256=73bTW2ZbHRfcrPN318cyjiqDN50AM1cOCQqUGJDIlBg,8199
|
84
84
|
parsl/executors/high_throughput/probe.py,sha256=QOEaliO3x5cB6ltMOZMsZQ-ath9AAuFqXcBzRgWOM60,2754
|
85
|
-
parsl/executors/high_throughput/process_worker_pool.py,sha256=
|
85
|
+
parsl/executors/high_throughput/process_worker_pool.py,sha256=Q7FN0MdXIAOouxDarim6etYVHEgbXFiaMhBahC2ZtIQ,41137
|
86
86
|
parsl/executors/high_throughput/zmq_pipes.py,sha256=NUK25IEh0UkxzdqQQyM8tMtuZmjSiTeWu1DzkkAIOhA,8980
|
87
87
|
parsl/executors/radical/__init__.py,sha256=CKbtV2numw5QvgIBq1htMUrt9TqDCIC2zifyf2svTNU,186
|
88
|
-
parsl/executors/radical/executor.py,sha256=
|
88
|
+
parsl/executors/radical/executor.py,sha256=cRxEAPLvdYozCHT_zSj79KAOltfZySFYUbMU4rTbGng,22859
|
89
89
|
parsl/executors/radical/rpex_resources.py,sha256=Q7-0u3K447LBCe2y7mVcdw6jqWI7SdPXxCKhkr6FoRQ,5139
|
90
90
|
parsl/executors/radical/rpex_worker.py,sha256=z6r82ZujKb6sdKIdHsQ_5EBMDIQieeGcrlt6kGLFo4M,1830
|
91
91
|
parsl/executors/taskvine/__init__.py,sha256=9rwp3M8B0YyEhZMLO0RHaNw7u1nc01WHbXLqnBTanu0,293
|
92
92
|
parsl/executors/taskvine/errors.py,sha256=euIYkSslrNSI85kyi2s0xzOaO9ik4c1fYHstMIeiBJk,652
|
93
93
|
parsl/executors/taskvine/exec_parsl_function.py,sha256=ftGdJU78lKPPkphSHlEi4rj164mhuMHJjghVqfgeXKk,7085
|
94
|
-
parsl/executors/taskvine/executor.py,sha256=
|
94
|
+
parsl/executors/taskvine/executor.py,sha256=PpsMPYx99mgKq_xOqnRdXo20NZOr7JFtOIKETIEK-z0,30930
|
95
95
|
parsl/executors/taskvine/factory.py,sha256=GU5JryEAKJuYKwrSc162BN-lhcKhapvBZHT820pxwic,2772
|
96
96
|
parsl/executors/taskvine/factory_config.py,sha256=ZQC5vyDe8cM0nuv7fbBCV2xnWGAZ87iLlT2UqmFFI1U,3695
|
97
97
|
parsl/executors/taskvine/manager.py,sha256=SUi5mqqMm_rnkBLrZtTQe7RiHqWDn1oOejQscYzfwAU,25797
|
@@ -100,7 +100,7 @@ parsl/executors/taskvine/utils.py,sha256=iSrIogeiauL3UNy_9tiZp1cBSNn6fIJkMYQRVi1
|
|
100
100
|
parsl/executors/workqueue/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
101
101
|
parsl/executors/workqueue/errors.py,sha256=XO2naYhAsHHyiOBH6hpObg3mPNDmvMoFqErsj0-v7jc,541
|
102
102
|
parsl/executors/workqueue/exec_parsl_function.py,sha256=YXKVVIa4zXmOtz-0Ca4E_5nQfN_3S2bh2tB75uZZB4w,7774
|
103
|
-
parsl/executors/workqueue/executor.py,sha256=
|
103
|
+
parsl/executors/workqueue/executor.py,sha256=aRvEt_BGO2AGNaoF8P109z81XhlFqjyjJnka3yIzy-4,49717
|
104
104
|
parsl/executors/workqueue/parsl_coprocess.py,sha256=cF1UmTgVLoey6QzBcbYgEiEsRidSaFfuO54f1HFw_EM,5737
|
105
105
|
parsl/executors/workqueue/parsl_coprocess_stub.py,sha256=_bJmpPIgL42qM6bVzeEKt1Mn1trSP41rtJguXxPGfHI,735
|
106
106
|
parsl/jobs/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
@@ -114,10 +114,10 @@ parsl/launchers/base.py,sha256=CblcvPTJiu-MNLWaRtFe29SZQ0BpTOlaY8CGcHdlHIE,538
|
|
114
114
|
parsl/launchers/errors.py,sha256=8YMV_CHpBNVa4eXkGE4x5DaFQlZkDCRCHmBktYcY6TA,467
|
115
115
|
parsl/launchers/launchers.py,sha256=cQsNsHuCOL_nQTjPXf0--YsgsDoMoJ77bO1Wt4ncLjs,15134
|
116
116
|
parsl/monitoring/__init__.py,sha256=0ywNz6i0lM1xo_7_BIxhETDGeVd2C_0wwD7qgeaMR4c,83
|
117
|
-
parsl/monitoring/db_manager.py,sha256=
|
118
|
-
parsl/monitoring/errors.py,sha256=
|
117
|
+
parsl/monitoring/db_manager.py,sha256=L0c5S9ockq0UIchT2bjmkSAWXS-t0G-Q_neOIBfLbm0,33444
|
118
|
+
parsl/monitoring/errors.py,sha256=GParOWoCTp2w1Hmif0PaF5J6p5dWVOwyhO18bcvr_uo,277
|
119
119
|
parsl/monitoring/message_type.py,sha256=Khn88afNxcOIciKiCK4GLnn90I5BlRTiOL3zK-P07yQ,401
|
120
|
-
parsl/monitoring/monitoring.py,sha256=
|
120
|
+
parsl/monitoring/monitoring.py,sha256=ZA-36DYtPRApJDc6cd8R8xoRGfCG4OMa9mzW4OPGCCs,10065
|
121
121
|
parsl/monitoring/remote.py,sha256=t0qCTUMCzeJ_JOARFpjqlTNrAWdEb20BxhmZh9X7kEM,13728
|
122
122
|
parsl/monitoring/types.py,sha256=oOCrzv-ab-_rv4pb8o58Sdb8G_RGp1aZriRbdf9zBEk,339
|
123
123
|
parsl/monitoring/queries/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
@@ -125,13 +125,13 @@ parsl/monitoring/queries/pandas.py,sha256=0Z2r0rjTKCemf0eaDkF1irvVHn5g7KC5SYETvQ
|
|
125
125
|
parsl/monitoring/radios/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
126
126
|
parsl/monitoring/radios/base.py,sha256=Ep5kHf07Sm-ApMBJVudRhoWRyuiu0udjO4NvEir5LEk,291
|
127
127
|
parsl/monitoring/radios/filesystem.py,sha256=ioZ3jOKX5Qf0DYRtWmpCEorfuMVbS58OMS_QV7DOFOs,1765
|
128
|
-
parsl/monitoring/radios/filesystem_router.py,sha256=
|
128
|
+
parsl/monitoring/radios/filesystem_router.py,sha256=kQkinktSpsVwfNESfUggSzBlRZ5JgwjM7IDN-jARAhM,2146
|
129
129
|
parsl/monitoring/radios/htex.py,sha256=qBu4O5NYnSETHX0ptdwxSpqa2Pp3Z_V6a6lb3TbjKm4,1643
|
130
130
|
parsl/monitoring/radios/multiprocessing.py,sha256=fsfaaoMDp6VJv1DSAl-P0R2ofO6jp13byx6NsPItV3Y,655
|
131
131
|
parsl/monitoring/radios/udp.py,sha256=bTpt7JYp-5hyBBLzgiLj1_BlSTn28UVp39OYgVGLXCw,1613
|
132
|
-
parsl/monitoring/radios/udp_router.py,sha256=
|
132
|
+
parsl/monitoring/radios/udp_router.py,sha256=LEiHZVhw3lVFhqUK1FAFFtpvNOWbB6RNRBK8FaMvtDw,5771
|
133
133
|
parsl/monitoring/radios/zmq.py,sha256=fhoHp9ylhf-D3eTJb2aSHRsuic8-FJ_oRNGnniGkCAI,592
|
134
|
-
parsl/monitoring/radios/zmq_router.py,sha256=
|
134
|
+
parsl/monitoring/radios/zmq_router.py,sha256=ksaWb9bceyFhGGMDC8Nc16JhQ3qpmg8uXQypbrvvtcg,7984
|
135
135
|
parsl/monitoring/visualization/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
136
136
|
parsl/monitoring/visualization/app.py,sha256=xMeRlAnzl5lHddAOdSBcqY3D5lmOYw3Z3Z2_YyoVwnw,1425
|
137
137
|
parsl/monitoring/visualization/models.py,sha256=C7CcF6w6PhtrdvDX9VgDH-aSrpLfvYU1fJ4-HDUeFVQ,5138
|
@@ -339,11 +339,13 @@ parsl/tests/test_monitoring/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMp
|
|
339
339
|
parsl/tests/test_monitoring/test_app_names.py,sha256=A-mOMCVhZDnUyJp32fsTUkHdcyval8o7WPEWacDkbD4,2208
|
340
340
|
parsl/tests/test_monitoring/test_basic.py,sha256=VdF6JHfqsEOIMg-ysIAREgygZIjHWNDVLNVQ7jhWxmQ,4592
|
341
341
|
parsl/tests/test_monitoring/test_db_locks.py,sha256=3s3c1xhKo230ZZIJ3f1Ca4U7LcEdXnanOGVXQyNlk2U,2895
|
342
|
-
parsl/tests/test_monitoring/
|
342
|
+
parsl/tests/test_monitoring/test_exit_helper.py,sha256=ob8Qd1hlkq_mowygfPetTnYN9LfuqeXHRpPilSfDSog,1232
|
343
|
+
parsl/tests/test_monitoring/test_fuzz_zmq.py,sha256=SQNNHhXxHB_LwW4Ujqkgut3lbG0XVW-hliPagQQpiTc,3449
|
343
344
|
parsl/tests/test_monitoring/test_htex_init_blocks_vs_monitoring.py,sha256=_QV8zjBKVF_qBbBnhT0C3X9AmfS7IKLcOnEw_cU6HeM,2622
|
344
345
|
parsl/tests/test_monitoring/test_incomplete_futures.py,sha256=ZnO1sFSwlWUBHX64C_zwfTVRVC_UFNlU4h0POgx6NEo,2005
|
345
346
|
parsl/tests/test_monitoring/test_memoization_representation.py,sha256=dknv2nO7pNZ1jGxWGsC_AW3rs90gjMIeC5d7pIJ75Xc,2645
|
346
|
-
parsl/tests/test_monitoring/
|
347
|
+
parsl/tests/test_monitoring/test_radio_zmq.py,sha256=7ARjDbde9kSuP4NCx_z-UtmMf2X5opbkkKM7mZcayuA,783
|
348
|
+
parsl/tests/test_monitoring/test_stdouterr.py,sha256=SEMKBk4v5Saoq3QiraFpzUpVe5vS_132GQPSf1Qu0qM,4573
|
347
349
|
parsl/tests/test_monitoring/test_viz_colouring.py,sha256=83Qdmn3gM0j7IL6kPDcuIsp_nl4zj-liPijyIN632SY,592
|
348
350
|
parsl/tests/test_mpi_apps/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
349
351
|
parsl/tests/test_mpi_apps/test_bad_mpi_config.py,sha256=QKvEUSrHIBrvqu2fRj1MAqxsYxDfcrdQ7dzWdOZejuU,1320
|
@@ -422,7 +424,7 @@ parsl/tests/test_serialization/test_pack_resource_spec.py,sha256=-Vtyh8KyezZw8e7
|
|
422
424
|
parsl/tests/test_serialization/test_proxystore_configured.py,sha256=lGWOSEWul16enDWhW-s7CK0d3eMDzm1324Fmj0cZMVU,2293
|
423
425
|
parsl/tests/test_serialization/test_proxystore_impl.py,sha256=uGd45sfPm9rJhzqKV0rI3lqdSOAUddQf-diEpcJAlcY,1228
|
424
426
|
parsl/tests/test_shutdown/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
425
|
-
parsl/tests/test_shutdown/test_kill_monitoring.py,sha256=
|
427
|
+
parsl/tests/test_shutdown/test_kill_monitoring.py,sha256=UNU_VeorxRq8mRGhjrDmqF_axZMCQjsPfAK0wh6ZN04,1929
|
426
428
|
parsl/tests/test_staging/__init__.py,sha256=WZl9EHSkfYiSoE3Gbulcq2ifmn7IFGUkasJIobL5T5A,208
|
427
429
|
parsl/tests/test_staging/staging_provider.py,sha256=6FDpImkWOLgysqM68NbCAoXZciZokI8dmBWRAxnggBk,3242
|
428
430
|
parsl/tests/test_staging/test_1316.py,sha256=eS0e2BDM2vmPNF60aDr35wcuGgDPfXjTjRV6kyBZOQc,2652
|
@@ -456,14 +458,14 @@ parsl/tests/unit/test_usage_tracking.py,sha256=xEfUlbBRpsFdUdOrCsk1Kz5AfmMxJT7f0
|
|
456
458
|
parsl/usage_tracking/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
457
459
|
parsl/usage_tracking/api.py,sha256=iaCY58Dc5J4UM7_dJzEEs871P1p1HdxBMtNGyVdzc9g,1821
|
458
460
|
parsl/usage_tracking/levels.py,sha256=xbfzYEsd55KiZJ-mzNgPebvOH4rRHum04hROzEf41tU,291
|
459
|
-
parsl/usage_tracking/usage.py,sha256=
|
460
|
-
parsl-2025.3.
|
461
|
-
parsl-2025.3.
|
462
|
-
parsl-2025.3.
|
463
|
-
parsl-2025.3.
|
464
|
-
parsl-2025.3.
|
465
|
-
parsl-2025.3.
|
466
|
-
parsl-2025.3.
|
467
|
-
parsl-2025.3.
|
468
|
-
parsl-2025.3.
|
469
|
-
parsl-2025.3.
|
461
|
+
parsl/usage_tracking/usage.py,sha256=8hq1UPdFlVcC0V3aj0ve-MvCyvwK8Xr3CVuSto3dTW4,9165
|
462
|
+
parsl-2025.3.24.data/scripts/exec_parsl_function.py,sha256=YXKVVIa4zXmOtz-0Ca4E_5nQfN_3S2bh2tB75uZZB4w,7774
|
463
|
+
parsl-2025.3.24.data/scripts/interchange.py,sha256=17MrOc7-FXxKBWTwkzIbUoa8fvvDfPelfjByd3ZD2Wk,29446
|
464
|
+
parsl-2025.3.24.data/scripts/parsl_coprocess.py,sha256=zrVjEqQvFOHxsLufPi00xzMONagjVwLZbavPM7bbjK4,5722
|
465
|
+
parsl-2025.3.24.data/scripts/process_worker_pool.py,sha256=__gFeFQJpV5moRofj3WKQCnKp6gmzieXjzkmzVuTmX4,41123
|
466
|
+
parsl-2025.3.24.dist-info/LICENSE,sha256=tAkwu8-AdEyGxGoSvJ2gVmQdcicWw3j1ZZueVV74M-E,11357
|
467
|
+
parsl-2025.3.24.dist-info/METADATA,sha256=_Wl6Xlf9aCRKSbnQxEquJuYSA3_uNmlLKPgs-2B9nf8,4023
|
468
|
+
parsl-2025.3.24.dist-info/WHEEL,sha256=tZoeGjtWxWRfdplE7E3d45VPlLNQnvbKiYnx7gwAy8A,92
|
469
|
+
parsl-2025.3.24.dist-info/entry_points.txt,sha256=XqnsWDYoEcLbsMcpnYGKLEnSBmaIe1YoM5YsBdJG2tI,176
|
470
|
+
parsl-2025.3.24.dist-info/top_level.txt,sha256=PIheYoUFQtF2icLsgOykgU-Cjuwr2Oi6On2jo5RYgRM,6
|
471
|
+
parsl-2025.3.24.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|