client_limits.c 1.8 KB
Newer Older
J
Ján Tomko 已提交
1 2 3
#include <stdio.h>
#include <stdlib.h>
#include <libvirt/libvirt-admin.h>
4 5 6 7 8 9 10 11

int main(int argc, char **argv)
{
    int ret = -1;
    virAdmConnectPtr conn = NULL;
    virAdmServerPtr srv = NULL;     /* which server to work with */
    virTypedParameterPtr params = NULL;
    int nparams = 0;
12
    int maxparams = 0;
13
    ssize_t i;
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63

    if (argc != 2) {
        fprintf(stderr, "One argument specifying the server which to work "
                "with is expected\n");
        return -1;
    }

    /* first, open a connection to the daemon */
    if (!(conn = virAdmConnectOpen(NULL, 0)))
        goto cleanup;

    /* a server handle is necessary before any API regarding threadpool
     * parameters can be issued
     */
    if (!(srv = virAdmConnectLookupServer(conn, argv[1], 0)))
        goto cleanup;

    /* get the current client limits */
    if (virAdmServerGetClientLimits(srv, &params, &nparams, 0) < 0)
        goto cleanup;

    for (i = 0; i < nparams; i++)
        printf("%-15s: %d\n", params[i].field, params[i].value.ui);

    virTypedParamsFree(params, nparams);
    params = NULL;
    nparams = 0;

    /* set nclients_max to 100 and nclients_unauth_max to 20 */
    if (virTypedParamsAddUInt(&params, &nparams, &maxparams,
                              VIR_SERVER_CLIENTS_MAX, 100) < 0 ||
        virTypedParamsAddUInt(&params, &nparams, &maxparams,
                              VIR_SERVER_CLIENTS_UNAUTH_MAX, 20) < 0)
        goto cleanup;

    /* now, change the client limits on the server */
    if (virAdmServerSetClientLimits(srv, params, nparams, 0) < 0)
        goto cleanup;

    ret = 0;
 cleanup:
    virTypedParamsFree(params, nparams);

    /* Once finished deallocate the server handle and close the connection
     * properly, @conn will be deallocated automatically
     */
    virAdmServerFree(srv);
    virAdmConnectClose(conn);
    return ret;
}