Misha Brukman 5cdf37eb7b Removed execute permissions from README files. 11 lat temu
..
bin 5cdf37eb7b Removed execute permissions from README files. 11 lat temu
ext 6a4c4fabf3 Added ruby tests to run_tests.py 11 lat temu
lib 46566b8c95 Fix typos 'proivde' -> 'provide' and 'e,g.' -> 'e.g.' 11 lat temu
spec 5cdf37eb7b Removed execute permissions from README files. 11 lat temu
.gitignore 097ef9b7d9 Incorporating ruby into the master grpc repository. 11 lat temu
.rspec 097ef9b7d9 Incorporating ruby into the master grpc repository. 11 lat temu
.rubocop.yml e2860c5bdb Adds rubocop and fixes most style violations it detected 11 lat temu
.rubocop_todo.yml e2860c5bdb Adds rubocop and fixes most style violations it detected 11 lat temu
Gemfile 0f0a6bc4f0 Switches to using protobuf-ruby. 11 lat temu
README.md 5cdf37eb7b Removed execute permissions from README files. 11 lat temu
Rakefile 36066537cf Fix lint errors, other cleanups 11 lat temu
grpc.gemspec c4a4288f83 Update grpc.gemspec 11 lat temu

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}")