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
6438b7aa
Commit
6438b7aa
authored
Feb 11, 2020
by
Nilanjan Daw
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
container deployment working
Reverse proxy based container worker working
parent
26565f8c
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
91 additions
and
72 deletions
+91
-72
dispatch_module/dispatch_daemon/config.json
dispatch_module/dispatch_daemon/config.json
+1
-1
dispatch_module/dispatch_daemon/execute.js
dispatch_module/dispatch_daemon/execute.js
+25
-19
dispatch_module/dispatch_daemon/index.js
dispatch_module/dispatch_daemon/index.js
+6
-5
dispatch_module/dispatcher/index.js
dispatch_module/dispatcher/index.js
+32
-45
dispatch_module/dispatcher/lib.js
dispatch_module/dispatcher/lib.js
+24
-1
dispatch_module/dispatcher/package.json
dispatch_module/dispatcher/package.json
+2
-0
dispatch_module/dispatcher/repository/worker_env/env.js
dispatch_module/dispatcher/repository/worker_env/env.js
+1
-1
No files found.
dispatch_module/dispatch_daemon/config.json
View file @
6438b7aa
{
"id"
:
"10.130.150.246"
,
"master_node"
:
"10.129.6.5"
}
\ No newline at end of file
{
"id"
:
"192.168.31.51"
,
"master_node"
:
"10.129.6.5"
}
\ No newline at end of file
dispatch_module/dispatch_daemon/execute.js
View file @
6438b7aa
...
...
@@ -102,6 +102,8 @@ function runContainer(imageName, port) {
}
else
{
const
process_checkContainer
=
spawn
(
'
docker
'
,
[
'
container
'
,
'
inspect
'
,
imageName
]);
process_checkContainer
.
on
(
'
close
'
,
(
code
)
=>
{
console
.
log
(
"
container starting at port
"
,
port
);
if
(
code
!=
0
)
{
const
process
=
spawn
(
'
docker
'
,
[
"
run
"
,
"
-p
"
,
`
${
port
}
:5000`
,
"
--name
"
,
imageName
,
registry_url
+
imageName
]);
let
result
=
""
;
...
...
@@ -124,26 +126,30 @@ function runContainer(imageName, port) {
workerEvent
.
emit
(
'
end
'
,
port
,
"
container
"
);
})
}
else
{
const
process
=
spawn
(
'
docker
'
,
[
"
start
"
,
"
-a
"
,
imageName
]);
let
result
=
""
;
timeStart
=
Date
.
now
()
process
.
stdout
.
on
(
'
data
'
,
(
data
)
=>
{
console
.
log
(
`stdout:
${
data
}
`
);
let
timeDifference
=
Math
.
ceil
((
Date
.
now
()
-
timeStart
))
console
.
log
(
"
container run time taken:
"
,
timeDifference
);
result
+=
data
;
workerEvent
.
emit
(
'
start
'
,
imageName
,
port
,
"
container
"
)
resolve
(
result
);
});
process
.
stderr
.
on
(
'
data
'
,
(
data
)
=>
{
console
.
error
(
`stderr:
${
data
}
`
);
reject
(
data
);
});
process
.
on
(
'
close
'
,
(
code
)
=>
{
workerEvent
.
emit
(
'
end
'
,
port
,
"
container
"
);
const
clean_container
=
spawn
(
'
docker
'
,
[
'
rm
'
,
imageName
])
clean_container
.
on
(
'
close
'
,
code
=>
{
const
process
=
spawn
(
'
docker
'
,
[
"
run
"
,
"
-p
"
,
`
${
port
}
:5000`
,
"
--name
"
,
imageName
,
registry_url
+
imageName
]);
let
result
=
""
;
timeStart
=
Date
.
now
()
process
.
stdout
.
on
(
'
data
'
,
(
data
)
=>
{
console
.
log
(
`stdout:
${
data
}
`
);
let
timeDifference
=
Math
.
ceil
((
Date
.
now
()
-
timeStart
))
console
.
log
(
"
container run time taken:
"
,
timeDifference
);
// result += data;
workerEvent
.
emit
(
'
start
'
,
imageName
,
port
,
"
container
"
)
resolve
(
result
);
});
process
.
stderr
.
on
(
'
data
'
,
(
data
)
=>
{
console
.
error
(
`stderr:
${
data
}
`
);
reject
(
data
);
});
process
.
on
(
'
close
'
,
(
code
)
=>
{
workerEvent
.
emit
(
'
end
'
,
port
,
"
container
"
);
})
})
}
})
...
...
dispatch_module/dispatch_daemon/index.js
View file @
6438b7aa
...
...
@@ -55,6 +55,8 @@ libSupport.makeTopic(node_id).then(() => {
function
startWorker
(
local_repository
,
functionHash
,
function_id
,
producer
,
runtime
)
{
let
port
=
libSupport
.
getPort
(
usedPort
)
console
.
log
(
"
Using port
"
,
port
,
"
for functionHash
"
,
functionHash
);
usedPort
.
set
(
port
,
functionHash
)
if
(
runtime
===
"
isolate
"
)
execute
.
runIsolate
(
local_repository
+
functionHash
).
then
(
result
=>
{
...
...
@@ -123,17 +125,16 @@ execute.workerEvent.on("start", (functionHash, port, runtime) => {
})
execute
.
workerEvent
.
on
(
'
end
'
,
(
port
)
=>
{
execute
.
workerEvent
.
on
(
'
end
'
,
(
port
,
runtime
)
=>
{
let
functionHash
=
usedPort
.
get
(
port
)
usedPort
.
delete
(
port
)
producer
.
send
(
[{
topic
:
"
removeWorker
"
,
messages
:
JSON
.
stringify
({
functionHash
,
port
,
runtime
,
node_id
})
}],
()
=>
{
})
console
.
log
(
"
Ending worker for function
"
,
functionHash
,
usedPort
,
functionToPort
);
}],
()
=>
{
console
.
log
(
"
Ending worker for function
"
,
functionHash
,
usedPort
);
})
})
setInterval
(
heartbeat
,
1000
);
\ No newline at end of file
dispatch_module/dispatcher/index.js
View file @
6438b7aa
...
...
@@ -25,7 +25,10 @@ let kafka = require('kafka-node'),
Consumer
=
kafka
.
Consumer
,
consumer
=
new
Consumer
(
client
,
[
{
topic
:
'
response
'
,
partition
:
0
,
offset
:
0
},
{
topic
:
'
heartbeat
'
},
{
topic
:
"
deployed
"
}
{
topic
:
'
response
'
,
partition
:
0
,
offset
:
0
},
{
topic
:
'
heartbeat
'
},
{
topic
:
"
deployed
"
},
{
topic
:
"
removeWorker
"
}
],
[
{
autoCommit
:
true
}
...
...
@@ -148,8 +151,7 @@ app.post('/serverless/execute/:id', (req, res) => {
let
forwardTo
=
functionToPort
.
get
(
req
.
params
.
id
+
runtime
)
console
.
log
(
"
resource found
"
,
forwardTo
);
res
.
redirect
(
307
,
`http://
${
forwardTo
.
node_id
}
:
${
forwardTo
.
port
}
/serverless/function/execute`
);
console
.
log
(
"
sending request to:
"
,
`http://
${
forwardTo
.
node_id
}
:
${
forwardTo
.
port
}
/serverless/function/execute`
);
libSupport
.
reverseProxy
(
req
,
res
,
`http://
${
forwardTo
.
node_id
}
:
${
forwardTo
.
port
}
/serverless/function/execute`
)
}
else
{
requestQueue
.
push
({
req
,
res
})
...
...
@@ -180,7 +182,7 @@ function dispatch() {
partition
:
0
}]
producer
.
send
(
payload
,
()
=>
{})
db
.
set
(
function
_id
,
res
)
db
.
set
(
function
Hash
+
runtime
,
{
req
,
res
}
)
}
}
...
...
@@ -189,48 +191,22 @@ function getAddress() {
return
workerNodes
[
Math
.
floor
(
Math
.
random
()
*
workerNodes
.
length
)];
}
// client.on('message', function (topic, message) {
// if (topic === "response") {
// message = JSON.parse(message)
// console.log(message);
// let res = db.get(message.function_id)
// res.json({
// "status": "success",
// "reply": message.result
// })
// db.delete(message.function_id)
// } else if (topic === "heartbeat") {
// message = JSON.parse(message)
// if (workerNodes.indexOf(message.address) === -1) {
// workerNodes.push(message.address)
// console.log(workerNodes);
// }
// }
// })
app
.
listen
(
port
,
()
=>
console
.
log
(
`Server listening on port
${
port
}
!`
))
// client.on('connect', function () {
// client.subscribe("response")
// client.subscribe("heartbeat")
// })
consumer
.
on
(
'
message
'
,
function
(
message
)
{
// console.log(message);
let
topic
=
message
.
topic
message
=
message
.
value
if
(
topic
===
"
response
"
)
{
message
=
JSON
.
parse
(
message
)
console
.
log
(
message
);
let
res
=
db
.
get
(
message
.
function_id
)
if
(
res
!=
null
)
res
.
json
({
"
status
"
:
"
success
"
,
"
reply
"
:
message
.
result
})
db
.
delete
(
message
.
function_id
)
//
message = JSON.parse(message)
//
console.log(message);
// let {req, res}
= db.get(message.function_id)
//
if (res != null)
//
res.json({
//
"status": "success",
//
"reply": message.result
//
})
//
db.delete(message.function_id)
}
else
if
(
topic
===
"
heartbeat
"
)
{
message
=
JSON
.
parse
(
message
)
if
(
Date
.
now
()
-
message
.
timestamp
<
300
)
...
...
@@ -239,14 +215,25 @@ consumer.on('message', function (message) {
console
.
log
(
workerNodes
);
}
}
else
if
(
topic
==
"
deployed
"
)
{
let
res
=
db
.
get
(
message
.
function_id
)
message
=
JSON
.
parse
(
message
)
console
.
log
(
message
);
// res.redirect(307, `http://${forwardTo.node_id}:${forwardTo.port}/serverless/function/execute`);
functionToPort
.
set
(
message
.
functionHash
+
message
.
runtime
,
{
port
:
parseInt
(
message
.
port
),
node_id
:
message
.
node_id
})
console
.
log
(
functionToPort
);
if
(
db
.
has
(
message
.
functionHash
+
message
.
runtime
))
{
let
{
req
,
res
}
=
db
.
get
(
message
.
functionHash
+
message
.
runtime
)
// res.redirect(307, `http://${forwardTo.node_id}:${forwardTo.port}/serverless/function/execute`);
if
(
parseInt
(
message
.
port
)
!=
-
1
)
functionToPort
.
set
(
message
.
functionHash
+
message
.
runtime
,
{
port
:
parseInt
(
message
.
port
),
node_id
:
message
.
node_id
})
libSupport
.
reverseProxy
(
req
,
res
,
`http://
${
message
.
node_id
}
:
${
message
.
port
}
/serverless/function/execute`
)
}
}
else
if
(
topic
==
"
removeWorker
"
)
{
console
.
log
(
"
removing metadata
"
,
message
);
message
=
JSON
.
parse
(
message
)
functionToPort
.
delete
(
message
.
functionHash
+
message
.
runtime
)
}
});
...
...
dispatch_module/dispatcher/lib.js
View file @
6438b7aa
const
crypto
=
require
(
'
crypto
'
);
const
fs
=
require
(
'
fs
'
)
var
rp
=
require
(
'
request-promise
'
);
function
makeid
(
length
)
{
var
result
=
''
;
var
characters
=
'
abcdefghijklmnopqrstuvwxyz0123456789
'
;
...
...
@@ -25,6 +26,28 @@ function makeid(length) {
fs
.
writeFileSync
(
functionPath
+
hash
,
output
)
return
hash
}
function
reverseProxy
(
req
,
res
,
url
)
{
console
.
log
(
"
requesting reverseproxy
"
);
var
options
=
{
method
:
'
POST
'
,
uri
:
url
,
body
:
req
.
body
,
json
:
true
// Automatically stringifies the body to JSON
};
rp
(
options
)
.
then
(
function
(
parsedBody
)
{
console
.
log
(
"
parsed body:
"
,
parsedBody
);
res
.
json
(
parsedBody
)
})
.
catch
(
function
(
err
)
{
console
.
log
(
"
error
"
,
err
.
message
);
res
.
json
(
err
.
message
).
status
(
err
.
statusCode
)
});
}
module
.
exports
.
makeid
=
makeid
;
module
.
exports
.
generateExecutor
=
generateExecutor
;
\ No newline at end of file
module
.
exports
.
generateExecutor
=
generateExecutor
;
module
.
exports
.
reverseProxy
=
reverseProxy
;
\ No newline at end of file
dispatch_module/dispatcher/package.json
View file @
6438b7aa
...
...
@@ -19,6 +19,8 @@
"mqtt"
:
"^3.0.0"
,
"nano"
:
"^8.1.0"
,
"redis"
:
"^2.8.0"
,
"request"
:
"^2.88.0"
,
"request-promise"
:
"^4.2.5"
,
"save"
:
"^2.4.0"
}
}
dispatch_module/dispatcher/repository/worker_env/env.js
View file @
6438b7aa
...
...
@@ -5,7 +5,7 @@ const app = express()
app
.
use
(
bodyParser
.
urlencoded
({
extended
:
true
}))
app
.
use
(
bodyParser
.
json
())
let
port
=
5000
,
lastRequest
=
Date
.
now
()
app
.
post
(
'
/serverless/function/execute/
:id
'
,
(
req
,
res
)
=>
{
app
.
post
(
'
/serverless/function/execute/
'
,
(
req
,
res
)
=>
{
let
payload
=
req
.
body
lastRequest
=
Date
.
now
()
executor
(
payload
).
then
((
result
)
=>
{
...
...
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