vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 1 | #!/usr/bin/env ruby |
| 2 | |
Jan Tattermusch | 7897ae9 | 2017-06-07 20:57:36 | [diff] [blame] | 3 | # Copyright 2016 gRPC authors. |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 4 | # |
Jan Tattermusch | 7897ae9 | 2017-06-07 20:57:36 | [diff] [blame] | 5 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 6 | # you may not use this file except in compliance with the License. |
| 7 | # You may obtain a copy of the License at |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 8 | # |
Jan Tattermusch | 7897ae9 | 2017-06-07 20:57:36 | [diff] [blame] | 9 | # http://www.apache.org/licenses/LICENSE-2.0 |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 10 | # |
Jan Tattermusch | 7897ae9 | 2017-06-07 20:57:36 | [diff] [blame] | 11 | # Unless required by applicable law or agreed to in writing, software |
| 12 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 13 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 14 | # See the License for the specific language governing permissions and |
| 15 | # limitations under the License. |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 16 | |
| 17 | # Worker and worker service implementation |
| 18 | |
| 19 | this_dir = File.expand_path(File.dirname(__FILE__)) |
| 20 | lib_dir = File.join(File.dirname(this_dir), 'lib') |
| 21 | $LOAD_PATH.unshift(lib_dir) unless $LOAD_PATH.include?(lib_dir) |
| 22 | $LOAD_PATH.unshift(this_dir) unless $LOAD_PATH.include?(this_dir) |
| 23 | |
| 24 | require 'grpc' |
| 25 | require 'optparse' |
| 26 | require 'histogram' |
| 27 | require 'etc' |
| 28 | require 'facter' |
vjpai | 75291c9 | 2016-03-21 14:59:26 | [diff] [blame] | 29 | require 'client' |
| 30 | require 'qps-common' |
| 31 | require 'server' |
kpayson64 | 7a20c96 | 2018-04-18 22:19:55 | [diff] [blame] | 32 | require 'src/proto/grpc/testing/worker_service_services_pb' |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 33 | |
| 34 | class WorkerServiceImpl < Grpc::Testing::WorkerService::Service |
vjpai | 75291c9 | 2016-03-21 14:59:26 | [diff] [blame] | 35 | def cpu_cores |
| 36 | Facter.value('processors')['count'] |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 37 | end |
vjpai | 75291c9 | 2016-03-21 14:59:26 | [diff] [blame] | 38 | def run_server(reqs) |
| 39 | q = EnumeratorQueue.new(self) |
| 40 | Thread.new { |
vjpai | e8ff388 | 2016-03-30 01:31:34 | [diff] [blame] | 41 | bms = '' |
vjpai | ed25a33 | 2016-03-30 19:16:25 | [diff] [blame] | 42 | gtss = Grpc::Testing::ServerStatus |
Jan Tattermusch | 3849335 | 2016-04-19 01:07:49 | [diff] [blame] | 43 | reqs.each do |req| |
vjpai | 45be26e | 2016-03-30 00:21:28 | [diff] [blame] | 44 | case req.argtype.to_s |
| 45 | when 'setup' |
vjpai | e8ff388 | 2016-03-30 01:31:34 | [diff] [blame] | 46 | bms = BenchmarkServer.new(req.setup, @server_port) |
vjpai | ed25a33 | 2016-03-30 19:16:25 | [diff] [blame] | 47 | q.push(gtss.new(stats: bms.mark(false), port: bms.get_port)) |
Jan Tattermusch | 3849335 | 2016-04-19 01:07:49 | [diff] [blame] | 48 | when 'mark' |
vjpai | ed25a33 | 2016-03-30 19:16:25 | [diff] [blame] | 49 | q.push(gtss.new(stats: bms.mark(req.mark.reset), cores: cpu_cores)) |
vjpai | 75291c9 | 2016-03-21 14:59:26 | [diff] [blame] | 50 | end |
| 51 | end |
vjpai | e8ff388 | 2016-03-30 01:31:34 | [diff] [blame] | 52 | bms.stop |
Alexander Polcyn | 847f9ec | 2016-08-16 01:44:14 | [diff] [blame] | 53 | q.push(self) |
vjpai | 75291c9 | 2016-03-21 14:59:26 | [diff] [blame] | 54 | } |
| 55 | q.each_item |
| 56 | end |
| 57 | def run_client(reqs) |
| 58 | q = EnumeratorQueue.new(self) |
| 59 | Thread.new { |
vjpai | d7f43b3 | 2016-03-30 01:38:10 | [diff] [blame] | 60 | client = '' |
vjpai | 75291c9 | 2016-03-21 14:59:26 | [diff] [blame] | 61 | reqs.each do |req| |
vjpai | ad1c1cc | 2016-03-30 16:58:46 | [diff] [blame] | 62 | case req.argtype.to_s |
vjpai | 45be26e | 2016-03-30 00:21:28 | [diff] [blame] | 63 | when 'setup' |
| 64 | client = BenchmarkClient.new(req.setup) |
vjpai | 75291c9 | 2016-03-21 14:59:26 | [diff] [blame] | 65 | q.push(Grpc::Testing::ClientStatus.new(stats: client.mark(false))) |
vjpai | 45be26e | 2016-03-30 00:21:28 | [diff] [blame] | 66 | when 'mark' |
vjpai | ed25a33 | 2016-03-30 19:16:25 | [diff] [blame] | 67 | q.push(Grpc::Testing::ClientStatus.new(stats: |
| 68 | client.mark(req.mark.reset))) |
vjpai | 75291c9 | 2016-03-21 14:59:26 | [diff] [blame] | 69 | end |
| 70 | end |
vjpai | ad1c1cc | 2016-03-30 16:58:46 | [diff] [blame] | 71 | client.shutdown |
Alexander Polcyn | 847f9ec | 2016-08-16 01:44:14 | [diff] [blame] | 72 | q.push(self) |
vjpai | 75291c9 | 2016-03-21 14:59:26 | [diff] [blame] | 73 | } |
| 74 | q.each_item |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 75 | end |
| 76 | def core_count(_args, _call) |
vjpai | 75291c9 | 2016-03-21 14:59:26 | [diff] [blame] | 77 | Grpc::Testing::CoreResponse.new(cores: cpu_cores) |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 78 | end |
| 79 | def quit_worker(_args, _call) |
Alex Polcyn | 81e9581 | 2017-09-24 01:48:02 | [diff] [blame] | 80 | @shutdown_thread = Thread.new { |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 81 | @server.stop |
| 82 | } |
| 83 | Grpc::Testing::Void.new |
| 84 | end |
vjpai | 45be26e | 2016-03-30 00:21:28 | [diff] [blame] | 85 | def initialize(s, sp) |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 86 | @server = s |
vjpai | 45be26e | 2016-03-30 00:21:28 | [diff] [blame] | 87 | @server_port = sp |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 88 | end |
Alex Polcyn | 81e9581 | 2017-09-24 01:48:02 | [diff] [blame] | 89 | def join_shutdown_thread |
| 90 | @shutdown_thread.join |
| 91 | end |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 92 | end |
| 93 | |
| 94 | def main |
| 95 | options = { |
vjpai | 45be26e | 2016-03-30 00:21:28 | [diff] [blame] | 96 | 'driver_port' => 0, |
| 97 | 'server_port' => 0 |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 98 | } |
| 99 | OptionParser.new do |opts| |
vjpai | 45be26e | 2016-03-30 00:21:28 | [diff] [blame] | 100 | opts.banner = 'Usage: [--driver_port <port>] [--server_port <port>]' |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 101 | opts.on('--driver_port PORT', '<port>') do |v| |
| 102 | options['driver_port'] = v |
| 103 | end |
vjpai | 45be26e | 2016-03-30 00:21:28 | [diff] [blame] | 104 | opts.on('--server_port PORT', '<port>') do |v| |
| 105 | options['server_port'] = v |
| 106 | end |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 107 | end.parse! |
Alexander Polcyn | 847f9ec | 2016-08-16 01:44:14 | [diff] [blame] | 108 | |
| 109 | # Configure any errors with client or server child threads to surface |
| 110 | Thread.abort_on_exception = true |
| 111 | |
Alex Polcyn | 81e9581 | 2017-09-24 01:48:02 | [diff] [blame] | 112 | s = GRPC::RpcServer.new(poll_period: 3) |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 113 | s.add_http2_port("0.0.0.0:" + options['driver_port'].to_s, |
| 114 | :this_port_is_insecure) |
Alex Polcyn | 81e9581 | 2017-09-24 01:48:02 | [diff] [blame] | 115 | worker_service = WorkerServiceImpl.new(s, options['server_port'].to_i) |
| 116 | s.handle(worker_service) |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 117 | s.run |
Alex Polcyn | 81e9581 | 2017-09-24 01:48:02 | [diff] [blame] | 118 | worker_service.join_shutdown_thread |
vjpai | fdeacd9 | 2016-03-17 21:52:20 | [diff] [blame] | 119 | end |
| 120 | |
| 121 | main |