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

hbase-webapps.master.snapshot.jsp Maven / Gradle / Ivy

<%--
/**
 * 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.
 */
--%>
<%@ page contentType="text/html;charset=UTF-8"
  import="java.util.Date"
  import="org.apache.hadoop.conf.Configuration"
  import="org.apache.hadoop.hbase.client.Admin"
  import="org.apache.hadoop.hbase.client.SnapshotDescription"
  import="org.apache.hadoop.hbase.http.InfoServer"
  import="org.apache.hadoop.hbase.master.HMaster"
  import="org.apache.hadoop.hbase.snapshot.SnapshotInfo"
  import="org.apache.hadoop.util.StringUtils"
  import="org.apache.hadoop.hbase.TableName"
%>
<%
  HMaster master = (HMaster)getServletContext().getAttribute(HMaster.MASTER);
  Configuration conf = master.getConfiguration();
  boolean readOnly = !InfoServer.canUserModifyUI(request, getServletContext(), conf);
  String snapshotName = request.getParameter("name");
  SnapshotDescription snapshot = null;
  SnapshotInfo.SnapshotStats stats = null;
  TableName snapshotTable = null;
  boolean tableExists = false;
  long snapshotTtl = 0;
  if(snapshotName != null && master.isInitialized()) {
    try (Admin admin = master.getConnection().getAdmin()) {
      for (SnapshotDescription snapshotDesc: admin.listSnapshots()) {
        if (snapshotName.equals(snapshotDesc.getName())) {
          snapshot = snapshotDesc;
          stats = SnapshotInfo.getSnapshotStats(conf, snapshot);
          snapshotTable = snapshot.getTableName();
          snapshotTtl = snapshot.getTtl();
          tableExists = admin.tableExists(snapshotTable);
          break;
        }
      }
    }
  }

  String action = request.getParameter("action");
  boolean isActionResultPage = (!readOnly && action != null);
  String pageTitle;
  if (isActionResultPage) {
    pageTitle = "HBase Master: " + master.getServerName();
  } else {
    pageTitle = "Snapshot: " + snapshotName;
  }
  pageContext.setAttribute("pageTitle", pageTitle);
%>


  


<% if (!master.isInitialized()) { %>
<% } else if (snapshot == null) { %>
<% } else { %>

Snapshot Attributes

<% if (stats.isSnapshotCorrupted()) { %> <% } else { %> <% } %>
Table Creation Time Time To Live(Sec) Type Format Version State
<% if (tableExists) { %> <%= snapshotTable.getNameAsString() %> <% } else { %> <%= snapshotTable.getNameAsString() %> <% } %> <%= new Date(snapshot.getCreationTime()) %> <% if (snapshotTtl == 0) { %> FOREVER <% } else { %> <%= snapshotTtl %> <% } %> <%= snapshot.getType() %> <%= snapshot.getVersion() %>CORRUPTEDok
<%= stats.getStoreFilesCount() %> HFiles (<%= stats.getArchivedStoreFilesCount() %> in archive), total size <%= StringUtils.humanReadableInt(stats.getStoreFilesSize()) %> (<%= stats.getSharedStoreFilePercentage() %>% <%= StringUtils.humanReadableInt(stats.getSharedStoreFilesSize()) %> shared with the source table)
<%= stats.getLogsCount() %> Logs, total size <%= StringUtils.humanReadableInt(stats.getLogsSize()) %>
<% if (stats.isSnapshotCorrupted()) { %>

CORRUPTED Snapshot

<%= stats.getMissingStoreFilesCount() %> hfile(s) and <%= stats.getMissingLogsCount() %> log(s) missing.
<% } %> <% } // end else %>




© 2015 - 2025 Weber Informatics LLC | Privacy Policy