Yang Gao 84a74f8966 Merge pull request #5327 from yang-g/v1alpha_to_v1 10 ani în urmă
..
bin 7fe43260ac Merge pull request #4412 from murgatroid99/ruby_auth_metadata_plugin 10 ani în urmă
ext 1280fdb574 Merge branch 'master' into backport-merge 10 ani în urmă
lib 88966ab145 Merge pull request #5348 from nicolasnoble/backport-merge 10 ani în urmă
pb f4fc61cf68 fix ruby impl and test 10 ani în urmă
spec f4fc61cf68 fix ruby impl and test 10 ani în urmă
.gitignore 097ef9b7d9 Incorporating ruby into the master grpc repository. 11 ani în urmă
.rubocop.yml aea13f1c85 global replace health check proto v1alpha to v1 10 ani în urmă
.rubocop_todo.yml aa57bab3ca Corrects the cancel_after_first_response behaviour 10 ani în urmă
CHANGELOG.md 51a4c0846b Corrects the Changelog date 10 ani în urmă
README.md d8521e75c8 Update Ruby README with simpler install instructions 10 ani în urmă

README.md

Gem

gRPC Ruby

A Ruby implementation of gRPC.

Status

Beta

PREREQUISITES

  • Ruby 2.x. The gRPC API uses keyword args.

INSTALLATION

Linux and Mac OS X:

gem install grpc

BUILD FROM SOURCE

  • Clone this repository

  • 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=ruby-2
    $
    $ # 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, build and 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
    

DOCUMENTATION

  • rubydoc for the gRPC gem is available online at rubydoc.
  • the gRPC Ruby reference documentation is available online at grpc.io

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 unittests
  • 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)
    GRPC.logger.info("div(7/3): req=#{req.inspect}")
    resp = stub.div(req)
    GRPC.logger.info("Answer: #{resp.inspect}")