Revert "YARN-9255. Improve recommend applications order and fix findbugs warnings. Contributed by Eric Yang"

This reverts commit aab7b77536.
This commit is contained in:
Billie Rinaldi 2019-03-12 11:48:55 -07:00
parent c449cdebe6
commit 024b3bae8a
4 changed files with 18 additions and 103 deletions

View File

@ -38,7 +38,6 @@
import org.apache.commons.logging.LogFactory; import org.apache.commons.logging.LogFactory;
import org.apache.solr.client.solrj.SolrClient; import org.apache.solr.client.solrj.SolrClient;
import org.apache.solr.client.solrj.SolrQuery; import org.apache.solr.client.solrj.SolrQuery;
import org.apache.solr.client.solrj.SolrQuery.ORDER;
import org.apache.solr.client.solrj.SolrServerException; import org.apache.solr.client.solrj.SolrServerException;
import org.apache.solr.client.solrj.impl.HttpSolrClient; import org.apache.solr.client.solrj.impl.HttpSolrClient;
import org.apache.solr.client.solrj.response.QueryResponse; import org.apache.solr.client.solrj.response.QueryResponse;
@ -65,16 +64,12 @@ public AppCatalogSolrClient() {
Properties properties = new Properties(); Properties properties = new Properties();
try { try {
properties.load(input); properties.load(input);
setSolrUrl(properties.getProperty("solr_url")); urlString = properties.getProperty("solr_url");
} catch (IOException e) { } catch (IOException e) {
LOG.error("Error reading appcatalog configuration: ", e); LOG.error("Error reading appcatalog configuration: ", e);
} }
} }
private synchronized static void setSolrUrl(String url) {
urlString = url;
}
public SolrClient getSolrClient() { public SolrClient getSolrClient() {
return new HttpSolrClient.Builder(urlString).build(); return new HttpSolrClient.Builder(urlString).build();
} }
@ -84,7 +79,6 @@ public List<AppStoreEntry> getRecommendedApps() {
SolrClient solr = getSolrClient(); SolrClient solr = getSolrClient();
SolrQuery query = new SolrQuery(); SolrQuery query = new SolrQuery();
query.setQuery("*:*"); query.setQuery("*:*");
query.setSort("download_i", ORDER.desc);
query.setFilterQueries("type_s:AppStoreEntry"); query.setFilterQueries("type_s:AppStoreEntry");
query.setRows(40); query.setRows(40);
QueryResponse response; QueryResponse response;
@ -101,8 +95,8 @@ public List<AppStoreEntry> getRecommendedApps() {
if (d.get("icon_s")!=null) { if (d.get("icon_s")!=null) {
entry.setIcon(d.get("icon_s").toString()); entry.setIcon(d.get("icon_s").toString());
} }
entry.setLike(Integer.parseInt(d.get("like_i").toString())); entry.setLike(Integer.valueOf(d.get("like_i").toString()));
entry.setDownload(Integer.parseInt(d.get("download_i").toString())); entry.setDownload(Integer.valueOf(d.get("download_i").toString()));
apps.add(entry); apps.add(entry);
} }
} catch (SolrServerException | IOException e) { } catch (SolrServerException | IOException e) {
@ -134,8 +128,8 @@ public List<AppStoreEntry> search(String keyword) {
entry.setOrg(d.get("org_s").toString()); entry.setOrg(d.get("org_s").toString());
entry.setName(d.get("name_s").toString()); entry.setName(d.get("name_s").toString());
entry.setDesc(d.get("desc_s").toString()); entry.setDesc(d.get("desc_s").toString());
entry.setLike(Integer.parseInt(d.get("like_i").toString())); entry.setLike(Integer.valueOf(d.get("like_i").toString()));
entry.setDownload(Integer.parseInt(d.get("download_i").toString())); entry.setDownload(Integer.valueOf(d.get("download_i").toString()));
apps.add(entry); apps.add(entry);
} }
} catch (SolrServerException | IOException e) { } catch (SolrServerException | IOException e) {
@ -195,8 +189,8 @@ public AppStoreEntry findAppStoreEntry(String id) {
entry.setOrg(d.get("org_s").toString()); entry.setOrg(d.get("org_s").toString());
entry.setName(d.get("name_s").toString()); entry.setName(d.get("name_s").toString());
entry.setDesc(d.get("desc_s").toString()); entry.setDesc(d.get("desc_s").toString());
entry.setLike(Integer.parseInt(d.get("like_i").toString())); entry.setLike(Integer.valueOf(d.get("like_i").toString()));
entry.setDownload(Integer.parseInt(d.get("download_i").toString())); entry.setDownload(Integer.valueOf(d.get("download_i").toString()));
Service yarnApp = mapper.readValue(d.get("yarnfile_s").toString(), Service yarnApp = mapper.readValue(d.get("yarnfile_s").toString(),
Service.class); Service.class);
String name; String name;
@ -269,8 +263,8 @@ public void deployApp(String id, Service service) throws SolrServerException,
entry.setOrg(d.get("org_s").toString()); entry.setOrg(d.get("org_s").toString());
entry.setName(d.get("name_s").toString()); entry.setName(d.get("name_s").toString());
entry.setDesc(d.get("desc_s").toString()); entry.setDesc(d.get("desc_s").toString());
entry.setLike(Integer.parseInt(d.get("like_i").toString())); entry.setLike(Integer.valueOf(d.get("like_i").toString()));
entry.setDownload(Integer.parseInt(d.get("download_i").toString())); entry.setDownload(Integer.valueOf(d.get("download_i").toString()));
download = entry.getDownload() + 1; download = entry.getDownload() + 1;
// Update download count // Update download count
@ -309,8 +303,7 @@ private SolrInputDocument incrementDownload(SolrDocument doc,
s.addField(name, doc.getFieldValues(name)); s.addField(name, doc.getFieldValues(name));
} }
} }
download++; s.setField("download_i", download++);
s.setField("download_i", download);
return s; return s;
} }
@ -363,42 +356,4 @@ public void register(Application app) throws IOException {
} }
} }
protected void register(AppStoreEntry app) throws IOException {
Collection<SolrInputDocument> docs = new HashSet<SolrInputDocument>();
SolrClient solr = getSolrClient();
ObjectMapper mapper = new ObjectMapper();
mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
try {
SolrInputDocument buffer = new SolrInputDocument();
buffer.setField("id", java.util.UUID.randomUUID().toString()
.substring(0, 11));
buffer.setField("org_s", app.getOrg());
buffer.setField("name_s", app.getName());
buffer.setField("desc_s", app.getDesc());
if (app.getIcon() != null) {
buffer.setField("icon_s", app.getIcon());
}
buffer.setField("type_s", "AppStoreEntry");
buffer.setField("like_i", app.getLike());
buffer.setField("download_i", app.getDownload());
// Keep only YARN data model for yarnfile field
String yarnFile = mapper.writeValueAsString(app);
LOG.info("app:"+yarnFile);
Service yarnApp = mapper.readValue(yarnFile, Service.class);
buffer.setField("yarnfile_s", mapper.writeValueAsString(yarnApp));
docs.add(buffer);
// Commit Solr changes.
UpdateResponse detailsResponse = solr.add(docs);
if (detailsResponse.getStatus() != 0) {
throw new IOException("Unable to register application " +
"in Application Store.");
}
solr.commit();
} catch (SolrServerException | IOException e) {
throw new IOException("Unable to register application " +
"in Application Store. "+ e.getMessage());
}
}
} }

View File

@ -51,26 +51,26 @@ public void setVersion(String version) {
} }
public String[] getPorts() { public String[] getPorts() {
return ports.clone(); return ports;
} }
public void setPorts(String[] ports2) { public void setPorts(String[] ports2) {
this.ports = ports2.clone(); this.ports = ports2;
} }
public String[] getVolumes() { public String[] getVolumes() {
return volumes.clone(); return volumes;
} }
public void setVolumes(String[] volumes) { public void setVolumes(String[] volumes) {
this.volumes = volumes.clone(); this.volumes = volumes;
} }
public String[] getEnv() { public String[] getEnv() {
return env.clone(); return env;
} }
public void setEnv(String[] env) { public void setEnv(String[] env) {
this.env = env.clone(); this.env = env;
} }
} }

View File

@ -18,8 +18,6 @@
package org.apache.hadoop.yarn.appcatalog.model; package org.apache.hadoop.yarn.appcatalog.model;
import java.util.Objects;
import javax.xml.bind.annotation.XmlRootElement; import javax.xml.bind.annotation.XmlRootElement;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties; import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
@ -66,24 +64,4 @@ public void setIcon(String icon) {
this.icon = icon; this.icon = icon;
} }
@Override
public boolean equals(final Object obj) {
if (obj == this) {
return true;
} else if ((obj instanceof Application)) {
if (((Application) obj).getName().equals(this.getName())
&& ((Application) obj).getVersion().equals(this.getVersion())
&& ((Application) obj).getOrganization()
.equals(this.getOrganization())) {
return true;
}
}
return false;
}
@Override
public int hashCode() {
return Objects
.hash(this.getName() + this.getVersion() + this.getOrganization());
}
} }

View File

@ -104,27 +104,9 @@ public void testNotFoundSearch() throws Exception {
@Test @Test
public void testGetRecommendedApps() throws Exception { public void testGetRecommendedApps() throws Exception {
AppStoreEntry example = new AppStoreEntry(); List<AppStoreEntry> expected = spy.getRecommendedApps();
example.setOrg("jenkins-ci.org");
example.setName("jenkins");
example.setDesc("World leading open source automation system.");
example.setIcon("/css/img/feather.png");
example.setDownload(100);
spy.register(example);
AppStoreEntry example2 = new AppStoreEntry();
example2.setOrg("Apache");
example2.setName("httpd");
example2.setDesc("Apache webserver");
example2.setIcon("/css/img/feather.png");
example2.setDownload(1);
spy.register(example2);
List<AppStoreEntry> actual = spy.getRecommendedApps(); List<AppStoreEntry> actual = spy.getRecommendedApps();
long previous = 1000L; assertEquals(expected, actual);
for (AppStoreEntry app: actual) {
assertTrue("Recommend app is not sort by download count.",
previous > app.getDownload());
previous = app.getDownload();
}
} }
} }