mirror of
https://github.com/OpenNebula/one.git
synced 2025-01-21 18:03:38 +03:00
2123afc890
logic in oned to delay NIC/context resolution till deployment time. Also scheduler has been extended to use the match-making algorithm to networks. Sunstone interface changes to select auto networks.
72 lines
2.3 KiB
C++
72 lines
2.3 KiB
C++
/* -------------------------------------------------------------------------- */
|
|
/* Copyright 2002-2018, OpenNebula Project, OpenNebula Systems */
|
|
/* */
|
|
/* Licensed under the Apache License, Version 2.0 (the "License"); you may */
|
|
/* not use this file except in compliance with the License. You may obtain */
|
|
/* a copy of the License at */
|
|
/* */
|
|
/* http://www.apache.org/licenses/LICENSE-2.0 */
|
|
/* */
|
|
/* Unless required by applicable law or agreed to in writing, software */
|
|
/* distributed under the License is distributed on an "AS IS" BASIS, */
|
|
/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */
|
|
/* See the License for the specific language governing permissions and */
|
|
/* limitations under the License. */
|
|
/* -------------------------------------------------------------------------- */
|
|
|
|
#include "Scheduler.h"
|
|
#include "SchedulerTemplate.h"
|
|
#include "RankPolicy.h"
|
|
#include "UserPriorityPolicy.h"
|
|
#include <unistd.h>
|
|
#include <sys/types.h>
|
|
#include <sys/stat.h>
|
|
#include <fcntl.h>
|
|
|
|
#include <iostream>
|
|
#include <sstream>
|
|
|
|
|
|
using namespace std;
|
|
|
|
class RankScheduler : public Scheduler
|
|
{
|
|
public:
|
|
|
|
RankScheduler():Scheduler(),rp_host(0),rp_ds(0),rp_nics(0), rp_vm(0){};
|
|
|
|
~RankScheduler()
|
|
{
|
|
delete rp_host;
|
|
delete rp_ds;
|
|
delete rp_nics;
|
|
|
|
delete rp_vm;
|
|
};
|
|
|
|
void register_policies(const SchedulerTemplate& conf)
|
|
{
|
|
rp_host = new RankHostPolicy(hpool, conf.get_policy(), 1.0);
|
|
|
|
add_host_policy(rp_host);
|
|
|
|
rp_ds = new RankDatastorePolicy(dspool, conf.get_ds_policy(), 1.0);
|
|
|
|
add_ds_policy(rp_ds);
|
|
|
|
rp_vm = new UserPriorityPolicy(vmpool, 1.0);
|
|
|
|
add_vm_policy(rp_vm);
|
|
|
|
rp_nics = new RankNetworkPolicy(vnetpool, conf.get_nics_policy(), 1.0);
|
|
|
|
add_nic_policy(rp_nics);
|
|
};
|
|
|
|
private:
|
|
RankPolicy * rp_host;
|
|
RankPolicy * rp_ds;
|
|
RankPolicy * rp_nics;
|
|
|
|
UserPriorityPolicy * rp_vm;
|
|
}; |