mirror of https://github.com/grpc/grpc.git
Merge pull request #2322 from murgatroid99/node_health_check_service
Node health check servicepull/2289/head^2
commit
a9a8eb7060
4 changed files with 225 additions and 1 deletions
@ -0,0 +1,70 @@ |
||||
/* |
||||
* |
||||
* Copyright 2015, Google Inc. |
||||
* All rights reserved. |
||||
* |
||||
* Redistribution and use in source and binary forms, with or without |
||||
* modification, are permitted provided that the following conditions are |
||||
* met: |
||||
* |
||||
* * Redistributions of source code must retain the above copyright |
||||
* notice, this list of conditions and the following disclaimer. |
||||
* * Redistributions in binary form must reproduce the above |
||||
* copyright notice, this list of conditions and the following disclaimer |
||||
* in the documentation and/or other materials provided with the |
||||
* distribution. |
||||
* * Neither the name of Google Inc. nor the names of its |
||||
* contributors may be used to endorse or promote products derived from |
||||
* this software without specific prior written permission. |
||||
* |
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
||||
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
||||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
||||
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
||||
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
||||
* |
||||
*/ |
||||
|
||||
'use strict'; |
||||
|
||||
var grpc = require('../'); |
||||
|
||||
var _ = require('lodash'); |
||||
|
||||
var health_proto = grpc.load(__dirname + '/health.proto'); |
||||
|
||||
var HealthClient = health_proto.grpc.health.v1alpha.Health; |
||||
|
||||
function HealthImplementation(statusMap) { |
||||
this.statusMap = _.clone(statusMap); |
||||
} |
||||
|
||||
HealthImplementation.prototype.setStatus = function(host, service, status) { |
||||
if (!this.statusMap[host]) { |
||||
this.statusMap[host] = {}; |
||||
} |
||||
this.statusMap[host][service] = status; |
||||
}; |
||||
|
||||
HealthImplementation.prototype.check = function(call, callback){ |
||||
var host = call.request.host; |
||||
var service = call.request.service; |
||||
var status = _.get(this.statusMap, [host, service], null); |
||||
if (status === null) { |
||||
callback({code:grpc.status.NOT_FOUND}); |
||||
} else { |
||||
callback(null, {status: status}); |
||||
} |
||||
}; |
||||
|
||||
module.exports = { |
||||
Client: HealthClient, |
||||
service: HealthClient.service, |
||||
Implementation: HealthImplementation |
||||
}; |
@ -0,0 +1,50 @@ |
||||
// Copyright 2015, Google Inc. |
||||
// All rights reserved. |
||||
// |
||||
// Redistribution and use in source and binary forms, with or without |
||||
// modification, are permitted provided that the following conditions are |
||||
// met: |
||||
// |
||||
// * Redistributions of source code must retain the above copyright |
||||
// notice, this list of conditions and the following disclaimer. |
||||
// * Redistributions in binary form must reproduce the above |
||||
// copyright notice, this list of conditions and the following disclaimer |
||||
// in the documentation and/or other materials provided with the |
||||
// distribution. |
||||
// * Neither the name of Google Inc. nor the names of its |
||||
// contributors may be used to endorse or promote products derived from |
||||
// this software without specific prior written permission. |
||||
// |
||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
||||
|
||||
syntax = "proto3"; |
||||
|
||||
package grpc.health.v1alpha; |
||||
|
||||
message HealthCheckRequest { |
||||
string host = 1; |
||||
string service = 2; |
||||
} |
||||
|
||||
message HealthCheckResponse { |
||||
enum ServingStatus { |
||||
UNKNOWN = 0; |
||||
SERVING = 1; |
||||
NOT_SERVING = 2; |
||||
} |
||||
ServingStatus status = 1; |
||||
} |
||||
|
||||
service Health { |
||||
rpc Check(HealthCheckRequest) returns (HealthCheckResponse); |
||||
} |
@ -0,0 +1,103 @@ |
||||
/* |
||||
* |
||||
* Copyright 2015, Google Inc. |
||||
* All rights reserved. |
||||
* |
||||
* Redistribution and use in source and binary forms, with or without |
||||
* modification, are permitted provided that the following conditions are |
||||
* met: |
||||
* |
||||
* * Redistributions of source code must retain the above copyright |
||||
* notice, this list of conditions and the following disclaimer. |
||||
* * Redistributions in binary form must reproduce the above |
||||
* copyright notice, this list of conditions and the following disclaimer |
||||
* in the documentation and/or other materials provided with the |
||||
* distribution. |
||||
* * Neither the name of Google Inc. nor the names of its |
||||
* contributors may be used to endorse or promote products derived from |
||||
* this software without specific prior written permission. |
||||
* |
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
||||
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
||||
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
||||
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
||||
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
||||
* |
||||
*/ |
||||
|
||||
'use strict'; |
||||
|
||||
var assert = require('assert'); |
||||
|
||||
var health = require('../health_check/health.js'); |
||||
|
||||
var grpc = require('../'); |
||||
|
||||
describe('Health Checking', function() { |
||||
var statusMap = { |
||||
'': { |
||||
'': 'SERVING', |
||||
'grpc.test.TestService': 'NOT_SERVING', |
||||
}, |
||||
virtual_host: { |
||||
'grpc.test.TestService': 'SERVING' |
||||
} |
||||
}; |
||||
var HealthServer = grpc.buildServer([health.service]); |
||||
var healthServer = new HealthServer({ |
||||
'grpc.health.v1alpha.Health': new health.Implementation(statusMap) |
||||
}); |
||||
var healthClient; |
||||
before(function() { |
||||
var port_num = healthServer.bind('0.0.0.0:0'); |
||||
healthServer.listen(); |
||||
healthClient = new health.Client('localhost:' + port_num); |
||||
}); |
||||
after(function() { |
||||
healthServer.shutdown(); |
||||
}); |
||||
it('should say an enabled service is SERVING', function(done) { |
||||
healthClient.check({service: ''}, function(err, response) { |
||||
assert.ifError(err); |
||||
assert.strictEqual(response.status, 'SERVING'); |
||||
done(); |
||||
}); |
||||
}); |
||||
it('should say that a disabled service is NOT_SERVING', function(done) { |
||||
healthClient.check({service: 'grpc.test.TestService'}, |
||||
function(err, response) { |
||||
assert.ifError(err); |
||||
assert.strictEqual(response.status, 'NOT_SERVING'); |
||||
done(); |
||||
}); |
||||
}); |
||||
it('should say that a service on another host is SERVING', function(done) { |
||||
healthClient.check({host: 'virtual_host', service: 'grpc.test.TestService'}, |
||||
function(err, response) { |
||||
assert.ifError(err); |
||||
assert.strictEqual(response.status, 'SERVING'); |
||||
done(); |
||||
}); |
||||
}); |
||||
it('should get NOT_FOUND if the service is not registered', function(done) { |
||||
healthClient.check({service: 'not_registered'}, function(err, response) { |
||||
assert(err); |
||||
assert.strictEqual(err.code, grpc.status.NOT_FOUND); |
||||
done(); |
||||
}); |
||||
}); |
||||
it('should get NOT_FOUND if the host is not registered', function(done) { |
||||
healthClient.check({host: 'wrong_host', service: 'grpc.test.TestService'}, |
||||
function(err, response) { |
||||
assert(err); |
||||
assert.strictEqual(err.code, grpc.status.NOT_FOUND); |
||||
done(); |
||||
}); |
||||
}); |
||||
}); |
Loading…
Reference in new issue