SUN RPC (ONC/RPC): расчет времени приема-передачи (или проверки связи) с использованием нулевой процедуры в C

Как рассчитать или оценить RTT (время приема-передачи) между клиентом и сервером?

Учебное пособие или пример, посвященный этому, также могут помочь.


person duru    schedule 13.04.2012    source источник
comment
mattgemmell.com/2008/12/08/what-have-you -пробовал   -  person Some programmer dude    schedule 13.04.2012
comment
Иоахим привет. Спасибо за попытку помочь, даже грубо. Вот что я сделал как новичок в то время, когда задал вопрос (я все еще новичок): я искал в Интернете все возможные комбинации ключевых слов заголовка (ключевые слова: SUN + RPC + ONC + RTT + туда и обратно + время прохождения туда и обратно + ping + нулевая процедура + c + оценка + клиент + сервер). Я прочитал всю документацию, которую нашел по RPC. Я даже прочитал несколько листов стандартов RFC. (Помню, они меня поразили.) Я ничего не придумал. Итак, ответ ниже - единственное решение, которое я смог найти. Это ...   -  person duru    schedule 30.07.2012
comment
... почему это дорого. В любом случае, спасибо за ваш ценный, но грубый вклад.   -  person duru    schedule 30.07.2012


Ответы (1)


Вот что я делаю:

#include <rpc/rpc.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/times.h>
#include <fcntl.h>
#include <time.h>

int main(int argc, char *argv[]) {

    enum clnt_stat status;
    CLIENT *handle;
    struct timeval t;
    clock_t rtime;
    struct tms dumm;
    int count = 100000;
    int i;
    time_t now;
    char stamp[27];
    int programm;
    int version;

    if (argc != 4) {
        printf("Usage: rpcping <host> <program> <version>\n");
        exit(1);
    }

    /*
     *   Create Client Handle
     */
    programm = atoi(argv[2]);
    version = atoi(argv[3]);
    handle = clnt_create(argv[1], programm, version, "tcp");
    if (handle == NULL) {
        printf("clnt failed\n");
        exit(1);
    }

    /*
     *   use 30 seconds timeout
     */
    t.tv_sec = 30;
    t.tv_usec = 0;

    while (1) {
        rtime = times(&dumm);
        for (i = 0; i < count; i++) {
            status = clnt_call(handle, 0, (xdrproc_t) xdr_void,
                NULL, (xdrproc_t) xdr_void, NULL, t);

            if (status == RPC_SUCCESS) { /* NOP */ }
        }
        now = time(NULL);
        ctime_r(&now, stamp);
        stamp[strlen(stamp) - 1] = '\0';
        fprintf(stdout, "[%s]: Speed:  %2.4fs.\n", stamp,
            count / ((double) (times(&dumm) - rtime) / (double) sysconf(_SC_CLK_TCK)));
        fflush(stdout);
    }

    clnt_destroy(handle);
}

У меня тоже многопоточная версия

https://gist.github.com/2401404

Тигран.

person kofemann    schedule 25.04.2012
comment
Спасибо большое Тигран. Это, наверное, один из немногих примеров на всем сайте www. У меня еще не было времени попробовать, но я постараюсь отметить это как ответ в ближайшее время. Еще раз большое спасибо. - person duru; 03.06.2012