tree: be307d30c7572e3d8a3299b751bcacd4eed18f56 [path history] [tgz]
  1. lib/
  2. route_guide/
  3. .gitignore
  4. Gemfile
  5. greeter_client.rb
  6. greeter_server.rb
  7. grpc-demo.gemspec
  8. README.md
ruby/README.md

gRPC in 3 minutes (Ruby)

BACKGROUND

For this sample, we've already generated the server and client stubs from helloworld.proto.

PREREQUISITES

This requires Ruby 2.1, as the gRPC API surface uses keyword args. If you don't have that installed locally, you can use RVM to use Ruby 2.1 for testing without upgrading the version of Ruby on your whole system. RVM is also useful if you don't have the necessary privileges to update your system's Ruby.

$ # RVM installation as specified at https://rvm.io/rvm/install
$ gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3
$ \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
  • N.B Make sure your run source $HOME/.rvm/scripts/rvm as instructed to complete the set-up of RVM.

INSTALL

  • Clone this repository.
  • Follow the instructions in INSTALL to install the gRPC C core.
  • Temporary
    • Install the full gRPC distribution from source on your local machine
    • Build gRPC Ruby as described in installing from source
    • update path: in Gemfile to refer to src/ruby within the gRPC directory
    • N.B: these steps are necessary until the gRPC ruby gem is published
  • Use bundler to install
$ # from this directory
$ gem install bundler && bundle install

Try it!

  • Run the server
$ # from this directory
$ bundle exec ./greeter_server.rb &
  • Run the client
$ # from this directory
$ bundle exec ./greeter_client.rb

Tutorial

You can find a more detailed tutorial in gRPC Basics: Ruby