Skip to content

Commit

Permalink
Revert "[Enhancement](Log) Reduce usage of log fatal(PART I) (apache#…
Browse files Browse the repository at this point in the history
…42344)"

This reverts commit 55c26e0.
  • Loading branch information
wangbo committed Dec 19, 2024
1 parent 55c26e0 commit 1d937b2
Show file tree
Hide file tree
Showing 71 changed files with 282 additions and 250 deletions.
11 changes: 1 addition & 10 deletions be/src/common/status.h
Original file line number Diff line number Diff line change
Expand Up @@ -293,8 +293,7 @@ namespace ErrorCode {
E(ENTRY_NOT_FOUND, -7002, false); \
E(INVALID_TABLET_STATE, -7211, false); \
E(ROWSETS_EXPIRED, -7311, false); \
E(CGROUP_ERROR, -7411, false); \
E(FATAL_ERROR, -7412, false);
E(CGROUP_ERROR, -7411, false);

// Define constexpr int error_code_name = error_code_value
#define M(NAME, ERRORCODE, ENABLESTACKTRACE) constexpr int NAME = ERRORCODE;
Expand Down Expand Up @@ -447,14 +446,6 @@ class [[nodiscard]] Status {

static Status OK() { return {}; }

template <bool stacktrace = true, typename... Args>
static Status FatalError(std::string_view msg, Args&&... args) {
#ifndef NDEBUG
LOG(FATAL) << fmt::format(msg, std::forward<Args>(args)...);
#endif
return Error<ErrorCode::FATAL_ERROR, stacktrace>(msg, std::forward<Args>(args)...);
}

// default have stacktrace. could disable manually.
#define ERROR_CTOR(name, code) \
template <bool stacktrace = true, typename... Args> \
Expand Down
5 changes: 1 addition & 4 deletions be/src/gutil/strings/escaping.cc
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,6 @@
#include <limits>
#include <ostream>

#include "common/exception.h"

using std::numeric_limits;
#include <vector>

Expand Down Expand Up @@ -1086,8 +1084,7 @@ int Base64UnescapeInternal(const char* src, int szsrc, char* dest, int szdest,

default:
// state should have no other values at this point.
throw doris::Exception(
doris::Status::FatalError("This can't happen; base64 decoder state = {}", state));
LOG(FATAL) << "This can't happen; base64 decoder state = " << state;
}

// The remainder of the string should be all whitespace, mixed with
Expand Down
6 changes: 2 additions & 4 deletions be/src/gutil/strings/numbers.cc
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,6 @@
#include <limits>
#include <ostream>

#include "common/exception.h"

using std::numeric_limits;
#include <string>

Expand Down Expand Up @@ -774,8 +772,8 @@ uint64 atoi_kmgt(const char* s) {
scale = GG_ULONGLONG(1) << 40;
break;
default:
throw doris::Exception(doris::Status::FatalError(
"Invalid mnemonic: `{}'; should be one of `K', `M', `G', and `T'.", c));
LOG(FATAL) << "Invalid mnemonic: `" << c << "';"
<< " should be one of `K', `M', `G', and `T'.";
}
}
return n * scale;
Expand Down
5 changes: 2 additions & 3 deletions be/src/gutil/strings/util.cc
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,6 @@
#include <mutex>
#include <ostream>

#include "common/exception.h"

using std::copy;
using std::max;
using std::min;
Expand Down Expand Up @@ -491,7 +489,8 @@ const char* strstr_delimited(const char* haystack, const char* needle, char deli
++haystack;
}
}
throw doris::Exception(doris::Status::FatalError("Unreachable statement"));
LOG(FATAL) << "Unreachable statement";
return nullptr;
}

// ----------------------------------------------------------------------
Expand Down
8 changes: 2 additions & 6 deletions be/src/gutil/threading/thread_collision_warner.cc
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,6 @@

#include "gutil/threading/thread_collision_warner.h"

#include "common/exception.h"
#include "common/status.h"

#ifdef __linux__
#include <syscall.h>
#else
Expand All @@ -22,9 +19,8 @@
namespace base {

void DCheckAsserter::warn(int64_t previous_thread_id, int64_t current_thread_id) {
throw doris::Exception(doris::Status::FatalError(
"Thread Collision! Previous thread id: {}, current thread id: {}", previous_thread_id,
current_thread_id));
LOG(FATAL) << "Thread Collision! Previous thread id: " << previous_thread_id
<< ", current thread id: " << current_thread_id;
}

static subtle::Atomic64 CurrentThread() {
Expand Down
5 changes: 3 additions & 2 deletions be/src/io/file_factory.h
Original file line number Diff line number Diff line change
Expand Up @@ -118,9 +118,10 @@ class FileFactory {
case TStorageBackendType::HDFS:
return TFileType::FILE_HDFS;
default:
throw Exception(Status::FatalError("not match type to convert, from type:{}", type));
LOG(FATAL) << "not match type to convert, from type:" << type;
}
throw Exception(Status::FatalError("__builtin_unreachable"));
LOG(FATAL) << "__builtin_unreachable";
__builtin_unreachable();
}
};

Expand Down
12 changes: 8 additions & 4 deletions be/src/olap/block_column_predicate.h
Original file line number Diff line number Diff line change
Expand Up @@ -74,21 +74,25 @@ class BlockColumnPredicate {
}

virtual bool can_do_apply_safely(PrimitiveType input_type, bool is_null) const {
throw Exception(Status::FatalError("should not reach here"));
LOG(FATAL) << "should not reach here";
return true;
}

virtual bool support_zonemap() const { return true; }

virtual bool evaluate_and(const std::pair<WrapperField*, WrapperField*>& statistic) const {
throw Exception(Status::FatalError("should not reach here"));
LOG(FATAL) << "should not reach here";
return true;
}

virtual bool evaluate_and(const segment_v2::BloomFilter* bf) const {
throw Exception(Status::FatalError("should not reach here"));
LOG(FATAL) << "should not reach here";
return true;
}

virtual bool evaluate_and(const StringRef* dict_words, const size_t dict_num) const {
throw Exception(Status::FatalError("should not reach here"));
LOG(FATAL) << "should not reach here";
return true;
}

virtual bool can_do_bloom_filter(bool ngram) const { return false; }
Expand Down
16 changes: 8 additions & 8 deletions be/src/olap/data_dir.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -316,10 +316,10 @@ Status DataDir::_check_incompatible_old_format_tablet() {
std::string_view value) -> bool {
// if strict check incompatible old format, then log fatal
if (config::storage_strict_check_incompatible_old_format) {
throw Exception(Status::FatalError(
"There are incompatible old format metas, current version does not support and "
"it may lead to data missing!!! tablet_id = {} schema_hash = {}",
tablet_id, schema_hash));
LOG(FATAL)
<< "There are incompatible old format metas, current version does not support "
<< "and it may lead to data missing!!! "
<< "tablet_id = " << tablet_id << " schema_hash = " << schema_hash;
} else {
LOG(WARNING)
<< "There are incompatible old format metas, current version does not support "
Expand Down Expand Up @@ -451,8 +451,7 @@ Status DataDir::load() {
<< ", loaded tablet: " << tablet_ids.size()
<< ", error tablet: " << failed_tablet_ids.size() << ", path: " << _path;
if (!config::ignore_load_tablet_failure) {
throw Exception(Status::FatalError(
"load tablets encounter failure. stop BE process. path: {}", _path));
LOG(FATAL) << "load tablets encounter failure. stop BE process. path: " << _path;
}
}
if (!load_tablet_status) {
Expand Down Expand Up @@ -496,9 +495,10 @@ Status DataDir::load() {
}
}
if (rowset_partition_id_eq_0_num > config::ignore_invalid_partition_id_rowset_num) {
throw Exception(Status::FatalError(
LOG(FATAL) << fmt::format(
"roswet partition id eq 0 is {} bigger than config {}, be exit, plz check be.INFO",
rowset_partition_id_eq_0_num, config::ignore_invalid_partition_id_rowset_num));
rowset_partition_id_eq_0_num, config::ignore_invalid_partition_id_rowset_num);
exit(-1);
}

// traverse rowset
Expand Down
13 changes: 8 additions & 5 deletions be/src/olap/key_coder.h
Original file line number Diff line number Diff line change
Expand Up @@ -109,8 +109,8 @@ class KeyCoderTraits<
case 16:
return BigEndian::FromHost128(val);
default:
throw Exception(Status::FatalError("Invalid type to big endian, type={}, size={}",
int(field_type), sizeof(UnsignedCppType)));
LOG(FATAL) << "Invalid type to big endian, type=" << int(field_type)
<< ", size=" << sizeof(UnsignedCppType);
}
}
}
Expand Down Expand Up @@ -300,7 +300,8 @@ class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_CHAR> {
}

static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
throw Exception(Status::FatalError("decode_ascending is not implemented"));
LOG(FATAL) << "decode_ascending is not implemented";
return Status::OK();
}
};

Expand All @@ -319,7 +320,8 @@ class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_VARCHAR> {
}

static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
throw Exception(Status::FatalError("decode_ascending is not implemented"));
LOG(FATAL) << "decode_ascending is not implemented";
return Status::OK();
}
};

Expand All @@ -338,7 +340,8 @@ class KeyCoderTraits<FieldType::OLAP_FIELD_TYPE_STRING> {
}

static Status decode_ascending(Slice* encoded_key, size_t index_size, uint8_t* cell_ptr) {
throw Exception(Status::FatalError("decode_ascending is not implemented"));
LOG(FATAL) << "decode_ascending is not implemented";
return Status::OK();
}
};

Expand Down
8 changes: 4 additions & 4 deletions be/src/olap/like_column_predicate.h
Original file line number Diff line number Diff line change
Expand Up @@ -128,8 +128,8 @@ class LikeColumnPredicate : public ColumnPredicate {
}
}
} else {
throw Exception(Status::FatalError(
"vectorized (not) like predicates should be dict column"));
LOG(FATAL) << "vectorized (not) like predicates should be dict column";
__builtin_unreachable();
}
} else {
if (column.is_column_dictionary()) {
Expand All @@ -153,8 +153,8 @@ class LikeColumnPredicate : public ColumnPredicate {
}
}
} else {
throw Exception(Status::FatalError(
"vectorized (not) like predicates should be dict column"));
LOG(FATAL) << "vectorized (not) like predicates should be dict column";
__builtin_unreachable();
}
}
}
Expand Down
3 changes: 2 additions & 1 deletion be/src/olap/match_predicate.h
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,8 @@ class MatchPredicate : public ColumnPredicate {
//evaluate predicate on Bitmap
Status evaluate(BitmapIndexIterator* iterator, uint32_t num_rows,
roaring::Roaring* roaring) const override {
throw Exception(Status::FatalError("Not Implemented MatchPredicate::evaluate"));
LOG(FATAL) << "Not Implemented MatchPredicate::evaluate";
__builtin_unreachable();
}

//evaluate predicate on inverted
Expand Down
4 changes: 2 additions & 2 deletions be/src/olap/null_predicate.h
Original file line number Diff line number Diff line change
Expand Up @@ -87,8 +87,8 @@ class NullPredicate : public ColumnPredicate {
if (_is_null) {
return bf->test_bytes(nullptr, 0);
} else {
throw Exception(Status::FatalError(
"Bloom filter is not supported by predicate type: is_null="));
LOG(FATAL) << "Bloom filter is not supported by predicate type: is_null=" << _is_null;
return true;
}
}

Expand Down
6 changes: 2 additions & 4 deletions be/src/olap/olap_common.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,6 @@
#include <utility>

#include "common/config.h"
#include "common/exception.h"
#include "io/io_common.h"
#include "olap/olap_define.h"
#include "olap/rowset/rowset_fwd.h"
Expand Down Expand Up @@ -420,8 +419,7 @@ struct RowsetId {
LOG(WARNING) << "failed to init rowset id: " << rowset_id_str;
high = next_rowset_id().hi;
} else {
throw Exception(
Status::FatalError("failed to init rowset id: {}", rowset_id_str));
LOG(FATAL) << "failed to init rowset id: " << rowset_id_str;
}
}
init(1, high, 0, 0);
Expand All @@ -442,7 +440,7 @@ struct RowsetId {
void init(int64_t id_version, int64_t high, int64_t middle, int64_t low) {
version = id_version;
if (UNLIKELY(high >= MAX_ROWSET_ID)) {
throw Exception(Status::FatalError("inc rowsetid is too large:{}", high));
LOG(FATAL) << "inc rowsetid is too large:" << high;
}
hi = (id_version << 56) + (high & LOW_56_BITS);
mi = middle;
Expand Down
6 changes: 4 additions & 2 deletions be/src/olap/page_cache.h
Original file line number Diff line number Diff line change
Expand Up @@ -176,9 +176,11 @@ class StoragePageCache {
return _pk_index_page_cache.get();
}
default:
throw Exception(Status::FatalError("get error type page cache"));
LOG(FATAL) << "get error type page cache";
__builtin_unreachable();
}
throw Exception(Status::FatalError("__builtin_unreachable"));
LOG(FATAL) << "__builtin_unreachable";
__builtin_unreachable();
}
};

Expand Down
3 changes: 2 additions & 1 deletion be/src/olap/rowset/beta_rowset_writer_v2.h
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,8 @@ class BetaRowsetWriterV2 : public RowsetWriter {
};

RowsetSharedPtr manual_build(const RowsetMetaSharedPtr& rowset_meta) override {
throw Exception(Status::FatalError("not implemeted"));
LOG(FATAL) << "not implemeted";
return nullptr;
}

PUniqueId load_id() override { return _context.load_id; }
Expand Down
4 changes: 1 addition & 3 deletions be/src/olap/rowset/rowset_writer.h
Original file line number Diff line number Diff line change
Expand Up @@ -170,9 +170,7 @@ class RowsetWriter {

virtual int32_t allocate_segment_id() = 0;

virtual void set_segment_start_id(int num_segment) {
throw Exception(Status::FatalError("not supported!"));
}
virtual void set_segment_start_id(int num_segment) { LOG(FATAL) << "not supported!"; }

virtual int64_t delete_bitmap_ns() { return 0; }

Expand Down
6 changes: 4 additions & 2 deletions be/src/olap/rowset/segment_v2/hierarchical_data_reader.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,8 @@ Status HierarchicalDataReader::init(const ColumnIteratorOptions& opts) {
}

Status HierarchicalDataReader::seek_to_first() {
throw Exception(Status::FatalError("Not implemented"));
LOG(FATAL) << "Not implemented";
__builtin_unreachable();
}

Status HierarchicalDataReader::seek_to_ordinal(ordinal_t ord) {
Expand Down Expand Up @@ -158,7 +159,8 @@ Status ExtractReader::init(const ColumnIteratorOptions& opts) {
}

Status ExtractReader::seek_to_first() {
throw Exception(Status::FatalError("Not implemented"));
LOG(FATAL) << "Not implemented";
__builtin_unreachable();
}

Status ExtractReader::seek_to_ordinal(ordinal_t ord) {
Expand Down
6 changes: 2 additions & 4 deletions be/src/olap/storage_policy.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -141,10 +141,8 @@ std::vector<std::pair<std::string, int64_t>> get_storage_resource_ids() {
namespace {

[[noreturn]] void exit_at_unknown_path_version(std::string_view resource_id, int64_t path_version) {
throw Exception(
Status::FatalError("unknown path version, please upgrade BE or drop this storage "
"vault. resource_id={} path_version={}",
resource_id, path_version));
LOG(FATAL) << "unknown path version, please upgrade BE or drop this storage vault. resource_id="
<< resource_id << " path_version=" << path_version;
}

} // namespace
Expand Down
2 changes: 1 addition & 1 deletion be/src/olap/tablet_reader.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@ using namespace ErrorCode;

void TabletReader::ReaderParams::check_validation() const {
if (UNLIKELY(version.first == -1 && is_segcompaction == false)) {
throw Exception(Status::FatalError("version is not set. tablet={}", tablet->tablet_id()));
LOG(FATAL) << "version is not set. tablet=" << tablet->tablet_id();
}
}

Expand Down
3 changes: 2 additions & 1 deletion be/src/pipeline/dependency.h
Original file line number Diff line number Diff line change
Expand Up @@ -723,7 +723,8 @@ inline std::string get_exchange_type_name(ExchangeType idx) {
case ExchangeType::LOCAL_MERGE_SORT:
return "LOCAL_MERGE_SORT";
}
throw Exception(Status::FatalError("__builtin_unreachable"));
LOG(FATAL) << "__builtin_unreachable";
__builtin_unreachable();
}

struct DataDistribution {
Expand Down
3 changes: 2 additions & 1 deletion be/src/pipeline/exec/exchange_sink_buffer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -422,7 +422,8 @@ void ExchangeSinkBuffer::_ended(InstanceLoId id) {
}
LOG(INFO) << ss.str();

throw Exception(Status::FatalError("not find the instance id"));
LOG(FATAL) << "not find the instance id";
__builtin_unreachable();
} else {
std::unique_lock<std::mutex> lock(*_instance_to_package_queue_mutex[id]);
_running_sink_count[id]--;
Expand Down
Loading

0 comments on commit 1d937b2

Please sign in to comment.