XHTTP: Beyond REALITY #4113
Replies: 54 comments 182 replies
-
先顶再看,不明觉厉 |
Beta Was this translation helpful? Give feedback.
-
中文 | РусскийXHTTP: За гранью REALITYКраткое описание разработки: В середине 2024 года, @mmmray @ll11l1lIllIl1lll и другие, основываясь на принципе "раздельная пакетная отправка, потоковая загрузка" и деталях реализации, описанных @RPRX, разработали SplitHTTP, впервые добившись обхода большинства промежуточных устройств, поддерживающих HTTP, без ущерба для эффективности загрузки, и впервые массово реализовали QUIC H3 через CDN, открыв новую эру. Впоследствии были реализованы: Broswer Dialer, добавление отступов в заголовки для уменьшения сигнатуры (header padding), управление мультиплексированием (XMUX) и разблокировка REALITY. Затем разработку взял на себя @RPRX, реализовав настоящее разделение исходящего и входящего трафика и переименовав проект в XHTTP. Например, исходящий и входящий трафик могут быть IPv6 CDN H3 и IPv4 REALITY H2 соответственно (даже исходные IP-адреса могут различаться), Эта статья призвана помочь вам полностью понять принцип и дизайн XHTTP, чтобы вы могли лучше его использовать. Если вы хотите пожертвовать проекту Xray или собираете NFT, соответствующая информация находится в конце статьи, спасибо за поддержку!Руководство по быстрому стартуНесмотря на большое количество параметров у XHTTP, для них уже настроены значения по умолчанию. Если вы просто хотите использовать XHTTP, достаточно выполнить шесть шагов:
XHTTP по умолчанию использует мультиплексирование, что обеспечивает меньшую задержку по сравнению с Vision, но многопоточное тестирование скорости может показать худшие результаты, если не установить Кроме того, в клиентах v2rayNG есть глобальная настройка mux.cool, которую следует отключить перед использованием XHTTP, иначе не удастся подключиться к серверу Xray новой версии. Эту статью можно использовать как расширенную версию документации, поскольку она охватывает практически всё, что вы хотели бы знать о XHTTP, с объяснением каждого параметра. В конце статьи также приведен пример конфигурации, включающий все параметры с описанием сценариев их использования. Если вам неясен какой-либо параметр, найдите его название в тексте, чтобы найти подробное объяснение. Два базовых принципаТак же, как REALITY может маскироваться под чужой веб-сайт, основная идея противодействия цензуре заключается в увеличении "сопутствующего ущерба" для цензоров при блокировке, что делает их менее склонными к необдуманным действиям. По той же причине я в свое время сделал ставку на TLS и запутывание временных и длиновых характеристик трафика TLS. Многолетний опыт показывает, что GFW не будет постоянно блокировать весь пул IP-адресов крупного CDN, так как это затронет слишком много обычных сайтов. Таким образом, наша первоначальная цель для XHTTP заключалась в том, чтобы скрыть его за множеством различных CDN. Однако, чтобы предотвратить атаки на исходный сервер, CDN, за исключением специально поддерживаемых WS и gRPC, обычно кэшируют весь HTTP-запрос, прежде чем отправить его на исходный сервер. Многие промежуточные HTTP-устройства по умолчанию также работают таким образом. Исходя из этого, протокол Meek от Tor упаковывает исходящий и входящий трафик в отдельные HTTP-запросы для обхода этих промежуточных устройств, но скорость при этом крайне низка, поскольку он не использует "потоковую загрузку" XHTTP. Кстати, о недавно ставшей популярной теме "злоупотребления" CDN: очевидно, что CDN, не поддерживающие потоковую отправку, не предназначены для создания прокси-сервисов. Однако в борьбе с GFW мы считаем разумным и необходимым постоянно исследовать, разрабатывать и использовать как можно больше новых путей. Это вынужденная мера, и увеличение "сопутствующего ущерба" для цензоров требует от нас смешиваться с "нормальными" сервисами, что также неизбежно. Простейший пример: если в один прекрасный день будет введен белый список IP-адресов, и IP-адрес CDN окажется в нем, будете ли вы его использовать? В области антицензуры не действуют некоторые правила реального мира, но этот простой принцип почему-то многие не могут понять. Если вы все еще не понимаете, то такие транспортные уровни, как WebSocket, сейчас существуют только для обхода CDN. Как разработчик, вы можете удалить его, а как пользователь, вы можете предложить разработчику удалить его, чтобы своими действиями доказать, что "злоупотребление CDN" - это не просто очередной предлог для атаки на Xray, вызванный завистью и удовлетворением каких-то болезненных психологических потребностей, PACKET-UPЭтот раздел содержит много технических деталей. Обычные пользователи могут читать только выделенный текст. Для режима packet-up в XHTTP, обеспечивающего наилучшую совместимость ("пакетная отправка, потоковая загрузка"), мы выбрали следующую схему:
Пакетная отправка и Кроме того, как и другие транспортные уровни Xray, сервер принимает заголовок Это упрощенный, необходимый процесс работы режима packet-up. Однако остается небольшой вопрос: как конкретно реализовать и ограничить POST-запросы? Для этого есть три специальных параметра:
"Для одного прокси-запроса" означает, что каждый прокси-запрос считается отдельно и не влияет на другие, даже если они находятся в одном H2/H3 соединении. Это и есть значение sc (sub-connection). Чтобы уменьшить сигнатуру, первые два значения можно задать в виде диапазона, например, "500000-1000000" и "10-50" соответственно, с случайным выбором значения в каждом запросе. Эти параметры можно передать клиенту через H1 / H2 / H3Теперь, когда у нас есть режим packet-up, способный обходить практически все промежуточные HTTP-устройства, давайте обсудим кое-что интересное: QUIC H3 через CDN, то есть ту самую новую эру, которую открыл SplitHTTP. Понимание этого раздела особенно важно для гибкого использования XHTTP. Особенностью многих промежуточных HTTP-устройств, таких как CDN и Nginx, является преобразование версии HTTP. Например, они могут преобразовывать полученный H3-трафик в H1 или H2 при обращении к исходному серверу. Это означает, что наш XHTTP-сервер может прослушивать только H1 и H2, без необходимости прослушивания H3, в то время как клиент XHTTP может использовать H3. Это также поведение XHTTP-сервера по умолчанию: прослушивание только TCP-порта и обработка трафика H1 и H2. При включении TLS и указании только одного элемента "h3" в Для клиента XHTTP:
Если вам нужно узнать фактически используемую версию HTTP, host, а также режим XHTTP, разделение исходящего и входящего трафика и другую информацию на стороне клиента Xray, установите уровень логирования "info". Проксирование QUIC H3 через CDN, по крайней мере, XHTTP был первым, кто реализовал это в массовом масштабе, открыв новый путь, поскольку в некоторых регионах и у некоторых провайдеров цензура H3 не так строга, XMUXПоскольку мы упомянули H2 и H3, нельзя не упомянуть и их мультиплексирование: в обоих случаях это 0-RTT. Разница лишь в том, что у H3 нет проблемы блокировки заголовка TCP, которая есть у H2, и H3 поддерживает миграцию соединения, поэтому при смене сети на клиенте соединение не разрывается.
XMUX предоставляет параметры, которые можно комбинировать различными способами. Например, перед многопоточным тестированием скорости необходимо установить Примечание: отсутствие параметров эквивалентно установке всех значений в ноль, и будут использоваться три значения по умолчанию. Однако, если указан хотя бы один параметр, остальные параметры не будут иметь значений по умолчанию и должны быть указаны явно, за исключением первых двух параметров. Все остальные параметры можно указывать одновременно. Кроме того, при использовании XHTTP не следует включать mux.cool, и новая версия сервера Xray проверяет это, принимая только чистый XUDP. Некоторые выдержки о значениях по умолчанию для XMUX:
Ниже в статье также обсуждаются некоторые параметры Nginx. STREAM-UP/ONEНаконец, мы добрались до другого важного режима XHTTP: stream-up ("потоковая отправка, потоковая загрузка"). Как следует из названия, в этом режиме отправка данных также потоковая, что не снижает ее эффективность. Изначально он был разработан для REALITY, пока мы не обнаружили, что с маскировкой заголовков gRPC под H2 можно обходить CF (необходимо включить поддержку gRPC в панели управления), и обратные прокси-серверы, такие как Nginx, также хорошо его поддерживают (для Nginx рекомендуется
Способы их реализации (обычные пользователи могут пропустить):
Тогда те, кто часто использует gRPC, спросят: какие преимущества у stream-up по сравнению с транспортным уровнем gRPC?
Конечно, преимущества XHTTP по сравнению с WebSocket и HTTPUpgrade, помимо "отсутствия явной сигнатуры ALPN как http/1.1", вы, дочитав до этого места, уже наверняка поняли сами, поэтому я не буду их перечислять, Разделение исходящего и входящего трафикаИ, наконец, кульминация - еще одна новая эра: разделение исходящего и входящего трафика. Мы знаем, что сейчас GFW обнаруживает такие характеристики трафика, как TLS in TLS, основываясь на одном соединении. Таким образом, если мы разделим исходящий и входящий трафик на разные системы проверки, например, исходящий трафик будет идти через IPv4 TCP, а входящий - через IPv6 UDP, GFW не сможет сразу среагировать. А поскольку сервер XHTTP связывает исходящий и входящий трафик только на основе случайно сгенерированного UUID в пути, packet-up и stream-up изначально обладают возможностью настоящего разделения трафика, и благодаря тому, что XHTTP может проходить через различные CDN и использоваться с REALITY, существует бесконечное количество вариантов. На клиенте необходимо настроить "xhttpSettings": {
"host": "example.com",
"path": "/yourpath", // должно совпадать
"mode": "auto",
"extra": {
"headers": {
// "key": "value"
},
"xPaddingBytes": "100-1000",
"noGRPCHeader": false, // stream-up/one, только клиент
"noSSEHeader": false, // только сервер
"scMaxEachPostBytes": 1000000, // только packet-up
"scMinPostsIntervalMs": 30, // packet-up, только клиент
"scMaxBufferedPosts": 30, // packet-up, только сервер
"xmux": { // в основном h2/h3, только клиент
"maxConcurrency": "16-32",
"maxConnections": 0,
"cMaxReuseTimes": "64-128",
"cMaxLifetimeMs": 0,
"hMaxRequestTimes": "800-900",
"hKeepAlivePeriod": 0
},
"downloadSettings": { // только клиент
"address": "", // другой домен/IP
"port": 443,
"network": "xhttp",
"security": "tls",
"tlsSettings": {
...
},
"xhttpSettings": {
"path": "/yourpath", // должно совпадать
...
},
"sockopt": {} // будет заменено на sockopt из upload, если находится в "extra"
}
}
} Как видите, Если вы используете CDN, вы можете управлять разделением трафика, даже не изменяя настройки сервера. Например, вы можете выбрать один IPv4 для TLS H2 и один IPv6 для QUIC H3. Большинство CDN поддерживают "префикс домена", например, Например, после появления разделения трафика многие используют его для разделения исходящего трафика по каналам с лучшим исходящим соединением, а входящего — по каналам с лучшим входящим соединением, что также весьма практично. Выше приведен пример конфигурации, включающий все параметры, главным образом для того, чтобы показать, где должен быть указан каждый параметр, и объяснить параметры, которые не были подробно рассмотрены ранее:
Beyond REALITYВ начале прошлого года я вернулся и написал Beyond REALITY не означает замену REALITY, а означает превзойденную популярность. Без преувеличения, как это всегда бывает с Xray, появление XHTTP затмило все остальные транспортные уровни на основе HTTP. Это эра всеобщего господства XHTTP. Он станет более популярным, чем предыдущий успешный протокол REALITY, потому что характеристики XHTTP определяют более широкий охват. Наконец, надеюсь, что появление XHTTP немного вас поразит, как это неоднократно бывало в истории Xray: инновации и постоянное обновление — это кредо Xray. Если эта статья была вам полезна, поддержите REALITY NFT:
Благодаря вашей поддержке, цена Project X NFT выросла в пять-шесть раз. Для тех, кто колебался при первоначальной продаже Project X NFT, это хороший шанс наверстать упущенное. Конечно, мы будем еще более благодарны, если вы сможете поддержать Project X NFT:
|
Beta Was this translation helpful? Give feedback.
-
It's rumored that some CDNs are acting against using their services for proxy (not at a large scale yet) As someone who don't want to get banned by CDNs, i prefer WebSocket or gRPC w/o '/Tun', but not XHTTP with static URL Pattern and xPaddingBytes query string with many 0 data |
Beta Was this translation helpful? Give feedback.
-
笔记本上:嗯嗯嗯,好好好,嗯嗯嗯,好好好,嗯嗯嗯,好好好 |
Beta Was this translation helpful? Give feedback.
-
Six,Six,Six... |
Beta Was this translation helpful? Give feedback.
-
尝试过
|
Beta Was this translation helpful? Give feedback.
-
奈何本人没文化,一句牛逼行天下🥰 |
Beta Was this translation helpful? Give feedback.
-
建议文中优化下"extra"的说明: 对于mode配置,也建议文中增加链接: 如果正文没修改,读者对extra或mode有疑问,可以读这个回复里的链接 |
Beta Was this translation helpful? Give feedback.
-
这种配置算“关闭了mux.cool(我理解是tcp的mux)纯xudp”吗?如果不是最佳实践 应该是怎样 |
Beta Was this translation helpful? Give feedback.
-
Look good to all |
Beta Was this translation helpful? Give feedback.
-
可否考虑在跑H3时,配置启用了cMaxLifetimeMs连接过期时间参数后,能把过期的主连接中的子连接迁移到新连接中,这样规避对UDP的Qos。 |
Beta Was this translation helpful? Give feedback.
-
尝试理解下我们XTLS旗下一系列协议的关注点和逻辑,如果错了请 @RPRX 指正。 XTLS初代splice/direct/origin等----解决性能: VISION----解决TLS in TLS特征: REALITY----解决SNI封锁问题: XHTTP----解决翻墙协议普遍存在的“单一隧道”特征: |
Beta Was this translation helpful? Give feedback.
-
这个想法有点意思 那么是否可以说 UDP(H3)抓不到连接头 所以理论上更安全? |
Beta Was this translation helpful? Give feedback.
-
上下行分離的部分能在xtls之類的現有協議啟用嗎?(還是說是xhttp獨有的) |
Beta Was this translation helpful? Give feedback.
-
"maxConnections:该值与 maxConcurrency 冲突,只能二选一。默认值 0,即不限制,支持填写范围,每次随机。" |
Beta Was this translation helpful? Give feedback.
-
为啥感觉xhttp 有时候连不上了 是tcp断了么 |
Beta Was this translation helpful? Give feedback.
-
报Remote host closed connection during handshake |
Beta Was this translation helpful? Give feedback.
-
does anyone know how to make h3 mode work on cloudfront cdn ? |
Beta Was this translation helpful? Give feedback.
-
Hi |
Beta Was this translation helpful? Give feedback.
-
Have you any benchmark for traffic load? How much throughput can you achieve with Cloudflare? Under the same baseline conditions, how does the speed compare to other solutions? |
Beta Was this translation helpful? Give feedback.
-
XHTTP: Beyond REALITYDevelopment Overview: Later, @RPRX took over development, achieving true upstream and downstream separation and renaming the protocol to XHTTP. This allowed upstream and downstream traffic to use entirely different configurations, such as IPv6 CDN H3 for upstream and IPv4 REALITY H2 for downstream, even with different source IPs. This innovation marked another leap forward. Subsequent developments included the stream-up mode, which improved upstream efficiency, and the extra configuration scheme, enabling users to share detailed settings. The stream-up mode was further enhanced with gRPC header camouflage, enabling H2 streaming upstream through CDNs, effectively replacing traditional gRPC transport layers. Finally, the HTTP transport layer was integrated into XHTTP as stream-one mode, inheriting features like header padding, XMUX, and gRPC header camouflage. With these advancements, XHTTP became a complete solution: capable of bypassing middleboxes in various ways, supporting upstream and downstream separation, and offering smooth multiplexing. The era of XHTTP as a universal, all-scenario proxy solution had officially begun. Quick Start GuideAlthough XHTTP offers many configuration options, its default settings are optimized for most use cases. To get started, follow these six steps:
By default, XHTTP supports multiplexing (XMUX), which reduces latency compared to Vision. However, multi-threaded speed tests may show lower performance unless you set Additionally, if you are using the v2rayN&G client, disable the global This article serves as an enhanced guide, covering everything you need to know about XHTTP. It explains each parameter in detail and includes a comprehensive configuration example at the end, with usage scenarios for each parameter. If you are unsure about a parameter, search for its name in this document to find a detailed explanation. Core PrinciplesThe fundamental logic of anti-censorship technologies like XHTTP is to increase the "collateral damage" for censors when implementing blocks. This makes them hesitant to block traffic indiscriminately. For example, REALITY disguises proxy traffic as legitimate website connections, forcing censors to risk blocking real websites if they attempt to block the proxy. Similarly, XHTTP leverages the fact that the Great Firewall (GFW) is unlikely to permanently block the entire IP range of a major CDN, as doing so would disrupt too many legitimate websites. The goal of XHTTP is to blend proxy traffic into the vast pool of normal CDN traffic. However, CDNs are designed to protect origin servers from attacks. Unless specifically configured (e.g., for WebSocket or gRPC), most CDNs cache the entire HTTP request before forwarding it to the origin server. Many HTTP middleboxes behave similarly. Protocols like Tor’s Meek wrap traffic into discrete HTTP requests to bypass these middleboxes, but this approach sacrifices speed. Meek lacks XHTTP’s "streaming downstream" capability, which ensures high downstream performance. What is "Streaming Downstream"?Imagine downloading a large file from a website. If the CDN doesn’t have the file cached, it fetches it from the origin server. Instead of waiting to cache the entire file, the CDN forwards the data to you as it receives it. This real-time forwarding is the foundation of XHTTP’s streaming downstream, ensuring maximum downstream speed. What about Upstream?For compatibility, XHTTP initially implemented "packetized upstream", which splits upstream traffic into discrete POST requests. While this approach is less efficient, upstream traffic is typically minimal for most proxy use cases. Later, streaming upstream was introduced, allowing real-time upstream data transfer. By adding gRPC header camouflage, XHTTP enabled H2 streaming upstream through Cloudflare (CF). After several optimizations, the speed of packetized upstream now rivals that of streaming upstream. PACKET-UP ModePacket-up mode is XHTTP’s most compatible configuration, combining packetized upstream with streaming downstream. Here’s how it works: Upstream (Client to Server):
Downstream (Server to Client):
Cross-Origin Compatibility:To avoid cross-origin restrictions when using Browser Dialer, the server includes the following headers in all GET and POST responses:
Header Padding:To address the fixed-length characteristics of HTTP headers:
Key Parameters for Packet-Up Mode
These parameters can be randomized to reduce traffic fingerprints. For example, H1 / H2 / H3Now that we have the packet-up mode, which can penetrate almost all HTTP middleboxes, let's discuss something interesting: QUIC H3 over CDN, the new era that SplitHTTP initially ushered in. Understanding this section is crucial for using XHTTP effectively. A characteristic of many HTTP middleboxes is that they perform HTTP version conversion. For example, CDNs and Nginx may convert incoming H3 traffic to H1 or H2 traffic when forwarding to the origin. This means our XHTTP server can listen only for H1 and H2, without needing to listen for H3, but the XHTTP client can still use H3. This is also the default behavior of the XHTTP server: it listens only on TCP ports and handles H1 and H2 traffic. When TLS is enabled and only one element, "h3", is set in For the XHTTP client:
If you want to confirm the HTTP version, host, XHTTP mode, upstream and downstream separation, and other information actually used by the Xray client, set the log level to "info". At least for large-scale implementation of proxying QUIC H3 over CDN, XHTTP is the first. It opened a new path, as some regions and operators do not strictly censor H3, although some may block it. Even though we later developed the stream-up mode and found that adding gRPC header camouflage can penetrate Cloudflare (CF), it only works for H2. It seems that the value of this new era is still rising. XMUXSince we mentioned H2 and H3, we have to talk about their multiplexing: both are 0-RTT. The difference is that H3 does not have the TCP head-of-line blocking problem of H2, and it supports connection migration, so the client will not disconnect when switching networks. Those who often read RFCs may ask: how to specifically control their multiplexing? We designed a concise and powerful interface, XMUX:
The parameters provided by XMUX can be combined in various ways. For example, set Note: If you don't fill in anything, it is equivalent to all zeros, and the three default values will be taken. But if you fill in any item, the other items will not have default values, and you need to fill them all yourself, except for the first two items, which can be filled in simultaneously. In addition, do not enable Regarding the default values of XMUX, some excerpts:
There is also a discussion of some Nginx parameters below the article. STREAM-UP/ONEFinally, we come to another important mode of XHTTP: stream-up, which is "streaming upstream, streaming downstream". As the name suggests, the upstream of this mode is also streaming, so it will not sacrifice upstream efficiency. It was originally developed for REALITY until we found that adding a gRPC header to disguise H2 can penetrate Cloudflare (CF) (gRPC support needs to be enabled in the panel), and the support of reverse proxy software such as Nginx is also good (Nginx recommends
Their implementation methods are (non-developers can skip):
Those who often use gRPC may ask: what are the advantages of stream-up over the gRPC transport layer?
Of course, the advantages of XHTTP over WebSocket and HTTPUpgrade, in addition to "no significant characteristics of ALPN being http/1.1", I believe you have read this far, and you already have the answer in your heart. I will not list them one by one, mainly because there are too many to list.Upstream and Downstream SeparationA groundbreaking advancement in XHTTP is upstream and downstream separation. The Great Firewall (GFW) typically analyzes traffic characteristics based on single connections. By splitting upstream and downstream traffic across different inspection systems, such as using IPv4 TCP for upstream and IPv6 UDP for downstream, the GFW's detection capabilities can be hindered. XHTTP natively supports true upstream and downstream separation because it associates upstream and downstream traffic based on a randomly generated UUID in the To enable upstream and downstream separation on the client-side, configure "xhttpSettings": {
"host": "example.com",
"path": "/yourpath", // must be the same
"mode": "auto",
"extra": {
"headers": {
// "key": "value"
},
"xPaddingBytes": "100-1000",
"noGRPCHeader": false, // stream-up/one, client only
"noSSEHeader": false, // server only
"scMaxEachPostBytes": 1000000, // packet-up only
"scMinPostsIntervalMs": 30, // packet-up, client only
"scMaxBufferedPosts": 30, // packet-up, server only
"xmux": { // h2/h3 mainly, client only
"maxConcurrency": "16-32",
"maxConnections": 0,
"cMaxReuseTimes": "64-128",
"cMaxLifetimeMs": 0,
"hMaxRequestTimes": "800-900",
"hKeepAlivePeriod": 0
},
"downloadSettings": { // client only
"address": "", // another domain/IP
"port": 443,
"network": "xhttp",
"security": "tls",
"tlsSettings": {
...
},
"xhttpSettings": {
"path": "/yourpath", // must be the same
...
},
"sockopt": {} // will be replaced by upload's when in "extra"
}
}
}
Except for this To counter upstream and downstream separation, the GFW would likely focus on the timing of main connection initiations. Future versions of XHTTP may allow initiating upstream and downstream connections at different times to address this. Leveraging CDNs for Upstream and Downstream SeparationYou can implement upstream and downstream separation even without modifying the server configuration if you are using a CDN. For example, you can use one optimized IPv4 for TLS H2 upstream and another optimized IPv6 for QUIC H3 downstream. CDNs generally support "same-domain domain fronting". For instance:
This makes the external SNI appear different while still using the same domain. If you have two domains, it's even better. If you don't have any domains, you can use two VPSs and two REALITY configurations for upstream and downstream separation. Whether using a CDN with a reverse proxy or REALITY with fallback, the key is to ensure that both upstream and downstream traffic reach the same XHTTP inbound on the same VPS using the same XHTTP's versatility allows for countless combinations. The only limitation is your imagination. A common use case for upstream and downstream separation is to route upstream traffic through a path with optimized outbound routing and downstream traffic through a path with optimized inbound routing. Configuration Example and ExplanationThe provided configuration example demonstrates the placement of each parameter:
Beyond REALITYREALITY, introduced last year, addressed several pain points and quickly became the primary choice for direct connections. Its stability and effectiveness have been widely recognized. While Xray has made numerous optimizations and improvements to other transports, XHTTP is the first native transport layer for Xray, and it's making a significant impact. "Beyond REALITY" does not mean replacing REALITY but rather surpassing its popularity. XHTTP's versatility and comprehensive features make it a superior choice compared to other HTTP-based transport layers. It is poised to become even more popular than REALITY due to its broader applicability. XHTTP continues Xray's tradition of innovation and transformation, bringing a powerful new tool to the anti-censorship arsenal. Support the ProjectIf you find this information helpful, consider supporting the project by purchasing a REALITY NFT:
Project X NFTs have already increased five to six times in value. This is an excellent opportunity for those who missed the initial Project X NFT offering. If you have the means, supporting the project with a Project X NFT is also greatly appreciated:
If ETH gas fees are high, you can favorite the NFT and purchase it when gas fees are lower. If you have any further questions, please leave a comment below, and I will update the article accordingly. It is recommended not to translate this article prematurely. User Comments on This Discussionfodhelper on Dec 5, 2024 As someone who doesn't want to get banned by CDNs, I prefer WebSocket or gRPC without RPRX on Dec 5, 2024 What else is their problem except the static Early-Data header key of WebSocket and the static Countermeasures should be studied when the CDN starts to target agents, and there is no point in fighting in advance or preparing for SHTF, not to wait until things go wrong and then start thinking about it and finding solutions. When it’s impossible to not have clear characteristics for CDN (or for GFW if the user wanted to not use TLS), there is no reason not to. RPRX on Dec 6, 2024 fodhelper on Dec 6, 2024
RPRX on Dec 18, 2024 fodhelper on Dec 18, 2024 MossAndMaurice on Dec 6, 2024 Trying to understand the focus and logic behind the XTLS series of protocols. If there are any inaccuracies, please @RPRX for corrections. XTLS (Initial Versions: splice/direct/origin, etc.) – Solving Performance Issues: Traditional TLS over TLS introduces the overhead of double encryption. XTLS embeds or splices the inner TLS data directly and losslessly into the outer TLS stream, making it appear as a single-layer TLS on the surface while hiding proxy traffic. This reduces redundant encryption and decryption processes. Without compromising security, it significantly lowers CPU load and encryption/decryption costs, thereby improving performance. VISION – Addressing TLS-in-TLS Characteristics: In multi-layered TLS (TLS-in-TLS), the inner and outer TLS handshakes involve two separate interactions, creating a timing pattern that can be precisely identified by the GFW. VISION works by simulating delays and adjusting the message exchange sequence to smooth out these unnatural timing characteristics. This makes the multi-layered TLS handshake process appear more like genuine internet traffic, reducing the risk of detection. REALITY – Solving the SNI Blocking Problem: In mainland China, SNI (Server Name Indication) cannot be encrypted, allowing the GFW to identify and block traffic based on SNI. REALITY disguises the TLS handshake and certificate exchange process by returning certificates and initial data that appear to belong to legitimate websites during the handshake. This makes the entire TLS connection indistinguishable from a connection to a major HTTPS website. For the GFW to block such traffic, it risks mistakenly blocking real websites. XHTTP – Addressing the "Single Tunnel" Characteristics of Proxy Protocols: Traditional protocols (e.g., Shadowsocks, Vmess, Trojan) typically encrypt data and transmit it continuously through specific ports, creating a "stable, long-duration encrypted stream" characteristic. Censors can use statistical analysis, long connection patterns, and data transmission modes to suspect proxy traffic. XHTTP focuses on the application layer, further wrapping encrypted transmissions into what appear to be legitimate HTTP requests and responses. It splits upstream data into multiple seemingly normal POST requests with randomized parameters in the URLs, while downstream data is disguised as large file downloads or continuous SSE (Server-Sent Events) outputs. This makes traffic behavior closely resemble ordinary user browsing or downloading patterns. Unlike traditional "encrypted tunnels," XHTTP no longer appears as a stable, continuous data pipeline but as a series of independent, scattered, and natural HTTP interactions, mimicking common web access actions. tomxiang1 on Dec 6, 2024 REALITY also solves the problem of server handshake negotiation, making it easy to disguise as a major server, so the GFW is hesitant to block it. Ahmad-2213 on Dec 8, 2024 A specific question! RPRX on Dec 9, 2024 It seems that stream-one might work. TheLordOfTheKings on Dec 8, 2024 Hi @RPRX, is it possible to have Vision Seed with XHTTP+REALITY in the future? RPRX on Dec 9, 2024 That's the purpose of Seed. RPRX on Dec 5, 2024 When discussing upstream and downstream separation, many people's approach is to prioritize upstream routes for upstream traffic and downstream routes for downstream traffic. This is quite practical. zzlinwq on Dec 9, 2024 I think this is more understandable if you think of upstream as the process of going and downstream as the process of returning. Prioritize routes for going and returning separately. This is also practical. If it's IPv6 going, then return via IPv6; if it's IPv4 going, then return via IPv4. zzlinwq on Dec 9, 2024 Does XHTTP require a domain certificate? If so, which one is better to apply for? xqzr on Dec 9, 2024 IP certificates are also acceptable. zzlinwq on Dec 10, 2024 Really? Which one should I apply for? xqzr on Dec 10, 2024 ZeroSSL. RPRX on Dec 10, 2024 I think this analogy of upstream as going and downstream as returning is more understandable. Prioritize routes for going and returning separately. This is also practical. If it's IPv6 going, then return via IPv6; if it's IPv4 going, then return via IPv4. The next version will change to "prioritize upstream routes for upstream traffic."iopq on Dec 10, 2024 Is it possible to split UDP and TCP connections? For example, I want UDP connections to go to a certain port, and TCP connections to go to 443. RPRX on Dec 10, 2024 Routing. iopq 3 weeks ago Wait, does reality even support QUIC? GreatMichaelLee on Dec 10, 2024 I'm a bit confused, but I think this is a good feature for reality—users with complex needs. Can you organize a few user cases (like with CDN, without CDN, different configurations, etc.) for different scenarios and provide configuration examples? Then users can adjust based on their server and IP. Some users may not be able to configure it themselves, so having examples would be helpful. Is there a public group for users? I'm currently struggling with the biggest confusion about upgrading XHTTP. I don't know which to change or keep, and if two configurations conflict, I don't know how to arrange them. RPRX on Dec 10, 2024 For small users, the "Quick Start Guide" in the article is enough. Basically, you only need to adjust |
Beta Was this translation helpful? Give feedback.
-
stream-up performance is much better. But it has a long way to reach tcp reality xtls-rprx-vision. |
Beta Was this translation helpful? Give feedback.
-
cloudfront可以用吗 |
Beta Was this translation helpful? Give feedback.
-
XHTTP 能用 xray 自己做接入层吗,不用CDN的情况下。还是必须nginx? 比如以下设想 Client -> up -> REALITY+XHTTP -> node2 -> VMESS/RAW -> node1 |
Beta Was this translation helpful? Give feedback.
-
请问一下xhttp的reality设置里面的dest是什么时候改成target的 |
Beta Was this translation helpful? Give feedback.
-
@RPRX I had a question : Doesn't xray round robin load balancing with multiple links perform a similar function to download/upload separations in xhttp? Because I see countless similarities between xhttp upload/download separation and load balancer. |
Beta Was this translation helpful? Give feedback.
-
经实验,部分CDN不支持流式下行,无论是否关闭缓存(例如 Azure CDN Standard 会直接卡住,直到超时)。想问能否考虑提供分包下行的降级机制,以便在特殊情况下保留高兼容性的保底手段? |
Beta Was this translation helpful? Give feedback.
-
中文 | Русский
XHTTP: Beyond REALITY
开发简述:2024 年中,@mmmray @ll11l1lIllIl1lll 等人基于 @RPRX 所述的“分包上行、流式下行”原理及实现细节开发出了 SplitHTTP,首次实现了不牺牲下行效率的同时穿透绝大多数支持 HTTP 的中间盒,并首次大规模实现了 QUIC H3 过 CDN,开启了一个崭新的时代,浏览器转发 Broswer Dialer 支持、减少特征的 header padding、控制复用的 XMUX、解锁 REALITY 也相继被安排上。随后 @RPRX 接手开发,实现了真正的上下行分离并更名为 XHTTP,比如上下行可以分别是 IPv6 CDN H3、IPv4 REALITY H2(源 IP 都可以不同),
这下又开启了一个崭新的时代,紧接着开发了不牺牲上行效率的流式上行 stream-up 模式、可以分享全部细节配置的 extra 方案,并给 stream-up 模式加上了默认的 gRPC header 伪装,实现了 H2 流式上行过 CDN,取代了传统的 gRPC 传输层,当初发现这也行就不会有它了,最后将 HTTP 传输层作为 stream-one 模式并入 XHTTP,使其也拥有了 header padding、XMUX、gRPC header 伪装等特性。至此,我们有了完全体 XHTTP:各种姿势穿透中间盒、上下行分离、丝滑的 XMUX 等应有尽有,XHTTP 全场景通吃的时代正式到来。原为导剪版文档,不小心写成了文章。这篇文章旨在帮助你透彻地理解 XHTTP 的原理、设计,以便更好地使用它。
如果你要捐助 Xray 项目、收藏 NFT,相关介绍在文末,感谢支持!
快速上手指南
别看 XHTTP 的参数较多,其实都调好了默认值,如果你只是想用 XHTTP 的话,只需遵循六步:
path
,其它不填即可alpn
选 "h3" 即可使用 QUICaddress
填 IP,serverName
(SNI)填域名即可mode
选 "packet-up",兼容性最强XHTTP 默认有多路复用,延迟比 Vision 低但多线程测速不如它,除非测速前设了
"maxConcurrency": 1
,参考 XMUX 小节。此外 v2rayN&G 客户端有全局 mux.cool 设置,用 XHTTP 前记得关闭,不然连不上新版 Xray 服务端。
这篇文章可以当增强版文档用,它基本上涵盖了关于 XHTTP 你想要了解的所有内容,对每个参数都有解释,文末也有一份涵盖了所有参数的配置示例,并且标注了每个参数的使用场景,如果你对哪个参数不清楚,文内搜索参数名即可找到该参数的详细解释。
两个底层逻辑
正如 REALITY 可以伪装成别人的网站,反审查的根本逻辑就是增加审查者执行封锁时的“附带伤害”,使审查者不敢贸然封锁,我当年看好 TLS 以及 TLS 上流量的时序、长度特征混淆也是同理。多年经验告诉我们 GFW 不会永久封锁大型 CDN 的整个 IP,否则会波及太多常规网站,那么对于 XHTTP,我们最初的目标就是把它隐藏在众多各种各样的 CDN 后面。然而 CDN 为了防止源站遭受攻击,除了有特殊支持的 WS、gRPC 外,一般会缓存完整个 HTTP 请求再发给源站,许多 HTTP 中间盒默认也是这样的行为。据此,Tor 的 Meek 协议把往返流量包装为了一个个 HTTP 请求以穿透这些中间盒,但速率惨不忍睹,因为它没有采用 XHTTP 的“流式下行”。什么是“流式下行”呢?想象一下你正在一个网站上下载一个很大的文件,CDN 没击中缓存于是回源拿,但显然它不太好像上行一样先缓存完整个文件让你干等,而是源站发来多少数据,CDN 就即时转发给你,这就是 XHTTP “流式下行”的基础,也保证了最重要的下行速率可以拉满。至于上行,出于兼容性考虑,XHTTP 首先实现的是“分包上行”,即把上行流量包装为一个个 POST 请求,它的效率显然会打折扣,但好在对于一般的代理需求而言上行流量极少。此后我加了“流式上行”,并且我们发现加上 gRPC header 伪装后还能 H2 流式上行穿透 CF,而我几轮优化”分包上行“后速率甚至直追”流式上行“。
顺便谈一下最近又比较火的套 CDN 是否属于“滥用”的问题:显然不支持流式上行的 CDN 其本意并非让你用来搭建代理服务,但我们为了对抗 GFW,不断探索、开发、利用尽可能多的新路是合理且必要的,是不得已而为之,且增加审查者的“附带伤害”就是要求我们混入“正常”服务,这也是不可避免的。举个最简单的例子:哪天 IP 白名单了而 CDN 的 IP 在里面,你用还是不用?反审查这一领域并不适用现实世界的一些规则,这么简单的道理却一直都有人想不明白。 如果还是没想通,那像 WebSocket 这样的传输层现在仅为了套 CDN 而存在,作为开发者可以删掉它,作为用户可以建议开发者删掉它,以自身的实际行动来证明“滥用 CDN”并不只是为了眼红攻击 Xray 这一为满足某些病态心理的日经无聊行为而找出的又一个借口罢了,
与此同时身体却很诚实,与此同时不难窥见,有些人的虚伪本质已经暴露无遗。PACKET-UP
这一小节技术细节太多,非开发者可以只看粗体部分。
对于 XHTTP 兼容性最强的“分包上行、流式下行”,即 packet-up 模式,我们是这样设计的:
客户端
POST /yourpath/sameUUID/seq
以发送上行数据:客户端
GET /yourpath/sameUUID
启动下行,服务端响应头包含:X-Accel-Buffering: no
以告知中间盒禁用缓冲Cache-Control: no-store
以告知中间盒无需缓存Content-Type: text/event-stream
以伪装成 server-sent events(兼容性更好,可以设置noSSEHeader
以关闭)Transfer-Encoding: chunked
,H2/H3 则不需要为了避免浏览器转发 Browser Dialer 遇到跨域限制,服务端针对所有 GET、POST 的响应头都会包含:
Access-Control-Allow-Origin: *
Access-Control-Allow-Methods: GET, POST
为了解决 HTTP 请求头和响应头的固定长度特征:
?x_padding=000...
(放 query string 是为了防止 Browser Dialer 产生不必要的 OPTIONS 请求),默认长度为 100-1000,每次请求随机,服务端默认会检查它是否在服务端允许的范围内X-Padding: 000...
,默认长度为 100-1000,每次响应随机xPaddingBytes
分包上行、
?x_padding=000...
会产生较多、较长的日志,你可以在反代软件中设置不记录它们。此外,和 Xray 的其它传输层一样,服务端也接受
X-Forwarded-For
header 以取得客户端的真实 IP,也会依据服务端设置的host
来检查客户端发来的 host(个人建议是没事别设,毕竟已经隐藏在 path 后面了)。以上就是 packet-up 模式的最简化、必要流程,不过此时还有个小问题:如何具体实施、限制 POST 请求?有三个专属参数:
scMaxEachPostBytes
:客户端每个 POST 最多携带多少数据,默认值 1000000 即 1MB,该值应小于 CDN 等 HTTP 中间盒所允许的最大值,服务端也会拒绝大于该值的 POSTscMinPostsIntervalMs
:仅客户端,基于单个代理请求,客户端发起 POST 请求的最小间隔,默认值 30 毫秒scMaxBufferedPosts
:仅服务端,基于单个代理请求,服务端最多缓存多少个 POST 请求,默认值 30 个,超限断连“基于单个代理请求”的意思是每个代理请求各自计数、互不影响,即使它们在同一条 H2 / H3 连接内,这便是 sc 即 sub-connection 的含义。为了减少指纹,前两个值可以设为范围的形式,比如分别为字符串 "500000-1000000"、"10-50",每次随机。这些参数都可以通过
extra
下发给客户端,文末有说明。此外值得一提的是,Xray 最新版优化了 packet-up,速率甚至直追 stream-up,主要利好 QUIC H3 过 CDN。H1 / H2 / H3
既然我们有了几乎能穿透所有 HTTP 中间盒的 packet-up 模式,让我们来讨论一个有趣的东西:QUIC H3 过 CDN,即当初 SplitHTTP 那个崭新的时代,理解这一小节对于灵活使用 XHTTP 尤为重要。
很多 HTTP 中间盒的一个特性就是会进行 HTTP 版本的转换,比如 CDN、Nginx 会将收到的 H3 流量转为 H1 或 H2 流量回源,也就是说我们的 XHTTP 服务端可以仅监听 H1 和 H2,无需监听 H3,但 XHTTP 客户端却可以使用 H3。
这也是 XHTTP 服务端的默认行为:仅监听 TCP 端口并处理 H1 和 H2 流量。 当启用 TLS 并在
alpn
处仅设置一个元素 "h3" 时,服务端将仅使用 quic-go 监听 UDP 端口并处理 H3 流量,但是目前不建议你这样做,而应将 XHTTP 隐藏在真正的 Nginx、Caddy 后面以减少指纹特征,这也是 XHTTP 相较于其它 QUIC 类代理的重要优点之一,另一个当然是能过 CDN。 此外 H3 的拥塞控制为应用层实现,理论上你可以修改这些反代软件的 QUIC 拥塞控制算法并编译,以实现有些人想要的暴力发包。对于 XHTTP 客户端:
alpn
仅有 "http/1.1" 则使用 HTTP/1.1(但 Xray 并不会允许它修改 uTLS 浏览器指纹伪装)alpn
仅有 "h3" 则使用 quic-go H3tlsSettings
都会失效)如果你要确认 Xray 客户端实际使用的 HTTP 版本、host,以及 XHTTP mode、上下行分离等信息,将日志调至 "info" 级别即可。
代理的 QUIC H3 过 CDN,至少 XHTTP 是首个大规模实现的,开了条新路,毕竟有的地区、有的运营商对 H3 审查不严,
不过也有的会 Q 死。即使后来我们开发了 stream-up 模式并发现了加上 gRPC header 伪装就能穿透 CF,也只作用于 H2,看来这个崭新的时代的含金量还在不断上升。XMUX
既然我们提到了 H2 和 H3,就不得不提它们的多路复用:均为 0-RTT,区别是 H3 没有 H2 的 TCP 队头阻塞问题,并且支持连接迁移,客户端换网也不会断。
那么经常研读 RFC 的朋友就会问了:如何具体控制它们的多路复用?我们设计了一个简洁而强大的接口,即 XMUX:maxConcurrency
:每条 TCP/QUIC 连接中最多同时存在多少代理请求,连接中的代理请求数量达到该值后 core 会建立新的连接,以容纳更多的代理请求。XMUX 全为 0 时该项默认值为 "16-32",每次随机。maxConnections
:最多同时存在多少条连接,连接数达到该值前每个新的代理请求都会开启一条新的连接,此后 core 会开始复用已有的连接。该值与maxConcurrency
冲突,只能二选一。默认值 0,即不限制,支持填写范围,每次随机。cMaxReuseTimes
:一条连接最多被复用几次,复用该次数后将不会被分配新的代理请求,将在内部最后一条代理请求关闭后断开。XMUX 全为 0 时该项默认值为 "64-128",每次随机。cMaxLifetimeMs
:一条连接最长“存活”多久,存活该时间后将不会被分配新的代理请求,将在内部最后一条代理请求关闭后断开。默认值 0,即不限制,支持填写范围,每次随机。hMaxRequestTimes
:@xqzr 发现 Nginx 默认最多允许每条 TCP/QUIC 连接累计承载 1000 个 HTTP 请求,XMUX 全为 0 时该项默认值为 "800-900" 取随机,否则该项默认 0 即不限制。该项基于 HTTP 请求计数,一般来说 stream-one 只产生一个 HTTP 请求,stream-up 是两个,packet-up 则是 N 个。该项计数不严谨,且 Golang 的 GET 请求有自动重试,故不建议顶格填写,那些 CDN 什么的要试出来。其中 packet-up 上行循环 POST 时若超过该值会自动切换到另一个 TCP/QUIC 连接,占它一个 reuseTimes 但不占 concurrency。 其实按 XMUX 的三项默认值,stream-* 不会超限,就 packet-up 会超,而它是 H3 的默认 mode,所以新增该项又主要是利好了 H3。hKeepAlivePeriod
:H2 / H3 连接空闲时客户端每隔多少秒发一次保活包,默认 0,即 Chrome H2 的 45 秒,或 quic-go H3 的 10 秒。它是 XMUX 里唯一不允许填范围(该项取随机才是特征)且允许填负数(比如填 -1 关掉空闲保活包)的项,建议留 0。XMUX 提供的这些参数可以组合出各种用法,比如多线程测速前需要设
"maxConcurrency" 1
,而“无限”复用可以设"maxConnections" 1
。即使你懒得研究也没事,当这些值全为 0 时就会取到上面写的三个默认值,相当于隔段时间就换个新的 H2/H3 主连接,相当丝滑,不会有 gRPC、HTTP 传输层始终复用同一条连接导致的“断流”体验。同样,这些参数都可以通过extra
下发给客户端。注:全不填也相当于全为零,会取到三个默认值,但若填了任一项,其它项就没有默认值了,全都要自己填,除前两项外其它项均可同时填。
此外,使用 XHTTP 时不要启用 mux.cool,并且新版 Xray 服务端已有检查,只接受纯 XUDP。
关于 XMUX 的默认值,一些摘录:
文章下方还有讨论一些 Nginx 参数。
STREAM-UP/ONE
终于轮到 XHTTP 的另一个重要模式了:“流式上行、流式下行”的 stream-up,顾名思义这种模式的上行也是流式的,从而不会牺牲上行效率。 它本来是为 REALITY 而开发的,直到我们发现加个 gRPC header 伪装 H2 就能穿透 CF(需要在面板中开启 gRPC 支持),并且 Nginx 等反代软件的支持也不错(Nginx 推荐 grpc_pass,简单省事),所以
mode
默认值 "auto" 的行为是:downloadSettings
时 stream-up),否则 packet-up它们的实现方式是(非开发者可以跳过):
POST /yourpath/sameUUID
即可,也有?x_padding=000...
POST /yourpath/
即可,响应即为下行,双向流式,请求头、响应头均有 header padding/yourpath
,实际请求的是/yourpath/
,若末尾没有/
会自动补上Content-Type: application/grpc
以伪装成 gRPC(可以设置noGRPCHeader
以关闭)noSSEHeader
那么经常使用 gRPC 的朋友就会问了:stream-up 比 gRPC 传输层有什么优势呢?
当然,XHTTP 相较于 WebSocket、HTTPUpgrade 的优势,除了“没有 ALPN 为 http/1.1 的显著特征”外,相信你都看到这里了,心里也早已有了答案,我就不一一列举了,
主要是太多了也不好列。上下行分离
压轴登场的当然是又一个崭新的时代:上下行分离。 我们大概知道,现在 GFW 针对 TLS in TLS 等流量特征的检测是基于单条连接,那么如果我们把上下行拆分到不同的审查系统,比如上行跑 IPv4 的 TCP,下行跑 IPv6 的 UDP,GFW 就会一时反应不过来。而由于 XHTTP 服务端仅基于 path 中随机生成的 UUID 关联上下行,packet-up 和 stream-up 天生就具有真正的上下行分离能力,且由于 XHTTP 可以穿透各种 CDN、可以搭配 REALITY 等,可选姿势也无限多。对于客户端,需要设置
downloadSettings
:可以看出,
downloadSettings
其实就是一套全新的streamSettings
,但是多了类似于 VLESS 出站中的address
和port
以指向另一个入口。显然其中network
必须为 "xhttp"(不可省略),security
可以为 "tls" 或 "reality"。sockopt
项不存在时会继承上行,且由于其中有些参数只作用于本地、分享后会出问题,若处于extra
中(可去掉)则为强制继承上行。除该特例外,上下行分离时下行配置是完全独立的,不会继承上行的任何配置,而且比如,即使上下行均未填 XMUX 从而取默认值时,它们分别在 range 内 roll 出的确定值也是相互独立、无关的,这样随着时间的推移,上下行的复用完全不对称,切换主连接的时间点也不同,反分析效果更好。因为 GFW 若要对上下行分离动手,“主连接发起的时间点相同”肯定是最重要的切入点,所以以后 XHTTP 还会允许一开始就以不同的时间点发起上下行连接。其实如果你套了 CDN,甚至不需要修改服务端配置就可以玩转上下行分离,比如你可以优选出一个 IPv4 跑 TLS H2,再优选出一个 IPv6 跑 QUIC H3。而且 CDN 基本都支持“同域域前置”,比如上行
serverName
填 "a.example.com",下行serverName
填 "b.example.com",上下行host
均填 "c.example.com",实现外部 SNI 看起来也不同,当然如果你本来就有两个域名就更好了。如果你没有任何域名的话,也可以开两台 VPS、开两个 REALITY 玩上下行分离:无论是 CDN 加反代,还是 REALITY 加回落,只要最终以同一 path 抵达同一 VPS 上的同一 XHTTP 入站即可。总之由于 XHTTP 到处都能用,可随意搭配出来的组合是无限的,唯一的问题是脑洞够不够大。比如上下行分离问世后,很多人的用法其实是把上行分给去程优的线路、把下行分给回程优的线路,这样也挺实用的。
上面贴出了一份涵盖了所有参数的配置示例,主要是为了让大家知道每一项应该写在哪,并说明一下前文中没怎么解释的参数:
extra
是host
、path
、mode
以外的所有参数的原始 JSON 分享方案,当extra
存在时,只有该四项会生效。且分享链接中只有这四项,GUI 一般也只有这四项,因为extra
中的参数都相对低频,且应当由服务发布者直接下发给客户端,不应该让客户端随意改。补充说明:“下发”的意思是“人去下发”,就是服务发布者写好
extra
后整个放进分享链接,客户端直接作为自己的extra
就可以用。host
的行为与 Xray 其它基于 HTTP 的传输层一致,客户端发送 host 的优先级为host
>serverName
>address
。服务端若设了host
,将会检查客户端发来的值是否一致,否则不会检查,建议没事别设。host
不可填在headers
内。Beyond REALITY
去年初我回归并写了
秒天秒地秒空气的REALITY,一举解决了多个痛点,然后就天天泡夜店没怎么管了,连文章都鸽到了现在还没完成,XUDP UoT Migration 更可惜,去年文章快写完了都没发,不知不觉 REALITY 已悄然成长为直连主力,经常能看到 XX 被封了下面的评论是推荐换 REALITY,口碑是有目共睹的,甚至因为过于稳定,这里都没以前热闹了。虽然 Xray 也为其它 transports 做出过大量优化、改进,但 XHTTP 是第一个 Xray 原生的传输层,第一个就整了波大的,当你看完这篇文章,也清楚 XHTTP 可以和 REALITY 一起用:Beyond REALITY 的意思并非是取代 REALITY,而是流行程度超越 REALITY。毫不夸张地说,正如 Xray 一贯的风格,XHTTP 的出现使得其它基于 HTTP 的传输层全部黯然失色,这就是 XHTTP 全场景通吃的时代。它将会比上一个成功的协议 REALITY 更加流行,因为 XHTTP 的特性就已经决定了它的覆盖面会更广。
最后,希望 XHTTP 的出现能够给大家带来一点小小的震撼,正如 Xray 历史上多次做到的那样:变革、推陈出新,始终是 Xray 的信仰。
若本文对你有所帮助,支持一个 REALITY NFT:
一篇介绍 REALITY 的文章将于接下来几天发布变成了介绍 XHTTP在大家的支持下,Project X NFT 已翻五六倍,对于 Project X NFT 首发时观望的朋友,这是一次弥补遗憾的好机会。
当然若你有余力,能支持个 Project X NFT 就更感谢了:
0xDc3Fe44F0f25D13CACb1C4896CD0D321df3146Ee
若还有哪里不清楚请在下方留言,我会更新文章,
建议不要过早出翻译版。Beta Was this translation helpful? Give feedback.
All reactions