Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
X
xanadu
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Analytics
Analytics
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
SYNERG
xanadu
Commits
b2c7f892
Commit
b2c7f892
authored
Feb 17, 2020
by
Nilanjan Daw
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/master'
parents
ca680d11
626ea0c0
Changes
3
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
113 additions
and
64 deletions
+113
-64
resource_manager/src/arbiter/arbiter.c
resource_manager/src/arbiter/arbiter.c
+73
-35
resource_manager/src/common/kafka.h
resource_manager/src/common/kafka.h
+0
-16
resource_manager/src/grunt/grunt.c
resource_manager/src/grunt/grunt.c
+40
-13
No files found.
resource_manager/src/arbiter/arbiter.c
View file @
b2c7f892
This diff is collapsed.
Click to expand it.
resource_manager/src/common/kafka.h
View file @
b2c7f892
...
...
@@ -106,22 +106,6 @@ rd_kafka_t* kafkaCreateWriter (Kafka *kafka, Char *address)
printf
(
"Ading brokers to writer
\n
"
);
rd_kafka_brokers_add
(
kafka
->
writer
,
address
);
#define CREATE_TOPIC(s) \
do { \
if (kafkaCreateTopic(kafka, s, 1, 1) == -1) { \
rd_kafka_destroy(kafka->writer); \
return NULL; \
} \
} while (0)
CREATE_TOPIC
(
"REQUEST_DISPATCHER_2_ARBITER"
);
//
CREATE_TOPIC
(
"RESPONSE_ARBITER_2_DISPATCHER"
);
CREATE_TOPIC
(
"REQUEST_ARBITER_2_GRUNT"
);
CREATE_TOPIC
(
"RESPONSE_GRUNT_2_ARBITER"
);
//
CREATE_TOPIC
(
"JOIN_GRUNT_2_ARBITER"
);
//
CREATE_TOPIC
(
"HEARTBEAT_GRUNT_2_ARBITER"
);
//
#undef CREATE_TOPIC
return
kafka
->
writer
;
}
...
...
resource_manager/src/grunt/grunt.c
View file @
b2c7f892
...
...
@@ -56,20 +56,44 @@ void signalHandlerSIGINT (int _)
int
main
(
int
argc
,
char
**
argv
)
{
unused_variable
(
argc
);
unused_variable
(
argv
);
Char
*
node_name
=
NULL
;
if
(
argc
>
1
)
{
node_name
=
argv
[
1
];
}
else
{
Char
hostname
[
1024
]
=
{
0
};
gethostname
(
hostname
,
1023
);
sbufPrint
(
node_name
,
"%s"
,
hostname
);
}
signal
(
SIGINT
,
signalHandlerSIGINT
);
Kafka
kafka
=
{
0
};
kafka
.
writer
=
kafkaCreateWriter
(
&
kafka
,
"10.129.6.5:9092"
);
#define CREATE_TOPIC(s) \
do { \
if (kafkaCreateTopic(&kafka, s, 1, 1) == -1) { \
rd_kafka_destroy(kafka.writer); \
return -1; \
} \
} while (0)
CREATE_TOPIC
(
"REQUEST_DM_2_RM"
);
//
CREATE_TOPIC
(
"RESPONSE_RM_2_DM"
);
CREATE_TOPIC
(
"REQUEST_RM_2_RD"
);
CREATE_TOPIC
(
"RESPONSE_RD_2_RM"
);
//
CREATE_TOPIC
(
"JOIN_RD_2_RM"
);
//
CREATE_TOPIC
(
"HEARTBEAT_RD_2_RM"
);
//
CREATE_TOPIC
(
"LOG_COMMON"
);
//
kafka
.
reader
=
kafkaCreateReader
(
&
kafka
,
"10.129.6.5:9092"
);
rd_kafka_topic_partition_list_t
*
kafka_reader_topics
=
rd_kafka_topic_partition_list_new
(
1
);
rd_kafka_topic_t
*
topic_req_a2g
=
kafkaSubscribe
(
&
kafka
,
kafka_reader_topics
,
"REQUEST_
ARBITER_2_GRUNT
"
);
"REQUEST_
RM_2_RD
"
);
unused_variable
(
topic_req_a2g
);
rd_kafka_resp_err_t
kafka_reader_topics_err
=
rd_kafka_subscribe
(
kafka
.
reader
,
kafka_reader_topics
);
...
...
@@ -83,10 +107,10 @@ int main(int argc, char** argv)
}
Char
*
join_msg
=
NULL
;
sbufPrint
(
join_msg
,
"{
\"
id
\"
:
\"
my-machine
\"
"
);
sbufPrint
(
join_msg
,
"{
\"
node_id
\"
:
\"
%s
\"
"
,
node_name
);
sbufPrint
(
join_msg
,
"
\n
}
\n
"
);
if
(
!
kafkaWrite
(
kafka
.
writer
,
"JOIN_
GRUNT_2_ARBITER"
,
"rm_grunt
"
,
join_msg
))
{
if
(
!
kafkaWrite
(
kafka
.
writer
,
"JOIN_
RD_2_RM"
,
"resource_daemon
"
,
join_msg
))
{
return
-
1
;
}
...
...
@@ -122,7 +146,7 @@ int main(int argc, char** argv)
// TODO(naman): Error
}
else
{
command_found
=
true
;
c
.
txn_id
=
cJSON_GetObjectItem
(
root
,
"id"
)
->
valuestring
;
c
.
txn_id
=
cJSON_GetObjectItem
(
root
,
"
resource_
id"
)
->
valuestring
;
c
.
res
.
memory
=
cJSON_GetObjectItem
(
root
,
"memory"
)
->
valueint
;
}
}
...
...
@@ -144,22 +168,25 @@ int main(int argc, char** argv)
if
(
command_found
)
{
Char
*
output
=
NULL
;
sbufPrint
(
output
,
"{
\n\"
id
\"
:
\"
%s
\"
"
,
c
.
txn_id
);
sbufPrint
(
output
,
"{
\n\"
node_id
\"
:
\"
%s
\"
"
,
node_name
);
sbufPrint
(
output
,
",
\n\"
resource_id
\"
:
\"
%s
\"
"
,
c
.
txn_id
);
if
(
memory
>=
c
.
res
.
memory
)
{
sbufPrint
(
output
,
",
\n\"
success
\"
:
%d
\n
"
,
1
);
sbufPrint
(
output
,
",
\n\"
success
\"
:
true
\n
"
);
// TODO(naman): Add port
// sbufPrint(output, ",\n\"port\": %d\n", port);
}
else
{
sbufPrint
(
output
,
",
\n\"
success
\"
:
%d
\n
"
,
0
);
sbufPrint
(
output
,
",
\n\"
success
\"
:
false
\n
"
);
}
sbufPrint
(
output
,
"
\n
}
\n
"
);
if
(
!
kafkaWrite
(
kafka
.
writer
,
"RESPONSE_
GRUNT_2_ARBITER"
,
"rm_grunt
"
,
output
))
{
if
(
!
kafkaWrite
(
kafka
.
writer
,
"RESPONSE_
RD_2_RM"
,
"resource_daemon
"
,
output
))
{
return
-
1
;
}
}
else
{
// Send a heartbeat message if it is time to do so
}
{
// Send a heartbeat message if it is time to do so
U64
time_new
=
timeMilli
();
U64
time_passed
=
time_new
-
time_begin
;
time_begin
=
time_new
;
...
...
@@ -170,12 +197,12 @@ int main(int argc, char** argv)
Char
*
output
=
NULL
;
sbufPrint
(
output
,
"{
\"
id
\"
:
\"
my-machine
\"
"
);
sbufPrint
(
output
,
"{
\"
node_id
\"
:
\"
%s
\"
"
,
node_name
);
sbufPrint
(
output
,
",
\n\"
memory
\"
: %d"
,
memory
);
sbufPrint
(
output
,
"
\n
}
\n
"
);
if
(
!
kafkaWrite
(
kafka
.
writer
,
"HEARTBEAT_
GRUNT_2_ARBITER"
,
"rm_grunt
"
,
output
))
{
if
(
!
kafkaWrite
(
kafka
.
writer
,
"HEARTBEAT_
RD_2_RM"
,
"resource_daemon
"
,
output
))
{
return
-
1
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment