Tim Emiola 26e2e8f0b5 Merge pull request #540 from ctiller/copyright 11 years ago
..
bin ce5021b0b9 Add missing new-lines at end of file 11 years ago
ext 26e2e8f0b5 Merge pull request #540 from ctiller/copyright 11 years ago
lib 26e2e8f0b5 Merge pull request #540 from ctiller/copyright 11 years ago
spec 26e2e8f0b5 Merge pull request #540 from ctiller/copyright 11 years ago
.gitignore 097ef9b7d9 Incorporating ruby into the master grpc repository. 11 years ago
.rspec 097ef9b7d9 Incorporating ruby into the master grpc repository. 11 years ago
.rubocop.yml e2860c5bdb Adds rubocop and fixes most style violations it detected 11 years ago
.rubocop_todo.yml e2860c5bdb Adds rubocop and fixes most style violations it detected 11 years ago
Gemfile 0f0a6bc4f0 Switches to using protobuf-ruby. 11 years ago
README.md 0343f7f3a6 Fixes markdown sytax errors 11 years ago
Rakefile 36066537cf Fix lint errors, other cleanups 11 years ago
grpc.gemspec 43374163ec Corrects a typo 11 years ago

README.md

gRPC Ruby

A Ruby implementation of gRPC, Google's RPC library.

INSTALLATION PREREQUISITES

This requires Ruby 2.x, as the rpc api surface uses keyword args.

INSTALLING

  • Install the gRPC core library TODO: describe this, once the core distribution mechanism is defined.

    $ gem install grpc
    

Installing from source

  • Build or Install the gRPC core E.g, from the root of the grpc git repo

    $ cd ../..
    $ make && sudo make install
    
  • Install Ruby 2.x. Consider doing this with RVM, it's a nice way of controlling the exact ruby version that's used.

    $ command curl -sSL https://rvm.io/mpapis.asc | gpg --import -
    $ \curl -sSL https://get.rvm.io | bash -s stable --ruby
    $
    $ # follow the instructions to ensure that your're using the latest stable version of Ruby
    $ # and that the rvm command is installed
    
  • Install bundler

    $ gem install bundler
    
  • Finally, install grpc ruby locally.

    $ cd <install_dir>
    $ bundle install
    $ rake  # compiles the extension, runs the unit tests, see rake -T for other options
    

CONTENTS

Directory structure is the layout for ruby extensions

  • ext: the gRPC ruby extension
  • lib: the entrypoint grpc ruby library to be used in a 'require' statement
  • spec: Rspec unittest
  • bin: example gRPC clients and servers, e.g,

    stub = Math::Math::Stub.new('my.test.math.server.com:8080')
    req = Math::DivArgs.new(dividend: 7, divisor: 3)
    logger.info("div(7/3): req=#{req.inspect}")
    resp = stub.div(req, INFINITE_FUTURE)
    logger.info("Answer: #{resp.inspect}")