Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 1 | These instructions only cover building grpc C and C++ libraries under |
| 2 | typical unix systems. If you need more information, please try grpc's |
| 3 | wiki pages: |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 4 | |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 5 | https://github.com/google/grpc/wiki |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 6 | |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 7 | |
| 8 | ************************* |
| 9 | * If you are in a hurry * |
| 10 | ************************* |
| 11 | |
| 12 | A typical unix installation won't require any more steps than running: |
| 13 | |
| 14 | $ make |
| 15 | # make install |
| 16 | |
Nicolas Noble | c70752a | 2015-02-12 17:01:52 -0800 | [diff] [blame^] | 17 | You don't need anything else than GNU Make, gcc and autotools. Under a Debian |
| 18 | or Ubuntu system, this should boil down to the following packages: |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 19 | |
Nicolas Noble | c70752a | 2015-02-12 17:01:52 -0800 | [diff] [blame^] | 20 | # apt-get install build-essential autoconf libtool |
| 21 | |
| 22 | Building the python wrapper requires the following: |
| 23 | |
| 24 | # apt-get install python-all-dev python-virtualenv |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 25 | |
| 26 | |
| 27 | ******************************* |
| 28 | * More detailled instructions * |
| 29 | ******************************* |
| 30 | |
| 31 | Setting up dependencies |
| 32 | ======================= |
| 33 | |
| 34 | Dependencies to compile the libraries |
| 35 | ------------------------------------- |
| 36 | |
| 37 | grpc libraries have few external dependencies. If you need to compile and |
| 38 | install them, they are present in the third_party directory if you have |
| 39 | cloned the github repository recursively. If you didn't clone recursively, |
| 40 | you can still get them later by running the following command: |
| 41 | |
| 42 | $ git submodule update --init |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 43 | |
nnoble | 69ac39f | 2014-12-12 15:43:38 -0800 | [diff] [blame] | 44 | Note that the Makefile makes it much easier for you to compile from sources |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 45 | if you were to clone recursively our git repository: it will automatically |
| 46 | compile zlib and OpenSSL, which are core requirements for grpc. Note this |
| 47 | creates grpc libraries that will have zlib and OpenSSL built-in inside of them, |
| 48 | which significantly increases the libraries' size. |
| 49 | |
| 50 | In order to decrease that size, you can manually install zlib and OpenSSL on |
| 51 | your system, so that the Makefile can use them instead. |
| 52 | |
| 53 | Under a Debian or Ubuntu system, one can acquire the development package |
| 54 | for zlib this way: |
| 55 | |
| 56 | # apt-get install zlib1g-dev |
| 57 | |
| 58 | To the best of our knowledge, no distribution has an OpenSSL package that |
| 59 | supports ALPN yet, so you would still have to depend on installing from source |
| 60 | for that particular dependency if you want to reduce the libraries' size. |
| 61 | |
| 62 | The recommended version of OpenSSL that provides ALPN support is available |
| 63 | at this URL: |
| 64 | |
Nicolas "Pixel" Noble | d566021 | 2015-01-23 20:35:49 +0100 | [diff] [blame] | 65 | https://www.openssl.org/source/openssl-1.0.2.tar.gz |
nnoble | 69ac39f | 2014-12-12 15:43:38 -0800 | [diff] [blame] | 66 | |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 67 | |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 68 | Dependencies to compile and run the tests |
| 69 | ----------------------------------------- |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 70 | |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 71 | Compiling and running grpc plain-C tests dont't require any more dependency. |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 72 | |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 73 | |
| 74 | Compiling and running grpc C++ tests depend on protobuf 3.0.0, gtest and |
Nicolas Noble | c70752a | 2015-02-12 17:01:52 -0800 | [diff] [blame^] | 75 | gflags. Although gflags is provided in third_party, you will need to manually |
| 76 | install that dependency on your system to run these tests. |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 77 | |
| 78 | Under a Debian or Ubuntu system, you can install the gtests and gflags packages |
| 79 | using apt-get: |
| 80 | |
| 81 | # apt-get install libgflags-dev libgtest-dev |
| 82 | |
Nicolas Noble | c70752a | 2015-02-12 17:01:52 -0800 | [diff] [blame^] | 83 | However, protobuf 3.0.0 isn't in a debian package yet, but the Makefile will |
| 84 | automatically try and compile the one present in third_party if you cloned the |
| 85 | repository recursively, and that it detects your system is lacking it. |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 86 | |
| 87 | Compiling and installing protobuf 3.0.0 requires a few more dependencies in |
Nicolas Noble | c70752a | 2015-02-12 17:01:52 -0800 | [diff] [blame^] | 88 | itself, notably the autoconf suite. If you have apt-get, you can install |
| 89 | these dependencies this way: |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 90 | |
Nicolas Noble | c70752a | 2015-02-12 17:01:52 -0800 | [diff] [blame^] | 91 | # apt-get install autoconf libtool |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 92 | |
| 93 | |
| 94 | A word on OpenSSL |
| 95 | ----------------- |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 96 | |
Abhishek Kumar | 3dd9df9 | 2015-02-10 10:16:41 -0800 | [diff] [blame] | 97 | Secure HTTP2 requires the TLS extension ALPN (see rfc 7301 and |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 98 | http://http2.github.io/http2-spec/ section 3.3). Our HTTP2 implementation |
Nicolas "Pixel" Noble | d566021 | 2015-01-23 20:35:49 +0100 | [diff] [blame] | 99 | relies on OpenSSL's implementation. OpenSSL 1.0.2 is the first released version |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 100 | of OpenSSL that has ALPN support, and this explains our dependency on it. |
| 101 | |
nnoble | 69ac39f | 2014-12-12 15:43:38 -0800 | [diff] [blame] | 102 | Note that the Makefile supports compiling only the unsecure elements of grpc, |
| 103 | and if you do not have OpenSSL and do not want it, you can still proceed |
Abhishek Kumar | 6749e73 | 2015-02-10 10:59:52 -0800 | [diff] [blame] | 104 | with installing only the elements you require. However, we strongly recommend |
Abhishek Kumar | 3dd9df9 | 2015-02-10 10:16:41 -0800 | [diff] [blame] | 105 | the use of encryption for all network traffic, and discourage the use of grpc |
| 106 | without TLS. |
nnoble | 69ac39f | 2014-12-12 15:43:38 -0800 | [diff] [blame] | 107 | |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 108 | |
| 109 | Compiling |
| 110 | ========= |
| 111 | |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 112 | If you have all the dependencies mentioned above, you should simply be able |
| 113 | to go ahead and run "make" to compile grpc's C and C++ libraries: |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 114 | |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 115 | $ make |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 116 | |
| 117 | |
| 118 | Testing |
| 119 | ======= |
| 120 | |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 121 | To build and run the tests, you can run the command: |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 122 | |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 123 | $ make test |
| 124 | |
| 125 | If you want to be able to run them in parallel, and get better output, you can |
| 126 | also use the python tool we have written: |
| 127 | |
| 128 | $ ./tools/run_tests/run_tests.py |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 129 | |
| 130 | |
| 131 | Installing |
| 132 | ========== |
| 133 | |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 134 | Once everything is compiled, you should be able to install grpc C and C++ |
nnoble | 0005b77 | 2014-12-10 16:25:34 -0800 | [diff] [blame] | 135 | libraries and headers: |
| 136 | |
Nicolas Noble | 6ae8ef1 | 2015-01-16 15:03:42 -0800 | [diff] [blame] | 137 | # make install |