-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmanager.h
More file actions
89 lines (76 loc) · 2.29 KB
/
Copy pathmanager.h
File metadata and controls
89 lines (76 loc) · 2.29 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
/*
* manager.h
*
* Created on: 2017年6月2日
* Author: zjbpoping
*/
#ifndef MANAGER_H_
#define MANAGER_H_
#include "proc_commu.h"
#include "endpoint.h"
#include "state.h"
#include <unordered_map>
#include <mutex>
#include <iostream>
using namespace std;
namespace ps{
class Customer;
/*parameter Server节点管理器,思路:节点崩溃和添加可以通过Scheduler节点通信来确定*/
class Manager{
public:
/*返回一个静态的Manager对象,一个节点只有这么一个*/
static Manager* Get(){
static Manager manager;
return &manager;
}
/*返回endpoint指针*/
Endpoint* GetEndpoint(){return ep_; }
int NumWorkers(){return num_workers_;}
int NumServers(){return num_servers_;}
void AddWorkers(){num_workers_++;}
void AddServers(){num_servers_++;}
// void SetWorkers(int num){num_workers_=num;}
// void SetServers(int num){num_servers_=num;}
/*判断当前节点类型*/
bool IsWorker(){return is_worker_;}
bool IsServer(){return is_server_;}
bool IsScheduler(){return is_scheduler_;}
/*启动节点管理器,同时会启动负责通信的endpoint*/
void Start();
/*终止节点管理器*/
void Stop();
int GetServerID(int num){
return num*2+8;
}
int GetWorkerID(int num){
return num*2+9;
}
void SetWorkerGroup(int id);
void SetServerGroup(int id);
int NodeIDSize(){
return node_ids_.size();
}
Customer* GetCustomer(int id,int timeout=0) const;
void AddCustomer(Customer* customer);
void RemoveCustomer(Customer* customer);
const std::vector<int>& GetNodeIDs(int node_id) const{
const auto it=node_ids_.find(node_id);
//it是空的话会出错,以后解决
return it->second;
}
private:
Manager();
~Manager(){delete ep_;}
/*该节点的通信断端点,也是一个节点只有一个*/
Endpoint* ep_;
int num_workers_=0,num_servers_=0;
bool is_worker_,is_server_,is_scheduler_;
//bool trans=true;//考虑用来作为允许传输标识符
time_t start_time_;
std::unordered_map<int,Customer*> customers_;
//还需要添加node_ids的初始化过程,思路可以是每次计算好num_workers_之后调用
std::unordered_map<int,std::vector<int>> node_ids_;
mutable std::mutex mu_;
};
}
#endif