Tim Emiola 8af5175e1f Clarified the reasons for using RVM 11 vuotta sitten
..
lib 600d70cd8d change proto README cpp node ruby 11 vuotta sitten
.gitignore 49f3ccdd01 Adds a helloworld sample in ruby. 11 vuotta sitten
Gemfile ccf41aad86 Update Gemfile 11 vuotta sitten
README.md 8af5175e1f Clarified the reasons for using RVM 11 vuotta sitten
greeter.gemspec 7b68400fa4 Fixes the gem name. 11 vuotta sitten
greeter_client.rb 49f3ccdd01 Adds a helloworld sample in ruby. 11 vuotta sitten
greeter_server.rb 600d70cd8d change proto README cpp node ruby 11 vuotta sitten

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