私はSSL/TLSについて何も知らず、gRPCでSSL/TLSチャネルを使用しようとしています。ここで は、サーバーのコードです:gRPCクライアントサーバ通信でSSLを使用
std::string server_address("0.0.0.0:50051");
GreeterServiceImpl service;
grpc::SslServerCredentialsOptions::PemKeyCertPair pkcp ={"a","b"};
grpc::SslServerCredentialsOptions ssl_opts;
ssl_opts.pem_root_certs="";
ssl_opts.pem_key_cert_pairs.push_back(pkcp);
std::shared_ptr<grpc::ServerCredentials> creds;
creds = grpc::SslServerCredentials(ssl_opts);
ServerBuilder builder;
builder.AddListeningPort(server_address, creds);
builder.RegisterService(&service);
std::unique_ptr<Server> server(builder.BuildAndStart());
サーバが起動すると、次のエラーで終了しません。
E1115 13:00:55.657846941 17129 ssl_transport_security.c:636] Invalid cert chain file.
E1115 13:00:55.657936436 17129 security_connector.c:830] Handshaker factory creation failed with TSI_INVALID_ARGUMENT.
E1115 13:00:55.657954952 17129 server_secure_chttp2.c:344] {"created":"@1479243655.657946821","description":"Unable to create secure server with credentials of type Ssl.","file":"src/core/ext/transport/chttp2/server/secure/server_secure_chttp2.c","file_line":242,"security_status":1}
Server listening on 0.0.0.0:50051
Segmentation fault (core dumped)
私がやりたいことは、サーバーとクライアントの通信にSSLを使用することだけです。サーバーに適切な証明書がないと思われ、同様のことがクライアントに必要と思われるように見えます。私はSSLの背景を持っていないので誰も私がどのようにそれらの証明書を作成し、gRPC通信のために適切に使用するかについての例を教えてくれるといいでしょう。