Mengatasi pengepala hos http klien gRPC dalam golang

王林
Lepaskan: 2024-02-09 08:18:18
ke hadapan
1295 orang telah melayarinya

Mengatasi pengepala hos http klien gRPC dalam golang

Ia adalah keperluan biasa untuk mengatasi pengepala hos http klien gRPC di golang. gRPC ialah rangka kerja panggilan prosedur jauh merentas bahasa berprestasi tinggi Apabila menggunakan gRPC untuk berkomunikasi, kadangkala perlu menyesuaikan pengepala hos permintaan http. Editor PHP Xigua akan memperkenalkan anda cara melaksanakan fungsi ini dalam golang untuk memenuhi keperluan perniagaan anda dengan lebih baik.

Kandungan soalan

Saya menghantar permintaan melalui sambungan melalui klien gRPC

conn, err := grpc.Dial("hostname:port",opts...)
Salin selepas log masuk

Dari sisi pelayan, saya nampak host是确切的hostname:port dalam http.request. Kemudian, tetapan pelayan nginx saya adalah seperti berikut

server {
    listen port http2;
    server_name hostname;
    # ...
}
server {
    listen port http2;
    server_name another_hostname;
    # ...
}
Salin selepas log masuk

Ini adalah teknologi pengehosan web biasa. Tidak kira nama hos yang saya gunakan dalam grpc.Dial(xxx:port) ia berfungsi dengan baik. Namun, apabila saya meletakkan

md := metadata.New(map[string]string{"host":"another_hostname:port"})
Salin selepas log masuk

Dalam konteks grpc (akan diisi dalam pengepala permintaan http2). Permintaan ini akan disekat oleh nginx dan saya mendapat

rpc error: code = Internal desc = unexpected HTTP status code received from server: 400 (Bad Request); transport: received unexpected content-type "text/html"
Salin selepas log masuk

Sebab mengapa anda perlu memasukkan nama hos secara manual adalah kerana grpc.Dial中的主机名是固定的。而且我不能使用不同的位置来做反向代理,因为portdiikuti dengan laluan penghalaan api yang tenang.

Jika nama hos ditetapkan dan laluan juga ditetapkan, adakah terdapat cara lain untuk membalikkan proksi?

(23/09) Kemas Kini: Ternyata pengepala hos dalam http2 telah digantikan dengan pengepala pseudo :Authority. :Authority伪头取代了。

解决方法

gRPC 使用 HTTP/2,不使用 :host 标头,而是使用 :authorityPenyelesaian

gRPC menggunakan HTTP/2 dan tidak menggunakan pengepala :host, tetapi pengepala pseudo :authority. Nilai pengepala ini ditentukan di sini:

https://github .com/grpc/grpc-go/blob/aa6ce35c792863305e0f42acc27f2c7153275f89/clientconn.go#L1942

:authority 标头的值是用户拨号目标的端点部分,其格式为 url://authority/endpointTL;PhD

Secara lalai, digunakan untuk authority。请参阅:https://pkg.go.dev/google.golang.org/ grpc#WithAuthority。但还要注意,此拨号选项会覆盖 TLS 握手期间使用的 ServerName.

gRPC-Go juga menyokong pilihan dailup untuk mengatasi kuasa ini. Lihat: https://pkg.go.dev/google.golang.org/ grpc#WithAuthority

. Tetapi juga ambil perhatian bahawa pilihan pendailan ini mengatasi nilai ServerName yang digunakan semasa jabat tangan TLS. 🎜 🎜Jika anda mempunyai lebih banyak soalan/kebimbangan, sila hubungi kami melalui repositori GitHub kami. Pertanyaan anda akan mendapat masa respons yang lebih baik di sana. 🎜

Atas ialah kandungan terperinci Mengatasi pengepala hos http klien gRPC dalam golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:stackoverflow.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan