Revert "HBASE-21410 A helper page that help find all problematic regions and procedures"

This reverts commit 3c34073988.

missing sign-off.
This commit is contained in:
Guanghao Zhang 2018-11-09 14:01:29 +08:00
parent 3c34073988
commit 13b4351012
3 changed files with 6 additions and 126 deletions

View File

@ -50,7 +50,7 @@ int numOfPages = (int) Math.ceil(numOfRITs * 1.0 / ritsPerPage);
</%java> </%java>
<section> <section>
<h2><a name="rit">Regions in Transition</a></h2> <h2><a name="rit">Regions in Transition</a></h2>
<p><a href="/rits.jsp"><% numOfRITs %> region(s) in transition.</a> <p><% numOfRITs %> region(s) in transition.
<%if ritStat.hasRegionsTwiceOverThreshold() %> <%if ritStat.hasRegionsTwiceOverThreshold() %>
<span class="label label-danger" style="font-size:100%;font-weight:normal"> <span class="label label-danger" style="font-size:100%;font-weight:normal">
<%elseif ritStat.hasRegionsOverThreshold() %> <%elseif ritStat.hasRegionsOverThreshold() %>

View File

@ -215,9 +215,6 @@ AssignmentManager assignmentManager = master.getAssignmentManager();
or re-run HBCK in repair mode. or re-run HBCK in repair mode.
</div> </div>
</%if> </%if>
<%if master.getAssignmentManager() != null %>
<& AssignmentManagerStatusTmpl; assignmentManager=master.getAssignmentManager()&>
</%if>
<%if master.getMasterCoprocessorHost().findCoprocessor("RSGroupAdminEndpoint") != null %> <%if master.getMasterCoprocessorHost().findCoprocessor("RSGroupAdminEndpoint") != null %>
<section> <section>
<h2><a name="rsgroup">RSGroup</a></h2> <h2><a name="rsgroup">RSGroup</a></h2>
@ -270,6 +267,9 @@ AssignmentManager assignmentManager = master.getAssignmentManager();
<h2><a name="peers">Peers</a></h2> <h2><a name="peers">Peers</a></h2>
<& peerConfigs &> <& peerConfigs &>
</section> </section>
<%if master.getAssignmentManager() != null %>
<& AssignmentManagerStatusTmpl; assignmentManager=master.getAssignmentManager()&>
</%if>
<%else> <%else>
<section> <section>
<& BackupMasterStatusTmpl; master = master &> <& BackupMasterStatusTmpl; master = master &>
@ -534,9 +534,9 @@ AssignmentManager assignmentManager = master.getAssignmentManager();
</%if> </%if>
<td><% tableState.getState() %></td> <td><% tableState.getState() %></td>
<td><% openRegionsCount %></td> <td><% openRegionsCount %></td>
<%if (openingRegionsCount > 0) %> <td><a href="/rits.jsp?table=<% tableName.getNameAsString() %>&state=OPENING"><% openingRegionsCount %></td> <%else><td><% openingRegionsCount %></td> </%if> <td><% openingRegionsCount %></td>
<td><% closedRegionsCount %></td> <td><% closedRegionsCount %></td>
<%if (closingRegionsCount > 0) %> <td><a href="/rits.jsp?table=<% tableName.getNameAsString() %>&state=CLOSING"><% closingRegionsCount %></td> <%else><td><% closingRegionsCount %></td> </%if> <td><% closingRegionsCount %></td>
<td><% offlineRegionsCount %></td> <td><% offlineRegionsCount %></td>
<td><% failedRegionsCount %></td> <td><% failedRegionsCount %></td>
<td><% splitRegionsCount %></td> <td><% splitRegionsCount %></td>

View File

@ -1,120 +0,0 @@
<%--
/**
* 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="static org.apache.commons.lang3.StringEscapeUtils.escapeXml"
import="java.util.Collections"
import="java.util.Comparator"
import="java.util.List"
import="org.apache.hadoop.hbase.master.HMaster"
import="org.apache.hadoop.hbase.master.assignment.RegionStateNode"
%>
<%@ page import="java.util.stream.Collectors" %>
<%
HMaster master = (HMaster) getServletContext().getAttribute(HMaster.MASTER);
List<RegionStateNode> rit = master.getAssignmentManager().getRegionsInTransition();
String table = request.getParameter("table");
String state = request.getParameter("state");
if (table != null && state != null && !table.equals("null") && !state.equals("null")) {
rit = rit.stream().filter(regionStateNode -> regionStateNode.getTable().getNameAsString().equals(table))
.filter(regionStateNode -> regionStateNode.getState().name().equals(state))
.collect(Collectors.toList());
}
String format = request.getParameter("format");
if(format == null || format.isEmpty()){
format = "html";
}
String filter = request.getParameter("filter");
Collections.sort(rit, new Comparator<RegionStateNode>() {
@Override
public int compare(RegionStateNode o1, RegionStateNode o2) {
if (o1.getState() != o2.getState()){
return o1.getState().ordinal() - o2.getState().ordinal();
}
return o1.compareTo(o2);
}
});
%>
<% if (format.equals("html")) { %>
<jsp:include page="header.jsp">
<jsp:param name="pageTitle" value="${pageTitle}"/>
</jsp:include>
<div class="container-fluid content">
<div class="row">
<div class="page-header">
<h1>Regions in transition</h1>
</div>
</div>
<div class="row">
<div class="page-header">
<a href="/rits.jsp?format=txt&filter=region&table=<%=table%>&state=<%=state%>" class="btn btn-primary">Regions in text format</a>
<a href="/rits.jsp?format=txt&filter=procedure&table=<%=table%>&state=<%=state%>" class="btn btn-info">Procedures in text format</a>
<p>regions and procedures in text format can be copied and passed to command-line utils such as hbck2</p>
</div>
</div>
<% if (rit != null && rit.size() > 0) { %>
<table class="table table-striped">
<tr>
<th>Region</th>
<th>Table</th>
<th>RegionState</th>
<th>Procedure</th>
<th>ProcedureState</th>
</tr>
<% for (RegionStateNode regionStateNode : rit) { %>
<tr>
<td><%= regionStateNode.getRegionInfo().getEncodedName() %></td>
<td><%= regionStateNode.getRegionInfo().getTable() %></td>
<td><%= regionStateNode.getState() %></td>
<td><%= regionStateNode.getProcedure().getProcId() %></td>
<td><%= escapeXml(regionStateNode.getProcedure().getState().toString() + (regionStateNode.getProcedure().isBypass() ? "(Bypassed)" : "")) %></td>
</tr>
<% } %>
<p><%= rit.size() %> region(s) in transition.</p>
</table>
<% } else { %>
<p> no region in transition right now. </p>
<% } %>
</div>
<jsp:include page="footer.jsp" />
<% } else { %>
<div class="container-fluid content">
<div class="row">
<p>
<%
if (filter.equals("region")) {
for (RegionStateNode regionStateNode : rit) { %>
<%= regionStateNode.getRegionInfo().getEncodedName() %><br>
<% }
} else if (filter.equals("procedure")) {
for (RegionStateNode regionStateNode : rit) { %>
<%= regionStateNode.getProcedure().getProcId() %><br>
<% }
} else { %>
"Not a valid filter"
<% } %>
</p>
</div>
</div>
<% } %>