forked from D-Net/dnet-hadoop
Sarc stats almost finished. Have to look at sarcStats() method - INSERT INTO downloads_stats
This commit is contained in:
parent
2ae67cfdba
commit
03fb2b9e01
|
@ -11,8 +11,10 @@ import java.sql.ResultSet;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.sql.Statement;
|
import java.sql.Statement;
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
|
@ -66,7 +68,8 @@ public class SarcStats {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void processSarc() throws Exception {
|
public void processSarc(String sarcsReportPathArray, String sarcsReportPathNonArray,
|
||||||
|
String url, String issn) throws Exception {
|
||||||
Statement stmt = ConnectDB.getConnection().createStatement();
|
Statement stmt = ConnectDB.getConnection().createStatement();
|
||||||
ConnectDB.getConnection().setAutoCommit(false);
|
ConnectDB.getConnection().setAutoCommit(false);
|
||||||
|
|
||||||
|
@ -74,16 +77,16 @@ public class SarcStats {
|
||||||
stmt.executeUpdate("add jar /usr/share/cmf/common_jars/hive-hcatalog-core-1.1.0-cdh5.14.0.jar");
|
stmt.executeUpdate("add jar /usr/share/cmf/common_jars/hive-hcatalog-core-1.1.0-cdh5.14.0.jar");
|
||||||
System.out.println("====> Added JSON Serde jar");
|
System.out.println("====> Added JSON Serde jar");
|
||||||
|
|
||||||
System.out.println("====> Dropping sarc_sushilogtmp_json_array table");
|
System.out.println("====> Dropping sarc_sushilogtmp_json_array_" + issn.replace("-", "_") + " table");
|
||||||
String drop_sarc_sushilogtmp_json_array = "DROP TABLE IF EXISTS " +
|
String drop_sarc_sushilogtmp_json_array = "DROP TABLE IF EXISTS " +
|
||||||
ConnectDB.getUsageStatsDBSchema() +
|
ConnectDB.getUsageStatsDBSchema() +
|
||||||
".sarc_sushilogtmp_json_array";
|
".sarc_sushilogtmp_json_array_" + issn.replace("-", "_");
|
||||||
stmt.executeUpdate(drop_sarc_sushilogtmp_json_array);
|
stmt.executeUpdate(drop_sarc_sushilogtmp_json_array);
|
||||||
System.out.println("====> Dropped sarc_sushilogtmp_json_array table");
|
System.out.println("====> Dropped sarc_sushilogtmp_json_array_" + issn.replace("-", "_") + " table");
|
||||||
|
|
||||||
System.out.println("====> Creating sarc_sushilogtmp_json_array table");
|
System.out.println("====> Creating sarc_sushilogtmp_json_array_" + issn.replace("-", "_") + " table");
|
||||||
String create_sarc_sushilogtmp_json_array = "CREATE EXTERNAL TABLE IF NOT EXISTS " +
|
String create_sarc_sushilogtmp_json_array = "CREATE EXTERNAL TABLE IF NOT EXISTS " +
|
||||||
ConnectDB.getUsageStatsDBSchema() + ".sarc_sushilogtmp_json_array(\n" +
|
ConnectDB.getUsageStatsDBSchema() + ".sarc_sushilogtmp_json_array_" + issn.replace("-", "_") + "(\n" +
|
||||||
" `ItemIdentifier` ARRAY<\n" +
|
" `ItemIdentifier` ARRAY<\n" +
|
||||||
" struct<\n" +
|
" struct<\n" +
|
||||||
" `Type`: STRING,\n" +
|
" `Type`: STRING,\n" +
|
||||||
|
@ -102,21 +105,21 @@ public class SarcStats {
|
||||||
" >\n" +
|
" >\n" +
|
||||||
")" +
|
")" +
|
||||||
"ROW FORMAT SERDE 'org.apache.hive.hcatalog.data.JsonSerDe'\n" +
|
"ROW FORMAT SERDE 'org.apache.hive.hcatalog.data.JsonSerDe'\n" +
|
||||||
"LOCATION '" + UsageStatsExporter.sarcsReportPathArray + "'\n" +
|
"LOCATION '" + sarcsReportPathArray + "/" + issn + "'\n" +
|
||||||
"TBLPROPERTIES (\"transactional\"=\"false\")";
|
"TBLPROPERTIES (\"transactional\"=\"false\")";
|
||||||
stmt.executeUpdate(create_sarc_sushilogtmp_json_array);
|
stmt.executeUpdate(create_sarc_sushilogtmp_json_array);
|
||||||
System.out.println("====> Created sarc_sushilogtmp_json_array table");
|
System.out.println("====> Created sarc_sushilogtmp_json_array_" + issn.replace("-", "_") + " table");
|
||||||
|
|
||||||
System.out.println("====> Dropping sarc_sushilogtmp_json_non_array table");
|
System.out.println("====> Dropping sarc_sushilogtmp_json_non_array_" + issn.replace("-", "_") + " table");
|
||||||
String drop_sarc_sushilogtmp_json_non_array = "DROP TABLE IF EXISTS " +
|
String drop_sarc_sushilogtmp_json_non_array = "DROP TABLE IF EXISTS " +
|
||||||
ConnectDB.getUsageStatsDBSchema() +
|
ConnectDB.getUsageStatsDBSchema() +
|
||||||
".sarc_sushilogtmp_json_non_array";
|
".sarc_sushilogtmp_json_non_array_" + issn.replace("-", "_");
|
||||||
stmt.executeUpdate(drop_sarc_sushilogtmp_json_non_array);
|
stmt.executeUpdate(drop_sarc_sushilogtmp_json_non_array);
|
||||||
System.out.println("====> Dropped sarc_sushilogtmp_json_non_array table");
|
System.out.println("====> Dropped sarc_sushilogtmp_json_non_array_" + issn.replace("-", "_") + " table");
|
||||||
|
|
||||||
System.out.println("====> Creating sarc_sushilogtmp_json_non_array table");
|
System.out.println("====> Creating sarc_sushilogtmp_json_non_array_" + issn.replace("-", "_") + " table");
|
||||||
String create_sarc_sushilogtmp_json_non_array = "CREATE EXTERNAL TABLE IF NOT EXISTS " +
|
String create_sarc_sushilogtmp_json_non_array = "CREATE EXTERNAL TABLE IF NOT EXISTS " +
|
||||||
ConnectDB.getUsageStatsDBSchema() + ".sarc_sushilogtmp_json_non_array(\n" +
|
ConnectDB.getUsageStatsDBSchema() + ".sarc_sushilogtmp_json_non_array_" + issn.replace("-", "_") + "(\n" +
|
||||||
" `ItemIdentifier` struct<\n" +
|
" `ItemIdentifier` struct<\n" +
|
||||||
" `Type`: STRING,\n" +
|
" `Type`: STRING,\n" +
|
||||||
" `Value`: STRING\n" +
|
" `Value`: STRING\n" +
|
||||||
|
@ -133,94 +136,131 @@ public class SarcStats {
|
||||||
" >" +
|
" >" +
|
||||||
")" +
|
")" +
|
||||||
"ROW FORMAT SERDE 'org.apache.hive.hcatalog.data.JsonSerDe'\n" +
|
"ROW FORMAT SERDE 'org.apache.hive.hcatalog.data.JsonSerDe'\n" +
|
||||||
"LOCATION '" + UsageStatsExporter.sarcsReportPathNonArray + "'\n" +
|
"LOCATION '" + sarcsReportPathNonArray + "/" + issn + "'\n" +
|
||||||
"TBLPROPERTIES (\"transactional\"=\"false\")";
|
"TBLPROPERTIES (\"transactional\"=\"false\")";
|
||||||
stmt.executeUpdate(create_sarc_sushilogtmp_json_non_array);
|
stmt.executeUpdate(create_sarc_sushilogtmp_json_non_array);
|
||||||
System.out.println("====> Created sarc_sushilogtmp_json_non_array table");
|
System.out.println("====> Created sarc_sushilogtmp_json_non_array_" + issn.replace("-", "_") + " table");
|
||||||
|
|
||||||
// System.out.println("====> Dropping sarc_sushilogtmp table");
|
System.out.println("====> Creating sarc_sushilogtmp table");
|
||||||
// String drop_sarc_sushilogtmp = "DROP TABLE IF EXISTS " +
|
String create_sarc_sushilogtmp = "CREATE TABLE " + ConnectDB.getUsageStatsDBSchema()
|
||||||
// ConnectDB.getUsageStatsDBSchema() +
|
+ ".sarc_sushilogtmp(source STRING, repository STRING, " +
|
||||||
// ".sushilogtmp";
|
"rid STRING, date STRING, metric_type STRING, count INT) clustered by (source) into 100 buckets stored as orc "
|
||||||
// stmt.executeUpdate(drop_sarc_sushilogtmp);
|
+
|
||||||
// System.out.println("====> Dropped sarc_sushilogtmp table");
|
"tblproperties('transactional'='true')";
|
||||||
|
stmt.executeUpdate(create_sarc_sushilogtmp);
|
||||||
|
System.out.println("====> Created sarc_sushilogtmp table");
|
||||||
|
|
||||||
|
// "INSERT INTO sushilog (source, repository, rid, date, metric_type, count) VALUES (?,?,?,?,?,?)");
|
||||||
|
|
||||||
|
// JSONObject itemPerformance = (JSONObject) jsonObjectRow.get("c:ItemPerformance");
|
||||||
|
// // for (Object perf : itemPerformance) {
|
||||||
|
// JSONObject performance = (JSONObject) itemPerformance;
|
||||||
|
// JSONObject periodObj = (JSONObject) performance.get("c:Period");
|
||||||
|
// String period = periodObj.get("c:Begin").toString();
|
||||||
|
// JSONObject instanceObj = (JSONObject) performance.get("c:Instance");
|
||||||
|
// String type = instanceObj.get("c:MetricType").toString();
|
||||||
|
// String count = instanceObj.get("c:Count").toString();
|
||||||
|
// // System.out.println(rid + " : " + period + " : " + count);
|
||||||
//
|
//
|
||||||
// System.out.println("====> Creating sarc_sushilogtmp table");
|
// preparedStatement.setString(1, "SARC-OJS");
|
||||||
// String create_sarc_sushilogtmp = "CREATE TABLE " + ConnectDB.getUsageStatsDBSchema()
|
// preparedStatement.setString(2, issn);
|
||||||
// + ".sarc_sushilogtmp(source STRING, repository STRING, " +
|
// // preparedStatement.setString(2, url);
|
||||||
// "rid STRING, date STRING, metric_type STRING, count INT) clustered by (source) into 100 buckets stored as orc "
|
// preparedStatement.setString(3, rid);
|
||||||
// +
|
// preparedStatement.setString(4, period);
|
||||||
// "tblproperties('transactional'='true')";
|
// preparedStatement.setString(5, type);
|
||||||
// stmt.executeUpdate(create_sarc_sushilogtmp);
|
// preparedStatement.setInt(6, Integer.parseInt(count));
|
||||||
// System.out.println("====> Created sarc_sushilogtmp table");
|
|
||||||
//
|
System.out.println("====> Inserting to sarc_sushilogtmp table (sarc_sushilogtmp_json_array)");
|
||||||
// System.out.println("====> Inserting to sarc_sushilogtmp table");
|
String insert_sarc_sushilogtmp = "INSERT INTO " + ConnectDB.getUsageStatsDBSchema() + ".sarc_sushilogtmp " +
|
||||||
// String insert_sarc_sushilogtmp = "INSERT INTO " + ConnectDB.getUsageStatsDBSchema() + ".sarc_sushilogtmp " +
|
"SELECT 'SARC-OJS', '" + issn + "' , `ItemIdent`.`Value`, `ItemPerformance`.`Period`.`Begin`, " +
|
||||||
// "SELECT 'IRUS-UK', 'opendoar____::', `ItemIdent`.`Value`, `ItemPerf`.`Period`.`Begin`, " +
|
"`ItemPerformance`.`Instance`.`MetricType`, `ItemPerformance`.`Instance`.`Count` " +
|
||||||
// "`ItemPerf`.`Instance`.`MetricType`, `ItemPerf`.`Instance`.`Count` " +
|
"FROM " + ConnectDB.getUsageStatsDBSchema() + ".sarc_sushilogtmp_json_array_" + issn.replace("-", "_") + " "
|
||||||
// "FROM " + ConnectDB.getUsageStatsDBSchema() + ".sushilogtmp_json " +
|
+
|
||||||
// "LATERAL VIEW posexplode(ItemIdentifier) ItemIdentifierTable AS seqi, ItemIdent " +
|
"LATERAL VIEW posexplode(ItemIdentifier) ItemIdentifierTable AS seqi, ItemIdent ";
|
||||||
// "LATERAL VIEW posexplode(ItemPerformance) ItemPerformanceTable AS seqp, ItemPerf " +
|
stmt.executeUpdate(insert_sarc_sushilogtmp);
|
||||||
// "WHERE `ItemIdent`.`Type`= 'OAI'";
|
System.out.println("====> Inserted to sarc_sushilogtmp table (sarc_sushilogtmp_json_array)");
|
||||||
// stmt.executeUpdate(insert_sarc_sushilogtmp);
|
|
||||||
// System.out.println("====> Inserted to sarc_sushilogtmp table");
|
System.out.println("====> Inserting to sarc_sushilogtmp table (sarc_sushilogtmp_json_non_array)");
|
||||||
|
insert_sarc_sushilogtmp = "INSERT INTO " + ConnectDB.getUsageStatsDBSchema() + ".sarc_sushilogtmp " +
|
||||||
|
"SELECT 'SARC-OJS', '" + issn + "' , `ItemIdentifier`.`Value`, `ItemPerformance`.`Period`.`Begin`, " +
|
||||||
|
"`ItemPerformance`.`Instance`.`MetricType`, `ItemPerformance`.`Instance`.`Count` " +
|
||||||
|
"FROM " + ConnectDB.getUsageStatsDBSchema() + ".sarc_sushilogtmp_json_non_array_" + issn.replace("-", "_");
|
||||||
|
stmt.executeUpdate(insert_sarc_sushilogtmp);
|
||||||
|
System.out.println("====> Inserted to sarc_sushilogtmp table (sarc_sushilogtmp_json_non_array)");
|
||||||
|
|
||||||
ConnectDB.getConnection().close();
|
ConnectDB.getConnection().close();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void getSarc(String sarcsReportPathArray, String sarcsReportPathNonArray) throws Exception {
|
public void getAndProcessSarc(String sarcsReportPathArray, String sarcsReportPathNonArray) throws Exception {
|
||||||
// There was a problem to download the following file
|
|
||||||
getARReport(
|
Statement stmt = ConnectDB.getConnection().createStatement();
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/motricidade/sushiLite/v1_7/",
|
ConnectDB.getConnection().setAutoCommit(false);
|
||||||
"1646-107X");
|
System.out.println("====> Dropping sarc_sushilogtmp table");
|
||||||
getARReport(
|
String drop_sarc_sushilogtmp = "DROP TABLE IF EXISTS " +
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/antropologicas/sushiLite/v1_7/",
|
ConnectDB.getUsageStatsDBSchema() +
|
||||||
"0873-819X");
|
".sarc_sushilogtmp";
|
||||||
getARReport(
|
stmt.executeUpdate(drop_sarc_sushilogtmp);
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/interaccoes/sushiLite/v1_7/",
|
System.out.println("====> Dropped sarc_sushilogtmp table");
|
||||||
"1646-2335");
|
ConnectDB.getConnection().close();
|
||||||
getARReport(
|
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/cct/sushiLite/v1_7/",
|
List<String[]> issnAndUrls = new ArrayList<String[]>();
|
||||||
"2182-3030");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://revistas.rcaap.pt/motricidade/sushiLite/v1_7/", "1646-107X"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://actapediatrica.spp.pt/sushiLite/v1_7/",
|
});
|
||||||
"0873-9781");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://revistas.rcaap.pt/antropologicas/sushiLite/v1_7/", "0873-819X"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/sociologiapp/sushiLite/v1_7/",
|
});
|
||||||
"0873-6529");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://revistas.rcaap.pt/interaccoes/sushiLite/v1_7/", "1646-2335"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/finisterra/sushiLite/v1_7/",
|
});
|
||||||
"0430-5027");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://revistas.rcaap.pt/cct/sushiLite/v1_7/", "2182-3030"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/sisyphus/sushiLite/v1_7/",
|
});
|
||||||
"2182-8474");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://actapediatrica.spp.pt/sushiLite/v1_7/", "0873-9781"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/anestesiologia/sushiLite/v1_7/",
|
});
|
||||||
"0871-6099");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://revistas.rcaap.pt/sociologiapp/sushiLite/v1_7/", "0873-6529"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/rpe/sushiLite/v1_7/",
|
});
|
||||||
"0871-9187");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://revistas.rcaap.pt/finisterra/sushiLite/v1_7/", "0430-5027"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/psilogos/sushiLite/v1_7/",
|
});
|
||||||
"1646-091X");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://revistas.rcaap.pt/sisyphus/sushiLite/v1_7/", "2182-8474"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/juridica/sushiLite/v1_7/",
|
});
|
||||||
"2183-5799");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://revistas.rcaap.pt/anestesiologia/sushiLite/v1_7/", "0871-6099"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/ecr/sushiLite/v1_7/",
|
});
|
||||||
"1647-2098");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://revistas.rcaap.pt/rpe/sushiLite/v1_7/", "0871-9187"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/nascercrescer/sushiLite/v1_7/",
|
});
|
||||||
"0872-0754");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://revistas.rcaap.pt/psilogos/sushiLite/v1_7/", "1646-091X"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/cea/sushiLite/v1_7/",
|
});
|
||||||
"1645-3794");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://revistas.rcaap.pt/juridica/sushiLite/v1_7/", "2183-5799"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/proelium/sushiLite/v1_7/",
|
});
|
||||||
"1645-8826");
|
issnAndUrls.add(new String[] {
|
||||||
getARReport(
|
"https://revistas.rcaap.pt/ecr/sushiLite/v1_7/", "1647-2098"
|
||||||
sarcsReportPathArray, sarcsReportPathNonArray, "https://revistas.rcaap.pt/millenium/sushiLite/v1_7/",
|
});
|
||||||
"0873-3015");
|
issnAndUrls.add(new String[] {
|
||||||
|
"https://revistas.rcaap.pt/nascercrescer/sushiLite/v1_7/", "0872-0754"
|
||||||
|
});
|
||||||
|
issnAndUrls.add(new String[] {
|
||||||
|
"https://revistas.rcaap.pt/cea/sushiLite/v1_7/", "1645-3794"
|
||||||
|
});
|
||||||
|
issnAndUrls.add(new String[] {
|
||||||
|
"https://revistas.rcaap.pt/proelium/sushiLite/v1_7/", "1645-8826"
|
||||||
|
});
|
||||||
|
issnAndUrls.add(new String[] {
|
||||||
|
"https://revistas.rcaap.pt/millenium/sushiLite/v1_7/", "0873-3015"
|
||||||
|
});
|
||||||
|
|
||||||
|
for (String[] issnAndUrl : issnAndUrls) {
|
||||||
|
getARReport(sarcsReportPathArray, sarcsReportPathNonArray, issnAndUrl[0], issnAndUrl[1]);
|
||||||
|
processSarc(sarcsReportPathArray, sarcsReportPathNonArray, issnAndUrl[0], issnAndUrl[1]);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void sarcStats() throws Exception {
|
public void sarcStats() throws Exception {
|
||||||
|
@ -275,6 +315,10 @@ public class SarcStats {
|
||||||
"INSERT INTO sushilog (source, repository, rid, date, metric_type, count) VALUES (?,?,?,?,?,?)");
|
"INSERT INTO sushilog (source, repository, rid, date, metric_type, count) VALUES (?,?,?,?,?,?)");
|
||||||
int batch_size = 0;
|
int batch_size = 0;
|
||||||
|
|
||||||
|
// Creating the directory to save the files
|
||||||
|
new File(sarcsReportPathArray + "/" + issn).mkdirs();
|
||||||
|
new File(sarcsReportPathNonArray + "/" + issn).mkdirs();
|
||||||
|
|
||||||
while (start.before(end)) {
|
while (start.before(end)) {
|
||||||
// String reportUrl =
|
// String reportUrl =
|
||||||
// "http://irus.mimas.ac.uk/api/sushilite/v1_7/GetReport/?Report=IR1&Release=4&RequestorID=OpenAIRE&BeginDate="
|
// "http://irus.mimas.ac.uk/api/sushilite/v1_7/GetReport/?Report=IR1&Release=4&RequestorID=OpenAIRE&BeginDate="
|
||||||
|
@ -329,19 +373,18 @@ public class SarcStats {
|
||||||
|
|
||||||
// Creating the file in the filesystem for the ItemIdentifier as array object
|
// Creating the file in the filesystem for the ItemIdentifier as array object
|
||||||
FileSystem fsArray = FileSystem.get(new Configuration());
|
FileSystem fsArray = FileSystem.get(new Configuration());
|
||||||
String filePathArray = sarcsReportPathArray + "/" + "SarcsARReport_" + issn + "_" +
|
String filePathArray = sarcsReportPathArray + "/" + issn + "/" + "SarcsARReport" +
|
||||||
simpleDateFormat.format(start.getTime()) + ".json";
|
simpleDateFormat.format(start.getTime()) + ".json";
|
||||||
System.out.println("Storing to file: " + filePathArray);
|
System.out.println("Storing to file: " + filePathArray);
|
||||||
FSDataOutputStream finArray = fsArray.create(new Path(filePathArray), true);
|
FSDataOutputStream finArray = fsArray.create(new Path(filePathArray), true);
|
||||||
|
|
||||||
// Creating the file in the filesystem for the ItemIdentifier as array object
|
// Creating the file in the filesystem for the ItemIdentifier as array object
|
||||||
FileSystem fsNonArray = FileSystem.get(new Configuration());
|
FileSystem fsNonArray = FileSystem.get(new Configuration());
|
||||||
String filePathNonArray = sarcsReportPathNonArray + "/" + "SarcsARReport_" + issn + "_" +
|
String filePathNonArray = sarcsReportPathNonArray + "/" + issn + "/" + "SarcsARReport" +
|
||||||
simpleDateFormat.format(start.getTime()) + ".json";
|
simpleDateFormat.format(start.getTime()) + ".json";
|
||||||
System.out.println("Storing to file: " + filePathNonArray);
|
System.out.println("Storing to file: " + filePathNonArray);
|
||||||
FSDataOutputStream finNonArray = fsNonArray.create(new Path(filePathNonArray), true);
|
FSDataOutputStream finNonArray = fsNonArray.create(new Path(filePathNonArray), true);
|
||||||
|
|
||||||
String rid = "";
|
|
||||||
for (Object aJsonArray : jsonArray) {
|
for (Object aJsonArray : jsonArray) {
|
||||||
|
|
||||||
JSONObject jsonObjectRow = (JSONObject) aJsonArray;
|
JSONObject jsonObjectRow = (JSONObject) aJsonArray;
|
||||||
|
@ -357,15 +400,17 @@ public class SarcStats {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (finArray.size() == 0)
|
|
||||||
fsArray.deleteOnExit(new Path(filePathArray));
|
|
||||||
|
|
||||||
if (finNonArray.size() == 0)
|
|
||||||
fsNonArray.deleteOnExit(new Path(filePathNonArray));
|
|
||||||
|
|
||||||
finArray.close();
|
finArray.close();
|
||||||
finNonArray.close();
|
finNonArray.close();
|
||||||
|
|
||||||
|
// Check the file size and if it is too big, delete it
|
||||||
|
File fileArray = new File(filePathArray);
|
||||||
|
if (fileArray.length() == 0)
|
||||||
|
fileArray.delete();
|
||||||
|
File fileNonArray = new File(filePathNonArray);
|
||||||
|
if (fileNonArray.length() == 0)
|
||||||
|
fileNonArray.delete();
|
||||||
|
|
||||||
//////////////////
|
//////////////////
|
||||||
// JSONObject jsonObjectRow = (JSONObject) aJsonArray;
|
// JSONObject jsonObjectRow = (JSONObject) aJsonArray;
|
||||||
// JSONArray itemIdentifier = new JSONArray();
|
// JSONArray itemIdentifier = new JSONArray();
|
||||||
|
|
|
@ -60,8 +60,7 @@ public class UsageStatsExporter {
|
||||||
// log.info("irus done");
|
// log.info("irus done");
|
||||||
|
|
||||||
SarcStats sarcStats = new SarcStats();
|
SarcStats sarcStats = new SarcStats();
|
||||||
// sarcStats.getSarc(sarcsReportPathArray, sarcsReportPathNonArray);
|
sarcStats.getAndProcessSarc(sarcsReportPathArray, sarcsReportPathNonArray);
|
||||||
sarcStats.processSarc();
|
|
||||||
// sarcStats.sarcStats();
|
// sarcStats.sarcStats();
|
||||||
log.info("sarc done");
|
log.info("sarc done");
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue