gpt4 book ai didi

ssl - 远程实例上的 Python 安全通道 gRPC 'ssl_transport_security.cc:1807] No match found for server name'

转载 作者:行者123 更新时间:2023-12-03 20:48:20 28 4
gpt4 key购买 nike

我有一个 Debian GCP 实例,我正在尝试运行 Python gRPC 服务器。我的实例有一个静态 IP,我正在尝试在我的远程实例(服务器)和本地客户端之间建立一个安全通道。
我在服务器上生成了自签名 OpenSSL 证书,并且在客户端上使用了相同的证书。要生成我用过的:

openssl req -newkey rsa:2048 -nodes -keyout ML.key -x509 -days 365 -out ML.crt
我的服务器是这样设置的( .key 和 .crt 文件加载了 open 作为 'rb' ):
server_credentials = grpc.ssl_server_credentials(((private_key, certificate_chain,),))
self.server.add_secure_port('0.0.0.0:%d' % self.port, server_credentials)
self.server.start()
我的客户设置为:
    host = '78.673.121.16' #this is the instance's static IP
port = 9063

certificate_chain = __load_ssl_certificate() #this loads the certificate file

# create credentials
credentials = grpc.ssl_channel_credentials(root_certificates=certificate_chain)

# create channel using ssl credentials
channel = grpc.secure_channel('{}:{}'.format(host, port), credentials)
然后我继续提出请求。
在服务器上,响应我的请求,我遇到了以下错误:
E1017 17:21:22.964227087    1881 ssl_transport_security.cc:1807] No match found for server name: 78.673.121.16.
我已尝试将证书的通用名称 (CN) 更改为 localhost , 0.0.0.078.673.121.16但无济于事。
有什么建议吗?

最佳答案

我刚刚遇到了类似的问题,最后终于解决了。就我而言,我将服务器托管在具有静态 ip 和端口的 kubernetes 集群中。该解决方案的关键组件是(在服务器证书中):

  • 使用静态 IP 地址作为公用名
  • 在证书的 SubjectAlternativeName 扩展中添加静态 IP 地址作为 DNSName

  • 事实证明,第 2 步至关重要。在 python(使用 grpc 版本 1.34.0)中,这是通过以下方式完成的:
    from cryptography import x509
    host = '78.673.121.16'
    builder = x509.CertificateBuilder()
    ...
    builder = builder.add_extension(x509.SubjectAlternativeName([x509.DNSName(host)]), critical=False)

    关于ssl - 远程实例上的 Python 安全通道 gRPC 'ssl_transport_security.cc:1807] No match found for server name',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64405428/

    28 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com