2015-08-10 22:18:00 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* Licensed 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.
|
|
|
|
*/
|
2010-04-14 20:32:20 +00:00
|
|
|
|
2015-11-18 21:46:33 +00:00
|
|
|
#include <thread>
|
|
|
|
|
2014-06-25 21:38:07 +00:00
|
|
|
#include <base/at_exit.h>
|
2014-04-21 21:33:32 +00:00
|
|
|
#include <base/command_line.h>
|
2015-11-13 01:52:17 +00:00
|
|
|
#include <base/files/file_path.h>
|
2011-02-28 19:17:43 +00:00
|
|
|
#include <base/logging.h>
|
2015-11-18 21:46:33 +00:00
|
|
|
#include <base/metrics/statistics_recorder.h>
|
2014-02-06 07:26:25 +00:00
|
|
|
#include <base/strings/string_util.h>
|
2015-11-13 01:52:17 +00:00
|
|
|
#include <base/time/time.h>
|
2015-10-13 16:23:34 +00:00
|
|
|
#include <brillo/flag_helper.h>
|
|
|
|
#include <brillo/syslog_logging.h>
|
2010-04-14 20:32:20 +00:00
|
|
|
|
2015-08-04 21:04:51 +00:00
|
|
|
#include "constants.h"
|
2015-11-18 21:46:33 +00:00
|
|
|
#include "uploader/bn_metricsd_impl.h"
|
|
|
|
#include "uploader/crash_counters.h"
|
2015-11-13 01:52:17 +00:00
|
|
|
#include "uploader/upload_service.h"
|
2010-04-14 20:32:20 +00:00
|
|
|
|
|
|
|
int main(int argc, char** argv) {
|
2015-11-06 21:25:41 +00:00
|
|
|
DEFINE_bool(foreground, false, "Don't daemonize");
|
2014-10-06 22:15:30 +00:00
|
|
|
|
|
|
|
// Upload the metrics once and exit. (used for testing)
|
2015-11-18 21:46:33 +00:00
|
|
|
DEFINE_bool(uploader_test, false, "run the uploader once and exit");
|
2014-10-06 22:15:30 +00:00
|
|
|
|
|
|
|
// Upload Service flags.
|
2015-11-18 21:46:33 +00:00
|
|
|
DEFINE_int32(upload_interval_secs, 1800,
|
2014-10-06 22:15:30 +00:00
|
|
|
"Interval at which metrics_daemon sends the metrics. (needs "
|
|
|
|
"-uploader)");
|
2015-11-18 21:46:33 +00:00
|
|
|
DEFINE_string(server, metrics::kMetricsServer,
|
2014-10-06 22:15:30 +00:00
|
|
|
"Server to upload the metrics to. (needs -uploader)");
|
2015-11-25 21:49:12 +00:00
|
|
|
DEFINE_string(private_directory, metrics::kMetricsdDirectory,
|
|
|
|
"Path to the private directory used by metricsd "
|
|
|
|
"(testing only)");
|
|
|
|
DEFINE_string(shared_directory, metrics::kSharedMetricsDirectory,
|
|
|
|
"Path to the shared metrics directory, used by "
|
|
|
|
"metrics_collector, metricsd and all metrics clients "
|
|
|
|
"(testing only)");
|
2014-10-06 22:15:30 +00:00
|
|
|
|
2015-11-06 21:25:41 +00:00
|
|
|
DEFINE_bool(logtostderr, false, "Log to standard error");
|
|
|
|
DEFINE_bool(logtosyslog, false, "Log to syslog");
|
|
|
|
|
2015-11-13 01:52:17 +00:00
|
|
|
brillo::FlagHelper::Init(argc, argv, "Brillo metrics daemon.");
|
2014-04-21 21:33:32 +00:00
|
|
|
|
2015-11-18 21:46:33 +00:00
|
|
|
int logging_location =
|
|
|
|
(FLAGS_foreground ? brillo::kLogToStderr : brillo::kLogToSyslog);
|
2015-11-06 21:25:41 +00:00
|
|
|
if (FLAGS_logtosyslog)
|
|
|
|
logging_location = brillo::kLogToSyslog;
|
|
|
|
|
|
|
|
if (FLAGS_logtostderr)
|
|
|
|
logging_location = brillo::kLogToStderr;
|
|
|
|
|
2014-04-21 21:33:32 +00:00
|
|
|
// Also log to stderr when not running as daemon.
|
2015-11-06 21:25:41 +00:00
|
|
|
brillo::InitLog(logging_location | brillo::kLogHeader);
|
|
|
|
|
|
|
|
if (FLAGS_logtostderr && FLAGS_logtosyslog) {
|
|
|
|
LOG(ERROR) << "only one of --logtosyslog and --logtostderr can be set";
|
|
|
|
return 1;
|
|
|
|
}
|
2014-12-01 21:38:21 +00:00
|
|
|
|
2015-11-06 21:25:41 +00:00
|
|
|
if (!FLAGS_foreground && daemon(0, 0) != 0) {
|
2014-12-01 21:38:21 +00:00
|
|
|
return errno;
|
|
|
|
}
|
|
|
|
|
2015-11-18 21:46:33 +00:00
|
|
|
std::shared_ptr<CrashCounters> counters(new CrashCounters);
|
|
|
|
|
|
|
|
UploadService upload_service(
|
2015-11-25 21:49:12 +00:00
|
|
|
FLAGS_server, base::TimeDelta::FromSeconds(FLAGS_upload_interval_secs),
|
|
|
|
base::FilePath(FLAGS_private_directory),
|
2015-11-18 21:46:33 +00:00
|
|
|
base::FilePath(FLAGS_shared_directory), counters);
|
|
|
|
|
|
|
|
base::StatisticsRecorder::Initialize();
|
|
|
|
|
|
|
|
// Create and start the binder thread.
|
|
|
|
BnMetricsdImpl binder_service(counters);
|
|
|
|
std::thread binder_thread(&BnMetricsdImpl::Run, &binder_service);
|
2014-06-25 21:38:07 +00:00
|
|
|
|
2015-11-18 21:46:33 +00:00
|
|
|
upload_service.Run();
|
2010-04-14 20:32:20 +00:00
|
|
|
}
|