All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.emc.ecs.nfsclient.portmap.Portmapper Maven / Gradle / Ivy

Go to download

NFS Client for Java - provides read/write access to data on NFS servers. The current implementation supports only NFS version 3.

There is a newer version: 1.1.0
Show newest version
/**
 * Copyright 2016 EMC Corporation. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License").
 * You may not use this file except in compliance with the License.
 * A copy of the License is located at
 *
 * http://www.apache.org/licenses/LICENSE-2.0.txt
 *
 * or in the "license" file accompanying this file. This file is distributed
 * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
 * express or implied. See the License for the specific language governing
 * permissions and limitations under the License.
 */
package com.emc.ecs.nfsclient.portmap;

import com.emc.ecs.nfsclient.network.NetMgr;
import com.emc.ecs.nfsclient.rpc.RpcException;
import com.emc.ecs.nfsclient.rpc.RpcStatus;
import com.emc.ecs.nfsclient.rpc.Xdr;

import java.io.IOException;

import org.apache.commons.lang.NotImplementedException;

/**
 * Used to query the port used for a service (mount or NFS), as specified by
 * https://tools.ietf.org/html/rfc1833.
 * 
 * @author seibed
 */
public class Portmapper {

    /**
     * TCP port for Portmap calls, as specified by
     * https://tools.ietf.org/html/rfc1833.
     */
    private static final int PMAP_PORT = 111;

    /**
     * Maximum request size in bytes.
     */
    private static final int PORTMAP_MAX_REQUEST_SIZE = 128;

    /**
     * RPC timeout in seconds.
     */
    private static int PORTMAP_RPC_TIMEOUT = 10;

    /**
     * Maximum number of retries. Calls are wrapped in case of temporary issues.
     */
    private static int _maxRetry = 2;

    /**
     * 
    *
  • If true, use a privileged local port (below 1024) for * Portmap RPC communication.
  • *
  • If false, use any non-privileged local port for Portmap * RPC communication.
  • *
*/ private static boolean _usePrivilegedPort = false; /** * Given program and version of a service, query its tcp port number * * @param program * The program number, used to identify it for RPC calls. * @param version * The program version number, used to identify it for RPC calls. * @param serverIP * The server IP address. * @return The port number for the program. */ public static int queryPortFromPortMap(int program, int version, String serverIP) throws IOException { GetPortResponse response = null; GetPortRequest request = new GetPortRequest(program, version); for (int i = 0; i < _maxRetry; ++i) { try { Xdr portmapXdr = new Xdr(PORTMAP_MAX_REQUEST_SIZE); request.marshalling(portmapXdr); Xdr reply = NetMgr.getInstance().sendAndWait(serverIP, PMAP_PORT, _usePrivilegedPort, portmapXdr, PORTMAP_RPC_TIMEOUT); response = new GetPortResponse(); response.unmarshalling(reply); } catch (RpcException e) { handleRpcException(e, i, serverIP); } } int port = response.getPort(); if (port == 0) { // A port value of zeros means the program has not been // registered. String msg = String.format("No registry entry for program: %s, version: %s, serverIP: %s", program, version, serverIP); throw new IOException(msg); } return port; } /** * Decide whether to retry or throw exception. * * @param e * The exception. * @param attemptNumber * The number of attempts so far. * @throws IOException */ private static void handleRpcException(RpcException e, int attemptNumber, String server) throws IOException { String messageStart; if (!(e.getStatus().equals(RpcStatus.NETWORK_ERROR))) { messageStart = "network"; } else { // check whether to retry if (attemptNumber + 1 < _maxRetry) { return; } messageStart = "rpc"; } throw new IOException( String.format("%s error, server: %s, RPC error: %s", messageStart, server, e.getMessage()), e); } /** * Never called. */ private Portmapper() { throw new NotImplementedException("No class instances should be needed."); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy