Package org.apache.zookeeper.server.quorum

Source Code of org.apache.zookeeper.server.quorum.QuorumPeerConfig

/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements.  See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership.  The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License.  You may obtain a copy of the License at
*
*     http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License 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 org.apache.zookeeper.server.quorum;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileReader;
import java.net.InetSocketAddress;
import java.util.Properties;
import java.util.Map.Entry;
import java.util.HashMap;

import org.apache.log4j.Logger;

import org.apache.zookeeper.server.ServerConfig;
import org.apache.zookeeper.server.quorum.QuorumPeer.QuorumServer;

public class QuorumPeerConfig extends ServerConfig {
    private static final Logger LOG = Logger.getLogger(QuorumPeerConfig.class);

    private int tickTime;
    private int initLimit;
    private int syncLimit;
    private int electionAlg;
    private int electionPort;
    private HashMap<Long,QuorumServer> servers = null;
    private long serverId;

    private QuorumPeerConfig(int port, String dataDir, String dataLogDir) {
        super(port, dataDir, dataLogDir);
    }

    public static void parse(String[] args) throws Exception {
        if (instance != null)
            return;
        if (args.length != 1) {
            throw new IllegalArgumentException("Invalid usage.");
        }
        File zooCfgFile = new File(args[0]);
        if (!zooCfgFile.exists()) {
            throw new IllegalArgumentException(zooCfgFile.toString()
                    + " file is missing");
        }
        Properties cfg = new Properties();
        FileInputStream zooCfgStream = new FileInputStream(zooCfgFile);
        try {
            cfg.load(zooCfgStream);
        } finally {
            zooCfgStream.close();
        }
        HashMap<Long, QuorumServer> servers = new HashMap<Long, QuorumServer>();
        String dataDir = null;
        String dataLogDir = null;
        int clientPort = 0;
        int tickTime = 0;
        int initLimit = 0;
        int syncLimit = 0;
        int electionAlg = 3;
        int electionPort = 2182;
        for (Entry<Object, Object> entry : cfg.entrySet()) {
            String key = entry.getKey().toString();
            String value = entry.getValue().toString();
            if (key.equals("dataDir")) {
                dataDir = value;
            } else if (key.equals("dataLogDir")) {
                dataLogDir = value;
            } else if (key.equals("clientPort")) {
                clientPort = Integer.parseInt(value);
            } else if (key.equals("tickTime")) {
                tickTime = Integer.parseInt(value);
            } else if (key.equals("initLimit")) {
                initLimit = Integer.parseInt(value);
            } else if (key.equals("syncLimit")) {
                syncLimit = Integer.parseInt(value);
            } else if (key.equals("electionAlg")) {
                electionAlg = Integer.parseInt(value);
            } else if (key.startsWith("server.")) {
                int dot = key.indexOf('.');
                long sid = Long.parseLong(key.substring(dot + 1));
                String parts[] = value.split(":");
                if ((parts.length != 2) && (parts.length != 3)) {
                    LOG.error(value
                       + " does not have the form host:port or host:port:port");
                }
                InetSocketAddress addr = new InetSocketAddress(parts[0],
                        Integer.parseInt(parts[1]));
                if (parts.length == 2)
                    servers.put(Long.valueOf(sid), new QuorumServer(sid, addr));
                else if (parts.length == 3) {
                    InetSocketAddress electionAddr = new InetSocketAddress(
                            parts[0], Integer.parseInt(parts[2]));
                    servers.put(Long.valueOf(sid), new QuorumServer(sid, addr,
                            electionAddr));
                }
            } else {
                System.setProperty("zookeeper." + key, value);
            }
        }
        if (dataDir == null) {
            throw new IllegalArgumentException("dataDir is not set");
        }
        if (dataLogDir == null) {
            dataLogDir = dataDir;
        } else {
            if (!new File(dataLogDir).isDirectory()) {
                throw new IllegalArgumentException("dataLogDir " + dataLogDir
                        + " is missing.");
            }
        }
        if (clientPort == 0) {
            throw new IllegalArgumentException("clientPort is not set");
        }
        if (tickTime == 0) {
            throw new IllegalArgumentException("tickTime is not set");
        }
        if (servers.size() > 1 && initLimit == 0) {
            throw new IllegalArgumentException("initLimit is not set");
        }
        if (servers.size() > 1 && syncLimit == 0) {
            throw new IllegalArgumentException("syncLimit is not set");
        }
        QuorumPeerConfig conf = new QuorumPeerConfig(clientPort, dataDir,
                dataLogDir);
        conf.tickTime = tickTime;
        conf.initLimit = initLimit;
        conf.syncLimit = syncLimit;
        conf.electionAlg = electionAlg;
        conf.servers = servers;
        if (servers.size() > 1) {
            /*
             * If using FLE, then every server requires a separate election
             * port.
             */
            if (electionAlg != 0) {
                for (QuorumServer s : servers.values()) {
                    if (s.electionAddr == null)
                        throw new IllegalArgumentException(
                                "Missing election port for server: " + s.id);
                }
            }

            File myIdFile = new File(dataDir, "myid");
            if (!myIdFile.exists()) {
                throw new IllegalArgumentException(myIdFile.toString()
                        + " file is missing");
            }
            BufferedReader br = new BufferedReader(new FileReader(myIdFile));
            String myIdString;
            try {
                myIdString = br.readLine();
            } finally {
                br.close();
            }
            try {
                conf.serverId = Long.parseLong(myIdString);
            } catch (NumberFormatException e) {
                throw new IllegalArgumentException("serverid " + myIdString
                        + " is not a number");
            }
        }
        instance = conf;
      
    }

    @Override
    protected boolean isStandaloneServer(){
        return QuorumPeerConfig.getServers().size() <= 1;
    }

    public static int getTickTime() {
        assert instance instanceof QuorumPeerConfig;
        return ((QuorumPeerConfig)instance).tickTime;
    }

    public static int getInitLimit() {
        assert instance instanceof QuorumPeerConfig;
        return ((QuorumPeerConfig)instance).initLimit;
    }

    public static int getSyncLimit() {
        assert instance instanceof QuorumPeerConfig;
        return ((QuorumPeerConfig)instance).syncLimit;
    }

    public static int getElectionAlg() {
        assert instance instanceof QuorumPeerConfig;
        return ((QuorumPeerConfig)instance).electionAlg;
    }
   
    public static HashMap<Long,QuorumServer> getServers() {
        assert instance instanceof QuorumPeerConfig;
        return ((QuorumPeerConfig)instance).servers;
    }

    public static int getQuorumSize(){
        assert instance instanceof QuorumPeerConfig;
        return ((QuorumPeerConfig)instance).servers.size();
    }

    public static long getServerId() {
        assert instance instanceof QuorumPeerConfig;
        return ((QuorumPeerConfig)instance).serverId;
    }
}
TOP

Related Classes of org.apache.zookeeper.server.quorum.QuorumPeerConfig

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.