10 #ifndef SIMULATION_COMPUTESERVICE_H
11 #define SIMULATION_COMPUTESERVICE_H
19 #include "wrench/services/Service.h"
20 #include "wrench/job/Job.h"
21 #include "wrench/job/StandardJob.h"
22 #include "wrench/job/PilotJob.h"
23 #include "wrench/job/CompoundJob.h"
52 static constexpr
unsigned long ALL_CORES = ULONG_MAX;
57 static constexpr
double ALL_RAM = DBL_MAX;
69 TERMINATION_COMPUTE_SERVICE_TERMINATED,
70 TERMINATION_JOB_KILLED,
71 TERMINATION_JOB_TIMEOUT
105 std::vector<std::string>
getHosts();
146 submitCompoundJob(std::shared_ptr<CompoundJob> job,
const std::map<std::string, std::string> &service_specific_arguments) = 0;
160 std::string service_name,
161 std::string scratch_space_mount_point);
166 friend class JobManager;
168 void submitJob(std::shared_ptr<CompoundJob> job,
const std::map<std::string, std::string>& = {});
171 std::map<std::string, std::string> &service_specific_args) ;
176 std::string service_name,
177 std::shared_ptr<StorageService> scratch_space);
199 std::shared_ptr<StorageService> scratch_space_storage_service_shared_ptr;
201 std::map<std::string, double> getServiceResourceInformation(
const std::string &desired_entries);
208 #endif //SIMULATION_COMPUTESERVICE_H
double getTotalScratchSpaceSize()
Get the total capacity of the compute service's scratch storage space.
Definition: ComputeService.cpp:527
std::map< std::string, double > getPerHostAvailableMemoryCapacity()
Get ram availability for each of the compute service's host.
Definition: ComputeService.cpp:325
TerminationCause
Job termination cause enum.
Definition: ComputeService.h:67
std::map< std::string, unsigned long > getPerHostNumIdleCores()
Get idle core counts for each of the compute service's host.
Definition: ComputeService.cpp:300
virtual bool hasScratch() const
Checks if the compute service has a scratch space.
Definition: ComputeService.cpp:561
virtual void terminateCompoundJob(std::shared_ptr< CompoundJob > job)=0
Method to terminate a compound job.
double getTTL()
Get the time-to-live of the compute service.
Definition: ComputeService.cpp:468
virtual unsigned long getTotalNumIdleCores()
Get the total idle core count for all hosts of the compute service. Note that this doesn't mean that ...
Definition: ComputeService.cpp:353
std::map< std::string, double > getCoreFlopRate()
Get the per-core flop rate of the compute service's hosts.
Definition: ComputeService.cpp:421
virtual bool supportsPilotJobs()=0
Returns true if the service supports compound jobs.
The compute service base class.
Definition: ComputeService.h:34
std::vector< std::string > getHosts()
Get the list of the compute service's compute host.
Definition: ComputeService.cpp:221
std::shared_ptr< StorageService > getScratch()
Get the compute service's scratch storage space.
Definition: ComputeService.cpp:545
virtual void validateJobsUseOfScratch(std::map< std::string, std::string > &service_specific_args)
Method to validate that a job's use of the scratch space if ok. Throws exception if not.
Definition: ComputeService.cpp:580
Definition: Action.cpp:28
std::map< std::string, unsigned long > getPerHostNumCores()
Get core counts for each of the compute service's host.
Definition: ComputeService.cpp:248
void submitJob(std::shared_ptr< CompoundJob > job, const std::map< std::string, std::string > &={})
Submit a job to the compute service.
Definition: ComputeService.cpp:108
ComputeService(const std::string &hostname, std::string service_name, std::string scratch_space_mount_point)
Constructor.
Definition: ComputeService.cpp:155
double getFreeScratchSpaceSize()
Get the free space on the compute service's scratch storage space.
Definition: ComputeService.cpp:536
virtual bool supportsStandardJobs()=0
Returns true if the service supports standard jobs.
void terminateJob(std::shared_ptr< CompoundJob > job)
Terminate a previously-submitted job (which may or may not be running yet)
Definition: ComputeService.cpp:132
virtual void submitCompoundJob(std::shared_ptr< CompoundJob > job, const std::map< std::string, std::string > &service_specific_arguments)=0
Method to submit a compound job to the service.
std::shared_ptr< StorageService > getScratchSharedPtr()
Get a shared pointer to the compute service's scratch storage space.
Definition: ComputeService.cpp:553
void stop() override
Stop the compute service.
Definition: ComputeService.cpp:32
unsigned long getTotalNumCores()
Get the total core counts for all hosts of the compute service.
Definition: ComputeService.cpp:273
virtual void validateServiceSpecificArguments(std::shared_ptr< CompoundJob > job, std::map< std::string, std::string > &service_specific_args)
Method the validates service-specific arguments (throws std::invalid_argument if invalid)
Definition: ComputeService.cpp:570
static constexpr unsigned long ALL_CORES
A convenient constant to mean "use all cores of a physical host" whenever a number of cores is needed...
Definition: ComputeService.h:52
std::string hostname
The name of the host on which the daemon is running.
Definition: S4U_Daemon.h:60
A class that provides basic simulation methods. Once the simulation object has been explicitly or imp...
Definition: Simulation.h:48
std::shared_ptr< StorageService > scratch_space_storage_service
A scratch storage service associated to the compute service.
Definition: ComputeService.h:180
virtual bool supportsCompoundJobs()=0
Returns true if the service supports pilot jobs.
static constexpr double ALL_RAM
A convenient constant to mean "use all ram of a physical host" whenever a ram capacity is needed when...
Definition: ComputeService.h:57
A service that can be added to the simulation and that can be used by a WMS when executing a workflow...
Definition: Service.h:31
virtual bool isThereAtLeastOneHostWithIdleResources(unsigned long num_cores, double ram)
Method to find out if, right now, the compute service has at least one host with some idle number of ...
Definition: ComputeService.cpp:380
unsigned long getNumHosts()
Get the number of hosts that the compute service manages.
Definition: ComputeService.cpp:202
std::map< std::string, double > getMemoryCapacity()
Get the RAM capacities for each of the compute service's hosts.
Definition: ComputeService.cpp:444