|
1 | | -# Маршрутизация |
| 1 | +### Маршрутизация |
2 | 2 |
|
3 | 3 | Модуль маршрутизации может отправлять входящие данные через разные исходящие соединения в соответствии с разными правилами для достижения цели проксирования по требованию. |
4 | 4 |
|
|
27 | 27 |
|
28 | 28 | - `"AsIs"`: для выбора маршрута используются только доменные имена. Значение по умолчанию. |
29 | 29 | - `"IPIfNonMatch"`: если доменное имя не соответствует ни одному правилу, доменное имя разрешается в IP-адрес (запись A или запись AAAA) для повторного сопоставления; |
30 | | - - Если у доменного имени несколько записей A, предпринимается попытка сопоставить все записи A, пока одна из них не будет соответствовать какому-либо правилу; |
31 | | - - Разрешенный IP-адрес используется только при выборе маршрута, в пересылаемых пакетах данных по-прежнему используется исходное доменное имя; |
| 30 | + - Если у доменного имени несколько записей A, предпринимается попытка сопоставить все записи A, пока одна из них не будет соответствовать какому-либо правилу; |
| 31 | + - Разрешенный IP-адрес используется только при выборе маршрута, в пересылаемых пакетах данных по-прежнему используется исходное доменное имя; |
32 | 32 | - `"IPOnDemand"`: если при сопоставлении встречается любое правило на основе IP-адреса, доменное имя немедленно разрешается в IP-адрес для сопоставления; |
33 | 33 |
|
34 | 34 | > `domainMatcher`: "hybrid" | "linear" |
|
117 | 117 | - IP-адрес: например, `"127.0.0.1"`. |
118 | 118 | - [CIDR](https://ru.wikipedia.org/wiki/Бесклассовая_междоменная_маршрутизация): например, `"10.0.0.0/8"`, также можно использовать `"0.0.0.0/0"` `"::/0"` для указания всех IPv4- или IPv6-адресов. |
119 | 119 | - Предопределенный список IP-адресов: этот список встроен в каждый установочный пакет Xray, имя файла - `geoip.dat`. Формат использования: `"geoip:код_страны"`, должно начинаться с `geoip:` (в нижнем регистре), за которым следует двухбуквенный код страны, поддерживаются почти все страны с доступом в Интернет. |
120 | | - - Специальное значение: `"geoip:private"`, включает в себя все частные адреса, например, `127.0.0.1`. |
121 | | - - Функция инверсии (!), `"geoip:!cn"` означает результаты, не входящие в `geoip:cn`. |
| 120 | + - Специальное значение: `"geoip:private"`, включает в себя все частные адреса, например, `127.0.0.1`. |
| 121 | + - Функция инверсии (!), `"geoip:!cn"` означает результаты, не входящие в `geoip:cn`. |
122 | 122 | - Загрузка IP-адресов из файла: имеет вид `"ext:файл:тег"`, должно начинаться с `ext:` (в нижнем регистре), за которым следует имя файла и тег, файл хранится в [каталоге ресурсов](./features/env.md#путь-к-файлу-ресурсов), формат файла такой же, как у `geoip.dat`, тег должен существовать в файле. |
123 | 123 |
|
124 | 124 | > `port`: number | string |
|
229 | 229 | > `strategy`: [StrategyObject](#strategyobject) |
230 | 230 |
|
231 | 231 | #### StrategyObject |
| 232 | + |
232 | 233 | ```json |
233 | 234 | { |
234 | 235 | "type": "roundRobin", |
235 | 236 | "settings": {} |
236 | 237 | } |
237 | 238 | ``` |
| 239 | + |
238 | 240 | > `type` : "random" | "roundRobin" | "leastPing" | "leastLoad" |
239 | 241 |
|
240 | 242 | - `random`: значение по умолчанию. Случайным образом выбирает соответствующий исходящий прокси. |
|
245 | 247 | > `settings`: [StrategySettingsObject](#strategysettingsobject) |
246 | 248 |
|
247 | 249 | ##### StrategySettingsObject |
| 250 | + |
248 | 251 | Это необязательный параметр конфигурации, формат которого различается для разных стратегий балансировки нагрузки. В настоящее время этот параметр конфигурации можно добавить только для стратегии балансировки нагрузки `leastLoad`. |
249 | 252 |
|
250 | 253 | ### Примеры конфигурации балансировки нагрузки |
251 | 254 |
|
252 | 255 | ```json |
253 | | - "routing": { |
254 | | - "rules": [ |
255 | | - { |
256 | | - "inboundTag": [ |
257 | | - "in" |
258 | | - ], |
259 | | - "balancerTag": "round" |
260 | | - } |
| 256 | +{ |
| 257 | + "routing": { |
| 258 | + "rules": [ |
| 259 | + { |
| 260 | + "inboundTag": [ |
| 261 | + "in" |
261 | 262 | ], |
262 | | - "balancers" : [ |
263 | | - { |
264 | | - "selector": [ |
265 | | - "out" |
266 | | - ], |
267 | | - "strategy": { |
268 | | - "type":"roundRobin" |
269 | | - }, |
270 | | - "tag": "round" |
271 | | - } |
272 | | - ] |
273 | | - } |
274 | | - |
275 | | - "inbounds": [ |
276 | | - { |
277 | | - "tag": "in" |
278 | | - } |
279 | | - ] |
280 | | - |
281 | | - "outbounds": [ |
282 | | - { |
283 | | - "tag": "out1" |
| 263 | + "balancerTag": "round" |
| 264 | + } |
| 265 | + ], |
| 266 | + "balancers" : [ |
| 267 | + { |
| 268 | + "selector": [ |
| 269 | + "out" |
| 270 | + ], |
| 271 | + "strategy": { |
| 272 | + "type":"roundRobin" |
284 | 273 | }, |
285 | | - { |
286 | | - "tag": "out2" |
287 | | - } |
| 274 | + "tag": "round" |
| 275 | + } |
288 | 276 | ] |
| 277 | + } |
| 278 | +} |
| 279 | +``` |
| 280 | + |
| 281 | +```json |
| 282 | +{ |
| 283 | + "inbounds": [ |
| 284 | + { |
| 285 | + "tag": "in" |
| 286 | + } |
| 287 | + ] |
| 288 | +} |
| 289 | +``` |
| 290 | + |
| 291 | +```json |
| 292 | +{ |
| 293 | + "outbounds": [ |
| 294 | + { |
| 295 | + "tag": "out1" |
| 296 | + }, |
| 297 | + { |
| 298 | + "tag": "out2" |
| 299 | + } |
| 300 | + ] |
| 301 | +} |
289 | 302 | ``` |
290 | 303 |
|
291 | 304 | ### Предопределенные списки доменов |
|
309 | 322 | - `tld-!cn`: содержит домены верхнего уровня, не используемые в материковом Китае, например, доменные имена, оканчивающиеся на `.tw` (Тайвань), `.jp` (Япония), `.sg` (Сингапур), `.us` (США), `.ca` (Канада) и т.д. |
310 | 323 |
|
311 | 324 | Вы также можете просмотреть полный список доменов здесь: [Domain list community](https://github.com/v2fly/domain-list-community). |
312 | | - |
|
0 commit comments