From 1288c6d49f684347b4bdd2f527ae8d71db3d66e6 Mon Sep 17 00:00:00 2001 From: Ovidiu Mircescu Date: Thu, 26 Sep 2019 13:24:57 +0200 Subject: [PATCH] Do not over write CatalogResources for a job on localhost with SalomeLauncher. When launching a job on localhost, SalomeLauncher used to create a new CatalogResources file which contained only "localhost". This behavior was changed in order to be able to use every resource of the original catalog in a job launched on localhost. This is needed by salome cfd. --- src/Launcher/Launcher_Job_SALOME.cxx | 57 +++++++++++++++------------- 1 file changed, 30 insertions(+), 27 deletions(-) diff --git a/src/Launcher/Launcher_Job_SALOME.cxx b/src/Launcher/Launcher_Job_SALOME.cxx index 492875a74..9321ba918 100644 --- a/src/Launcher/Launcher_Job_SALOME.cxx +++ b/src/Launcher/Launcher_Job_SALOME.cxx @@ -97,33 +97,36 @@ Launcher::Job_SALOME::buildSalomeScript(Batch::Parametre params) launch_script_stream << "export SALOME_TMP_DIR=" << work_directory << "/logs" << std::endl; // -- Generates Catalog Resources - std::string resource_protocol = _resource_definition.getClusterInternalProtocolStr(); - launch_script_stream << "if [ \"x$LIBBATCH_NODEFILE\" != \"x\" ]; then " << std::endl; - launch_script_stream << "CATALOG_FILE=" << "CatalogResources_" << _launch_date << ".xml" << std::endl; - launch_script_stream << "export USER_CATALOG_RESOURCES_FILE=" << "$CATALOG_FILE" << std::endl; - launch_script_stream << "{" << std::endl; - launch_script_stream << "echo ''" << std::endl; - launch_script_stream << "echo ''" << std::endl; - launch_script_stream << "sort \"$LIBBATCH_NODEFILE\" | uniq -c | while read nbproc host" << std::endl; - launch_script_stream << "do" << std::endl; - // Full name doesn't work. eg: sagittaire-7 instead of sagittaire-7.lyon.grid5000.fr - launch_script_stream << "host_basename=$(echo \"$host\" | cut -f1 -d.)" << std::endl; - launch_script_stream << "echo ''" << std::endl; - launch_script_stream << "done" << std::endl; - launch_script_stream << "echo ''" << std::endl; - launch_script_stream << "} > $CATALOG_FILE" << std::endl; - launch_script_stream << "fi" << std::endl; - + // do not build a new catalog if the job is launched on localhost + if(_resource_required_params.name != "localhost") + { + std::string resource_protocol = _resource_definition.getClusterInternalProtocolStr(); + launch_script_stream << "if [ \"x$LIBBATCH_NODEFILE\" != \"x\" ]; then " << std::endl; + launch_script_stream << "CATALOG_FILE=" << "CatalogResources_" << _launch_date << ".xml" << std::endl; + launch_script_stream << "export USER_CATALOG_RESOURCES_FILE=" << "$CATALOG_FILE" << std::endl; + launch_script_stream << "{" << std::endl; + launch_script_stream << "echo ''" << std::endl; + launch_script_stream << "echo ''" << std::endl; + launch_script_stream << "sort \"$LIBBATCH_NODEFILE\" | uniq -c | while read nbproc host" << std::endl; + launch_script_stream << "do" << std::endl; + // Full name doesn't work. eg: sagittaire-7 instead of sagittaire-7.lyon.grid5000.fr + launch_script_stream << "host_basename=$(echo \"$host\" | cut -f1 -d.)" << std::endl; + launch_script_stream << "echo ''" << std::endl; + launch_script_stream << "done" << std::endl; + launch_script_stream << "echo ''" << std::endl; + launch_script_stream << "} > $CATALOG_FILE" << std::endl; + launch_script_stream << "fi" << std::endl; + } // Create file for ns-port-log launch_script_stream << "NS_PORT_FILE_PATH=$(mktemp " << _resource_definition.AppliPath << "/USERS/nsport_XXXXXX) &&\n"; -- 2.39.2