Tim Emiola af74e4e47d Updates gRPC Ruby to 0.9.0 10 vuotta sitten
..
bin f233d968d2 Encapsulate logger within GRPC module 10 vuotta sitten
ext 47b7bd99e6 Update ruby add_http2_port comments to use port 50051 10 vuotta sitten
lib af74e4e47d Updates gRPC Ruby to 0.9.0 10 vuotta sitten
spec 4aba356630 Various tweaks to improve server stability 10 vuotta sitten
.gitignore 097ef9b7d9 Incorporating ruby into the master grpc repository. 11 vuotta sitten
.rspec c85c1ae463 Add SimpleCov coverage set up for gRPC ruby 10 vuotta sitten
.rubocop.yml e2860c5bdb Adds rubocop and fixes most style violations it detected 11 vuotta sitten
.rubocop_todo.yml 4aba356630 Various tweaks to improve server stability 10 vuotta sitten
CHANGELOG.md 51a4c0846b Corrects the Changelog date 10 vuotta sitten
Gemfile 0f0a6bc4f0 Switches to using protobuf-ruby. 11 vuotta sitten
README.md 5cdf37eb7b Removed execute permissions from README files. 11 vuotta sitten
Rakefile c85c1ae463 Add SimpleCov coverage set up for gRPC ruby 10 vuotta sitten
grpc.gemspec f2fb07dafc Pin the version of rubocop used in grpc.gemspec 10 vuotta sitten

README.md

gRPC Ruby

A Ruby implementation of gRPC.

Status

Alpha : Ready for early adopters

INSTALLATION PREREQUISITES

This requires Ruby 2.1, as the RPC API surface uses keyword args.

QUICK - INSTALL

  • Clone this repository.
  • Follow the instructions in INSTALL to install the gRPC C core.
  • If you don't have Ruby 2.1 installed, switch to the more detailed instructions below
  • Use bundler to install

    $ # from this directory
    $ gem install bundler && bundle install
    

Installing from source

  • Build the gRPC C core E.g, from the root of the gRPC git repo

    $ cd ../..
    $ make && sudo make install
    
  • Install Ruby 2.1. 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=ruby-2.1
    $
    $ # follow the instructions to ensure that your're using the latest stable version of Ruby
    $ # and that the rvm command is installed
    
  • Make sure your run source $HOME/.rvm/scripts/rvm as instructed to complete the set up of RVM

  • Install bundler

    $ gem install bundler
    
  • Finally, install the gRPC gem locally.

    $ # from this directory
    $ bundle install  # creates the ruby bundle, including building the grpc extension
    $ rake  # 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)
    logger.info("Answer: #{resp.inspect}")