Search in sources :

Example 21 with Patterns

use of org.apache.asterix.event.schema.pattern.Patterns in project asterixdb by apache.

the class PatternCreator method createRemoveAsterixLogDirPattern.

private Patterns createRemoveAsterixLogDirPattern(AsterixInstance instance) throws Exception {
    List<Pattern> patternList = new ArrayList<>();
    Cluster cluster = instance.getCluster();
    String pargs = instance.getCluster().getLogDir();
    Nodeid nodeid = new Nodeid(new Value(null, cluster.getMasterNode().getId()));
    Event event = new Event("file_delete", nodeid, pargs);
    patternList.add(new Pattern(null, 1, null, event));
    for (Node node : cluster.getNode()) {
        nodeid = new Nodeid(new Value(null, node.getId()));
        if (node.getLogDir() != null) {
            pargs = node.getLogDir();
        }
        event = new Event("file_delete", nodeid, pargs);
        patternList.add(new Pattern(null, 1, null, event));
    }
    return new Patterns(patternList);
}
Also used : Pattern(org.apache.asterix.event.schema.pattern.Pattern) Node(org.apache.asterix.event.schema.cluster.Node) ArrayList(java.util.ArrayList) Nodeid(org.apache.asterix.event.schema.pattern.Nodeid) Value(org.apache.asterix.event.schema.pattern.Value) Cluster(org.apache.asterix.event.schema.cluster.Cluster) Event(org.apache.asterix.event.schema.pattern.Event) Patterns(org.apache.asterix.event.schema.pattern.Patterns)

Example 22 with Patterns

use of org.apache.asterix.event.schema.pattern.Patterns in project asterixdb by apache.

the class PatternCreator method getLibraryUninstallPattern.

public Patterns getLibraryUninstallPattern(AsterixInstance instance, String dataverse, String libraryName) throws Exception {
    List<Pattern> patternList = new ArrayList<>();
    Cluster cluster = instance.getCluster();
    String workingDir = cluster.getWorkingDir().getDir();
    String destFile = dataverse + "." + libraryName;
    String pargs = workingDir + File.separator + "uninstall" + " " + destFile;
    String metadataNodeId = instance.getMetadataNodeId();
    Nodeid nodeid = new Nodeid(new Value(null, metadataNodeId));
    Event event = new Event("file_create", nodeid, pargs);
    Pattern p = new Pattern(null, 1, null, event);
    patternList.add(p);
    Iterator<Node> uninstallTargets = cluster.getNode().iterator();
    String libDir = workingDir + File.separator + "library" + File.separator + dataverse + File.separator + libraryName;
    Node uninstallNode = uninstallTargets.next();
    nodeid = new Nodeid(new Value(null, uninstallNode.getId()));
    event = new Event("file_delete", nodeid, libDir);
    p = new Pattern(null, 1, null, event);
    patternList.add(p);
    pargs = libDir;
    if (!cluster.getWorkingDir().isNFS()) {
        while (uninstallTargets.hasNext()) {
            uninstallNode = uninstallTargets.next();
            nodeid = new Nodeid(new Value(null, uninstallNode.getId()));
            event = new Event("file_delete", nodeid, pargs);
            p = new Pattern(null, 1, null, event);
            patternList.add(p);
        }
        nodeid = new Nodeid(new Value(null, cluster.getMasterNode().getId()));
        event = new Event("file_delete", nodeid, pargs);
        p = new Pattern(null, 1, null, event);
        patternList.add(p);
    }
    return new Patterns(patternList);
}
Also used : Pattern(org.apache.asterix.event.schema.pattern.Pattern) Node(org.apache.asterix.event.schema.cluster.Node) ArrayList(java.util.ArrayList) Nodeid(org.apache.asterix.event.schema.pattern.Nodeid) Value(org.apache.asterix.event.schema.pattern.Value) Cluster(org.apache.asterix.event.schema.cluster.Cluster) Event(org.apache.asterix.event.schema.pattern.Event) Patterns(org.apache.asterix.event.schema.pattern.Patterns)

Example 23 with Patterns

use of org.apache.asterix.event.schema.pattern.Patterns in project asterixdb by apache.

the class PatternCreator method createRemoveHDFSBackupPattern.

private Patterns createRemoveHDFSBackupPattern(AsterixInstance instance, String hdfsBackupDir) throws Exception {
    List<Pattern> patternList = new ArrayList<>();
    Cluster cluster = instance.getCluster();
    String hdfsUrl = AsterixEventService.getConfiguration().getBackup().getHdfs().getUrl();
    String hadoopVersion = AsterixEventService.getConfiguration().getBackup().getHdfs().getVersion();
    String workingDir = cluster.getWorkingDir().getDir();
    Node launchingNode = cluster.getNode().get(0);
    Nodeid nodeid = new Nodeid(new Value(null, launchingNode.getId()));
    String pathToDelete = hdfsBackupDir + File.separator + instance.getName();
    String pargs = workingDir + " " + hadoopVersion + " " + hdfsUrl + " " + pathToDelete;
    Event event = new Event("hdfs_delete", nodeid, pargs);
    patternList.add(new Pattern(null, 1, null, event));
    return new Patterns(patternList);
}
Also used : Pattern(org.apache.asterix.event.schema.pattern.Pattern) Node(org.apache.asterix.event.schema.cluster.Node) ArrayList(java.util.ArrayList) Nodeid(org.apache.asterix.event.schema.pattern.Nodeid) Value(org.apache.asterix.event.schema.pattern.Value) Cluster(org.apache.asterix.event.schema.cluster.Cluster) Event(org.apache.asterix.event.schema.pattern.Event) Patterns(org.apache.asterix.event.schema.pattern.Patterns)

Example 24 with Patterns

use of org.apache.asterix.event.schema.pattern.Patterns in project asterixdb by apache.

the class PatternCreator method createDeleteInstancePattern.

public Patterns createDeleteInstancePattern(AsterixInstance instance) throws Exception {
    List<Pattern> patternList = new ArrayList<>();
    patternList.addAll(createRemoveAsterixStoragePattern(instance).getPattern());
    if (instance.getBackupInfo() != null && !instance.getBackupInfo().isEmpty()) {
        List<BackupInfo> backups = instance.getBackupInfo();
        Set<String> removedBackupDirsHDFS = new HashSet<>();
        Set<String> removedBackupDirsLocal = new HashSet<>();
        String backupDir;
        for (BackupInfo binfo : backups) {
            backupDir = binfo.getBackupConf().getBackupDir();
            switch(binfo.getBackupType()) {
                case HDFS:
                    if (removedBackupDirsHDFS.contains(backupDir)) {
                        continue;
                    }
                    patternList.addAll(createRemoveHDFSBackupPattern(instance, backupDir).getPattern());
                    removedBackupDirsHDFS.add(backupDir);
                    break;
                case LOCAL:
                    if (removedBackupDirsLocal.contains(backupDir)) {
                        continue;
                    }
                    patternList.addAll(createRemoveLocalBackupPattern(instance, backupDir).getPattern());
                    removedBackupDirsLocal.add(backupDir);
                    break;
            }
        }
    }
    patternList.addAll(createRemoveAsterixLogDirPattern(instance).getPattern());
    patternList.addAll(createRemoveAsterixRootMetadata(instance).getPattern());
    patternList.addAll(createRemoveAsterixTxnLogs(instance).getPattern());
    return new Patterns(patternList);
}
Also used : BackupInfo(org.apache.asterix.event.model.BackupInfo) Pattern(org.apache.asterix.event.schema.pattern.Pattern) ArrayList(java.util.ArrayList) Patterns(org.apache.asterix.event.schema.pattern.Patterns) HashSet(java.util.HashSet)

Example 25 with Patterns

use of org.apache.asterix.event.schema.pattern.Patterns in project asterixdb by apache.

the class PatternCreator method createRemoveAsterixRootMetadata.

private Patterns createRemoveAsterixRootMetadata(AsterixInstance instance) throws Exception {
    List<Pattern> patternList = new ArrayList<>();
    Cluster cluster = instance.getCluster();
    Nodeid nodeid;
    String pargs;
    Event event;
    for (Node node : cluster.getNode()) {
        String iodevices = node.getIodevices() == null ? cluster.getIodevices() : node.getIodevices();
        String primaryIODevice = iodevices.split(",")[0].trim();
        pargs = primaryIODevice + File.separator + StorageConstants.METADATA_ROOT;
        nodeid = new Nodeid(new Value(null, node.getId()));
        event = new Event("file_delete", nodeid, pargs);
        patternList.add(new Pattern(null, 1, null, event));
    }
    return new Patterns(patternList);
}
Also used : Pattern(org.apache.asterix.event.schema.pattern.Pattern) Node(org.apache.asterix.event.schema.cluster.Node) ArrayList(java.util.ArrayList) Nodeid(org.apache.asterix.event.schema.pattern.Nodeid) Value(org.apache.asterix.event.schema.pattern.Value) Cluster(org.apache.asterix.event.schema.cluster.Cluster) Event(org.apache.asterix.event.schema.pattern.Event) Patterns(org.apache.asterix.event.schema.pattern.Patterns)

Aggregations

Patterns (org.apache.asterix.event.schema.pattern.Patterns)35 ArrayList (java.util.ArrayList)24 Pattern (org.apache.asterix.event.schema.pattern.Pattern)24 Node (org.apache.asterix.event.schema.cluster.Node)21 Nodeid (org.apache.asterix.event.schema.pattern.Nodeid)17 Value (org.apache.asterix.event.schema.pattern.Value)17 Event (org.apache.asterix.event.schema.pattern.Event)16 Cluster (org.apache.asterix.event.schema.cluster.Cluster)15 AsterixInstance (org.apache.asterix.event.model.AsterixInstance)12 AsterixEventServiceClient (org.apache.asterix.event.management.AsterixEventServiceClient)7 File (java.io.File)5 Date (java.util.Date)4 AsterixRuntimeState (org.apache.asterix.event.model.AsterixRuntimeState)4 BackupInfo (org.apache.asterix.event.model.BackupInfo)3 PatternCreator (org.apache.asterix.event.util.PatternCreator)3 InstallerException (org.apache.asterix.installer.error.InstallerException)3 ClusterState (org.apache.asterix.common.api.IClusterManagementWork.ClusterState)2 BackupType (org.apache.asterix.event.model.BackupInfo.BackupType)2 ProcessInfo (org.apache.asterix.event.model.ProcessInfo)2 ClusterStateWatcher (org.apache.asterix.event.service.ClusterStateWatcher)2