WedX - журнал о программировании и компьютерных науках

Как хранить несколько гиперсерверов в одном векторе?

Я пытаюсь написать простое приложение для чтения файла конфигурации, а затем развернуть гиперреверсивный прокси для каждой записи в этом файле.

Я анализирую конфигурацию в цикле и хочу иметь возможность отслеживать каждый сервер, который я создал, возможно, в Vec. Я не могу понять, какого типа должен быть Vec, так как каждый сервер относится к разному типу. Я пробовал упаковать результат map_error и сохранить его, но ничего не добился. В гипер-примере на GitHub используются только статически созданные серверы.

Это упрощенная версия того, что я пытаюсь сделать:

use futures::future::{self, Future};
use hyper::service::{make_service_fn, service_fn};
use hyper::{Body, Request, Response, Server};

type BoxFut = Box<Future<Item = Response<Body>, Error = hyper::Error> + Send>;

fn debug_request(req: Request<Body>) -> BoxFut {
    let body_str = format!("{:?}", req);
    let response = Response::new(Body::from(body_str));
    Box::new(future::ok(response))
}

fn main() {
    // This is our socket address...
    let local_address = ([127, 0, 0, 1], 9001).into();

    // A `Service` is needed for every connection.
    let make_svc = make_service_fn(|socket: &AddrStream| {
        let remote_addr = socket.remote_addr();
        service_fn(move |req: Request<Body>| {
            // returns BoxFut

            return hyper_reverse_proxy::call(remote_addr.ip(), "https://192.9.200.162:80", req);
        })
    });

    let server = Box::new(
        Server::bind(&local_address)
            .serve(make_svc)
            .map_err(|e| eprintln!("server error: {}", e)),
    );

    let server2 = Box::new(
        Server::bind(&local_address)
            .serve(make_svc)
            .map_err(|e| eprintln!("server error: {}", e)),
    );

    let vec = vec![server, server2];

    println!("Running server on {:?}", local_address);

    // Run this server for... forever!
    let all_servers = future::join_all(vec);
    hyper::rt::run(all_servers);
}

vec не может удерживать оба сервера, поскольку они имеют разные типы, и я не уверен, как лучше всего сделать hyper::rt::run.

31.07.2019


Новые материалы

Как создать диаграмму градиентной кисти с помощью D3.js
Резюме: Из этого туториала Вы узнаете, как добавить градиентную кисть к диаграмме с областями в D3.js. Мы добавим градиент к значениям SVG и применим градиент в качестве заливки к диаграмме с..

Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

Объяснение документов 02: BERT
BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

Как проанализировать работу вашего классификатора?
Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

Работа с цепями Маркова, часть 4 (Машинное обучение)
Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..


Для любых предложений по сайту: [email protected]