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

com.github.hackerwin7.jd.lib.executors.InitMagpieJobCheckpoint Maven / Gradle / Ivy

package com.github.hackerwin7.jd.lib.executors;

import com.github.hackerwin7.jd.lib.utils.TrainConfService;
import com.github.hackerwin7.jd.lib.utils.magpie.MagpieUtils;
import com.github.hackerwin7.jlib.utils.drivers.file.FileUtils;
import com.github.hackerwin7.jlib.utils.drivers.shell.ShellGetMysqlOffset;
import net.sf.json.JSONObject;
import org.apache.log4j.Logger;

import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;

/**
 * Created by IntelliJ IDEA.
 * User: hackerwin7
 * Date: 2016/03/08
 * Time: 2:07 PM
 * Desc: init the jobId checkpoint (tracker and parser)
 * Tips:
 */
public class InitMagpieJobCheckpoint {

    private Logger logger = Logger.getLogger(InitMagpieJobCheckpoint.class);

    private List tids = new LinkedList<>();

    private Map ttopics = new HashMap<>();
    private Map tips = new HashMap<>();

    public static void main(String[] args) throws Exception {
        InitMagpieJobCheckpoint imjc = new InitMagpieJobCheckpoint();
        imjc.mainProc();
    }

    private void mainProc() throws Exception {
        tids = FileUtils.file2List("job.list");
        CheckpointUtilNginx cp = new CheckpointUtilNginx();
        scanKeyVal("tracker_log_topic", "source_host");
        for(String tid : tids) {
            String pid = MagpieUtils.tracker2ParserJobid(tid);
            String ip = tips.get(tid);
            String topic = ttopics.get(tid);
            String myOffset = ShellGetMysqlOffset.showMasterStatus(ip).toString();
            String tcp = myOffset + ":" + "0:0";
            String pcp = topic + ":" + "0:0:0:0:0";
            cp.write(tid, tcp);
            cp.write(pid, pcp);
            System.out.println(tid + " " + ip + " " + topic + " " + tcp + " " + pcp);
        }
    }

    private void scanKeyVal(String key, String key1) throws Exception {
        for(String tid : tids) {
            JSONObject conf = TrainConfService.getConf(tid);
            String val = conf.getString(key);
            String val1 = conf.getString(key1);
            ttopics.put(tid, val);
            tips.put(tid, val1);
            System.out.println("get conf = " + tid + " " + val + " " + val1);
        }
        System.out.println("count = " + ttopics.size() + "topic map  = " + ttopics);
        System.out.println("count = " + tips.size() + "ip map = " + tips);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy