2018-01-06 22:05:16 -07:00
|
|
|
// Copyright (c) 2014-2018, The Monero Project
|
2015-12-13 21:54:39 -07:00
|
|
|
//
|
2014-07-23 07:03:52 -06:00
|
|
|
// All rights reserved.
|
2015-12-13 21:54:39 -07:00
|
|
|
//
|
2014-07-23 07:03:52 -06:00
|
|
|
// Redistribution and use in source and binary forms, with or without modification, are
|
|
|
|
// permitted provided that the following conditions are met:
|
2015-12-13 21:54:39 -07:00
|
|
|
//
|
2014-07-23 07:03:52 -06:00
|
|
|
// 1. Redistributions of source code must retain the above copyright notice, this list of
|
|
|
|
// conditions and the following disclaimer.
|
2015-12-13 21:54:39 -07:00
|
|
|
//
|
2014-07-23 07:03:52 -06:00
|
|
|
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
|
|
|
// of conditions and the following disclaimer in the documentation and/or other
|
|
|
|
// materials provided with the distribution.
|
2015-12-13 21:54:39 -07:00
|
|
|
//
|
2014-07-23 07:03:52 -06:00
|
|
|
// 3. Neither the name of the copyright holder nor the names of its contributors may be
|
|
|
|
// used to endorse or promote products derived from this software without specific
|
|
|
|
// prior written permission.
|
2015-12-13 21:54:39 -07:00
|
|
|
//
|
2014-07-23 07:03:52 -06:00
|
|
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
|
|
|
|
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
|
|
|
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
|
|
|
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
|
|
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
|
|
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
|
|
|
|
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
2015-12-13 21:54:39 -07:00
|
|
|
//
|
2014-07-23 07:03:52 -06:00
|
|
|
// Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers
|
2014-03-03 15:07:58 -07:00
|
|
|
|
2015-11-23 10:34:55 -07:00
|
|
|
// IP blocking adapted from Boolberry
|
|
|
|
|
2014-05-25 11:06:40 -06:00
|
|
|
#include <algorithm>
|
2014-12-15 15:23:42 -07:00
|
|
|
#include <boost/date_time/posix_time/posix_time.hpp>
|
2015-12-13 21:54:39 -07:00
|
|
|
#include <boost/thread/thread.hpp>
|
2018-12-17 17:05:27 -07:00
|
|
|
#include <boost/uuid/uuid_io.hpp>
|
2017-11-29 15:53:58 -07:00
|
|
|
#include <boost/bind.hpp>
|
2014-12-15 15:23:42 -07:00
|
|
|
#include <atomic>
|
2014-05-25 11:06:40 -06:00
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
#include "version.h"
|
|
|
|
#include "string_tools.h"
|
|
|
|
#include "common/util.h"
|
2014-09-17 15:25:19 -06:00
|
|
|
#include "common/dns_utils.h"
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
#include "common/pruning.h"
|
2014-03-03 15:07:58 -07:00
|
|
|
#include "net/net_helper.h"
|
|
|
|
#include "math_helper.h"
|
|
|
|
#include "p2p_protocol_defs.h"
|
|
|
|
#include "net_peerlist_boost_serialization.h"
|
|
|
|
#include "net/local_ip.h"
|
|
|
|
#include "crypto/crypto.h"
|
|
|
|
#include "storages/levin_abstract_invoke2.h"
|
2017-10-28 09:06:43 -06:00
|
|
|
#include "cryptonote_core/cryptonote_core.h"
|
2014-09-10 12:01:30 -06:00
|
|
|
|
2018-04-21 03:30:55 -06:00
|
|
|
#include <miniupnp/miniupnpc/miniupnpc.h>
|
|
|
|
#include <miniupnp/miniupnpc/upnpcommands.h>
|
|
|
|
#include <miniupnp/miniupnpc/upnperrors.h>
|
2014-04-09 06:14:35 -06:00
|
|
|
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
#undef MONERO_DEFAULT_LOG_CATEGORY
|
|
|
|
#define MONERO_DEFAULT_LOG_CATEGORY "net.p2p"
|
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
#define NET_MAKE_IP(b1,b2,b3,b4) ((LPARAM)(((DWORD)(b1)<<24)+((DWORD)(b2)<<16)+((DWORD)(b3)<<8)+((DWORD)(b4))))
|
|
|
|
|
2017-03-17 17:39:47 -06:00
|
|
|
#define MIN_WANTED_SEED_NODES 12
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
namespace nodetool
|
|
|
|
{
|
2018-06-10 21:43:18 -06:00
|
|
|
inline bool append_net_address(std::vector<epee::net_utils::network_address> & seed_nodes, std::string const & addr, uint16_t default_port);
|
2014-03-03 15:07:58 -07:00
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
void node_server<t_payload_net_handler>::init_options(boost::program_options::options_description& desc)
|
|
|
|
{
|
|
|
|
command_line::add_arg(desc, arg_p2p_bind_ip);
|
2017-02-09 14:29:35 -07:00
|
|
|
command_line::add_arg(desc, arg_p2p_bind_port, false);
|
2014-03-03 15:07:58 -07:00
|
|
|
command_line::add_arg(desc, arg_p2p_external_port);
|
|
|
|
command_line::add_arg(desc, arg_p2p_allow_local_ip);
|
|
|
|
command_line::add_arg(desc, arg_p2p_add_peer);
|
|
|
|
command_line::add_arg(desc, arg_p2p_add_priority_node);
|
2014-05-25 11:06:40 -06:00
|
|
|
command_line::add_arg(desc, arg_p2p_add_exclusive_node);
|
2015-12-13 21:54:39 -07:00
|
|
|
command_line::add_arg(desc, arg_p2p_seed_node);
|
2015-01-05 12:30:17 -07:00
|
|
|
command_line::add_arg(desc, arg_p2p_hide_my_port);
|
|
|
|
command_line::add_arg(desc, arg_no_igd);
|
|
|
|
command_line::add_arg(desc, arg_out_peers);
|
2018-01-20 14:44:23 -07:00
|
|
|
command_line::add_arg(desc, arg_in_peers);
|
2015-01-05 12:30:17 -07:00
|
|
|
command_line::add_arg(desc, arg_tos_flag);
|
|
|
|
command_line::add_arg(desc, arg_limit_rate_up);
|
2015-05-06 10:10:51 -06:00
|
|
|
command_line::add_arg(desc, arg_limit_rate_down);
|
|
|
|
command_line::add_arg(desc, arg_limit_rate);
|
|
|
|
command_line::add_arg(desc, arg_save_graph);
|
2015-04-01 11:00:45 -06:00
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::init_config()
|
|
|
|
{
|
|
|
|
//
|
|
|
|
TRY_ENTRY();
|
|
|
|
std::string state_file_path = m_config_folder + "/" + P2P_NET_DATA_FILENAME;
|
|
|
|
std::ifstream p2p_data;
|
|
|
|
p2p_data.open( state_file_path , std::ios_base::binary | std::ios_base::in);
|
|
|
|
if(!p2p_data.fail())
|
|
|
|
{
|
2015-12-06 17:20:00 -07:00
|
|
|
try
|
|
|
|
{
|
2016-12-19 21:04:19 -07:00
|
|
|
// first try reading in portable mode
|
|
|
|
boost::archive::portable_binary_iarchive a(p2p_data);
|
2015-12-06 17:20:00 -07:00
|
|
|
a >> *this;
|
|
|
|
}
|
2016-12-19 21:04:19 -07:00
|
|
|
catch (...)
|
2015-12-06 17:20:00 -07:00
|
|
|
{
|
2016-12-19 21:04:19 -07:00
|
|
|
// if failed, try reading in unportable mode
|
|
|
|
boost::filesystem::copy_file(state_file_path, state_file_path + ".unportable", boost::filesystem::copy_option::overwrite_if_exists);
|
|
|
|
p2p_data.close();
|
|
|
|
p2p_data.open( state_file_path , std::ios_base::binary | std::ios_base::in);
|
|
|
|
if(!p2p_data.fail())
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
boost::archive::binary_iarchive a(p2p_data);
|
|
|
|
a >> *this;
|
|
|
|
}
|
|
|
|
catch (const std::exception &e)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
MWARNING("Failed to load p2p config file, falling back to default config");
|
2016-12-19 21:04:19 -07:00
|
|
|
m_peerlist = peerlist_manager(); // it was probably half clobbered by the failed load
|
|
|
|
make_default_config();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
make_default_config();
|
|
|
|
}
|
2015-12-06 17:20:00 -07:00
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
}else
|
|
|
|
{
|
|
|
|
make_default_config();
|
|
|
|
}
|
|
|
|
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
#ifdef CRYPTONOTE_PRUNING_DEBUG_SPOOF_SEED
|
|
|
|
std::list<peerlist_entry> plw;
|
|
|
|
while (m_peerlist.get_white_peers_count())
|
|
|
|
{
|
|
|
|
plw.push_back(peerlist_entry());
|
|
|
|
m_peerlist.get_white_peer_by_index(plw.back(), 0);
|
|
|
|
m_peerlist.remove_from_peer_white(plw.back());
|
|
|
|
}
|
|
|
|
for (auto &e:plw)
|
|
|
|
m_peerlist.append_with_peer_white(e);
|
|
|
|
|
|
|
|
std::list<peerlist_entry> plg;
|
|
|
|
while (m_peerlist.get_gray_peers_count())
|
|
|
|
{
|
|
|
|
plg.push_back(peerlist_entry());
|
|
|
|
m_peerlist.get_gray_peer_by_index(plg.back(), 0);
|
|
|
|
m_peerlist.remove_from_peer_gray(plg.back());
|
|
|
|
}
|
|
|
|
for (auto &e:plg)
|
|
|
|
m_peerlist.append_with_peer_gray(e);
|
|
|
|
#endif
|
|
|
|
|
2017-01-22 04:37:55 -07:00
|
|
|
// always recreate a new peer id
|
|
|
|
make_default_peer_id();
|
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
//at this moment we have hardcoded config
|
|
|
|
m_config.m_net_config.handshake_interval = P2P_DEFAULT_HANDSHAKE_INTERVAL;
|
|
|
|
m_config.m_net_config.packet_max_size = P2P_DEFAULT_PACKET_MAX_SIZE; //20 MB limit
|
|
|
|
m_config.m_net_config.config_id = 0; // initial config
|
|
|
|
m_config.m_net_config.connection_timeout = P2P_DEFAULT_CONNECTION_TIMEOUT;
|
|
|
|
m_config.m_net_config.ping_connection_timeout = P2P_DEFAULT_PING_CONNECTION_TIMEOUT;
|
|
|
|
m_config.m_net_config.send_peerlist_sz = P2P_DEFAULT_PEERS_IN_HANDSHAKE;
|
2016-10-26 13:00:08 -06:00
|
|
|
m_config.m_support_flags = P2P_SUPPORT_FLAGS;
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
m_first_connection_maker_call = true;
|
|
|
|
CATCH_ENTRY_L0("node_server::init_config", false);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2016-10-26 13:00:08 -06:00
|
|
|
void node_server<t_payload_net_handler>::for_each_connection(std::function<bool(typename t_payload_net_handler::connection_context&, peerid_type, uint32_t)> f)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
m_net_server.get_config_object().foreach_connection([&](p2p_connection_context& cntx){
|
2016-10-26 13:00:08 -06:00
|
|
|
return f(cntx, cntx.peer_id, cntx.support_flags);
|
2014-03-03 15:07:58 -07:00
|
|
|
});
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-07-02 15:41:15 -06:00
|
|
|
bool node_server<t_payload_net_handler>::for_connection(const boost::uuids::uuid &connection_id, std::function<bool(typename t_payload_net_handler::connection_context&, peerid_type, uint32_t)> f)
|
|
|
|
{
|
|
|
|
return m_net_server.get_config_object().for_connection(connection_id, [&](p2p_connection_context& cntx){
|
|
|
|
return f(cntx, cntx.peer_id, cntx.support_flags);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-05-27 04:35:54 -06:00
|
|
|
bool node_server<t_payload_net_handler>::is_remote_host_allowed(const epee::net_utils::network_address &address)
|
2015-11-23 10:34:55 -07:00
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
CRITICAL_REGION_LOCAL(m_blocked_hosts_lock);
|
|
|
|
auto it = m_blocked_hosts.find(address.host_str());
|
|
|
|
if(it == m_blocked_hosts.end())
|
2015-11-23 10:34:55 -07:00
|
|
|
return true;
|
2015-11-25 15:04:27 -07:00
|
|
|
if(time(nullptr) >= it->second)
|
2015-11-23 10:34:55 -07:00
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
m_blocked_hosts.erase(it);
|
|
|
|
MCLOG_CYAN(el::Level::Info, "global", "Host " << address.host_str() << " unblocked.");
|
2015-11-23 10:34:55 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-01-22 04:37:55 -07:00
|
|
|
bool node_server<t_payload_net_handler>::make_default_peer_id()
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
m_config.m_peer_id = crypto::rand<uint64_t>();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-01-22 04:37:55 -07:00
|
|
|
bool node_server<t_payload_net_handler>::make_default_config()
|
|
|
|
{
|
|
|
|
return make_default_peer_id();
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-05-27 04:35:54 -06:00
|
|
|
bool node_server<t_payload_net_handler>::block_host(const epee::net_utils::network_address &addr, time_t seconds)
|
2015-11-23 10:34:55 -07:00
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
CRITICAL_REGION_LOCAL(m_blocked_hosts_lock);
|
|
|
|
m_blocked_hosts[addr.host_str()] = time(nullptr) + seconds;
|
2016-10-02 10:39:21 -06:00
|
|
|
|
|
|
|
// drop any connection to that IP
|
2016-12-03 04:20:48 -07:00
|
|
|
std::list<boost::uuids::uuid> conns;
|
|
|
|
m_net_server.get_config_object().foreach_connection([&](const p2p_connection_context& cntxt)
|
2016-10-02 10:39:21 -06:00
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
if (cntxt.m_remote_address.is_same_host(addr))
|
2016-10-02 10:39:21 -06:00
|
|
|
{
|
2016-12-03 04:20:48 -07:00
|
|
|
conns.push_back(cntxt.m_connection_id);
|
2016-10-02 10:39:21 -06:00
|
|
|
}
|
|
|
|
return true;
|
2016-12-03 04:20:48 -07:00
|
|
|
});
|
|
|
|
for (const auto &c: conns)
|
|
|
|
m_net_server.get_config_object().close(c);
|
2016-10-02 10:39:21 -06:00
|
|
|
|
2017-05-27 04:35:54 -06:00
|
|
|
MCLOG_CYAN(el::Level::Info, "global", "Host " << addr.host_str() << " blocked.");
|
2015-11-23 10:34:55 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-05-27 04:35:54 -06:00
|
|
|
bool node_server<t_payload_net_handler>::unblock_host(const epee::net_utils::network_address &address)
|
2015-11-25 17:04:22 -07:00
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
CRITICAL_REGION_LOCAL(m_blocked_hosts_lock);
|
|
|
|
auto i = m_blocked_hosts.find(address.host_str());
|
|
|
|
if (i == m_blocked_hosts.end())
|
2015-11-25 17:04:22 -07:00
|
|
|
return false;
|
2017-05-27 04:35:54 -06:00
|
|
|
m_blocked_hosts.erase(i);
|
|
|
|
MCLOG_CYAN(el::Level::Info, "global", "Host " << address.host_str() << " unblocked.");
|
2015-11-25 17:04:22 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-05-27 04:35:54 -06:00
|
|
|
bool node_server<t_payload_net_handler>::add_host_fail(const epee::net_utils::network_address &address)
|
2015-11-23 10:34:55 -07:00
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
CRITICAL_REGION_LOCAL(m_host_fails_score_lock);
|
|
|
|
uint64_t fails = ++m_host_fails_score[address.host_str()];
|
|
|
|
MDEBUG("Host " << address.host_str() << " fail score=" << fails);
|
2015-11-23 10:34:55 -07:00
|
|
|
if(fails > P2P_IP_FAILS_BEFORE_BLOCK)
|
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
auto it = m_host_fails_score.find(address.host_str());
|
|
|
|
CHECK_AND_ASSERT_MES(it != m_host_fails_score.end(), false, "internal error");
|
2015-11-23 10:34:55 -07:00
|
|
|
it->second = P2P_IP_FAILS_BEFORE_BLOCK/2;
|
2017-05-27 04:35:54 -06:00
|
|
|
block_host(address);
|
2015-11-23 10:34:55 -07:00
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-05-27 04:35:54 -06:00
|
|
|
bool node_server<t_payload_net_handler>::parse_peer_from_string(epee::net_utils::network_address& pe, const std::string& node_addr, uint16_t default_port)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
return epee::net_utils::create_network_address(pe, node_addr, default_port);
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2014-09-08 10:51:04 -06:00
|
|
|
bool node_server<t_payload_net_handler>::handle_command_line(
|
|
|
|
const boost::program_options::variables_map& vm
|
|
|
|
)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
2018-02-16 04:04:04 -07:00
|
|
|
bool testnet = command_line::get_arg(vm, cryptonote::arg_testnet_on);
|
|
|
|
bool stagenet = command_line::get_arg(vm, cryptonote::arg_stagenet_on);
|
|
|
|
m_nettype = testnet ? cryptonote::TESTNET : stagenet ? cryptonote::STAGENET : cryptonote::MAINNET;
|
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
m_bind_ip = command_line::get_arg(vm, arg_p2p_bind_ip);
|
2018-01-21 08:29:55 -07:00
|
|
|
m_port = command_line::get_arg(vm, arg_p2p_bind_port);
|
2014-03-03 15:07:58 -07:00
|
|
|
m_external_port = command_line::get_arg(vm, arg_p2p_external_port);
|
|
|
|
m_allow_local_ip = command_line::get_arg(vm, arg_p2p_allow_local_ip);
|
2015-01-05 12:30:17 -07:00
|
|
|
m_no_igd = command_line::get_arg(vm, arg_no_igd);
|
2017-11-30 08:35:52 -07:00
|
|
|
m_offline = command_line::get_arg(vm, cryptonote::arg_offline);
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
if (command_line::has_arg(vm, arg_p2p_add_peer))
|
2015-12-13 21:54:39 -07:00
|
|
|
{
|
2014-03-03 15:07:58 -07:00
|
|
|
std::vector<std::string> perrs = command_line::get_arg(vm, arg_p2p_add_peer);
|
|
|
|
for(const std::string& pr_str: perrs)
|
|
|
|
{
|
|
|
|
nodetool::peerlist_entry pe = AUTO_VAL_INIT(pe);
|
|
|
|
pe.id = crypto::rand<uint64_t>();
|
2018-06-10 21:16:29 -06:00
|
|
|
const uint16_t default_port = cryptonote::get_config(m_nettype).P2P_DEFAULT_PORT;
|
2017-05-27 04:35:54 -06:00
|
|
|
bool r = parse_peer_from_string(pe.adr, pr_str, default_port);
|
2018-06-10 21:43:18 -06:00
|
|
|
if (r)
|
|
|
|
{
|
|
|
|
m_command_line_peers.push_back(pe);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
std::vector<epee::net_utils::network_address> resolved_addrs;
|
|
|
|
r = append_net_address(resolved_addrs, pr_str, default_port);
|
|
|
|
CHECK_AND_ASSERT_MES(r, false, "Failed to parse or resolve address from string: " << pr_str);
|
|
|
|
for (const epee::net_utils::network_address& addr : resolved_addrs)
|
|
|
|
{
|
|
|
|
pe.id = crypto::rand<uint64_t>();
|
|
|
|
pe.adr = addr;
|
|
|
|
m_command_line_peers.push_back(pe);
|
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
|
|
|
}
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2015-04-01 11:00:45 -06:00
|
|
|
if(command_line::has_arg(vm, arg_save_graph))
|
|
|
|
{
|
2015-12-13 21:54:39 -07:00
|
|
|
set_save_graph(true);
|
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
|
2014-05-25 11:06:40 -06:00
|
|
|
if (command_line::has_arg(vm,arg_p2p_add_exclusive_node))
|
|
|
|
{
|
|
|
|
if (!parse_peers_and_add_to_container(vm, arg_p2p_add_exclusive_node, m_exclusive_peers))
|
|
|
|
return false;
|
|
|
|
}
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2014-06-27 11:21:48 -06:00
|
|
|
if (command_line::has_arg(vm, arg_p2p_add_priority_node))
|
2014-05-25 11:06:40 -06:00
|
|
|
{
|
|
|
|
if (!parse_peers_and_add_to_container(vm, arg_p2p_add_priority_node, m_priority_peers))
|
|
|
|
return false;
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
if (command_line::has_arg(vm, arg_p2p_seed_node))
|
|
|
|
{
|
2014-05-25 11:06:40 -06:00
|
|
|
if (!parse_peers_and_add_to_container(vm, arg_p2p_seed_node, m_seed_nodes))
|
|
|
|
return false;
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
2014-05-25 11:06:40 -06:00
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
if(command_line::has_arg(vm, arg_p2p_hide_my_port))
|
2014-05-25 11:06:40 -06:00
|
|
|
m_hide_my_port = true;
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2015-01-05 12:30:17 -07:00
|
|
|
if ( !set_max_out_peers(vm, command_line::get_arg(vm, arg_out_peers) ) )
|
2015-12-13 21:54:39 -07:00
|
|
|
return false;
|
2015-01-05 12:30:17 -07:00
|
|
|
|
2018-01-20 14:44:23 -07:00
|
|
|
if ( !set_max_in_peers(vm, command_line::get_arg(vm, arg_in_peers) ) )
|
|
|
|
return false;
|
|
|
|
|
2015-12-13 21:54:39 -07:00
|
|
|
if ( !set_tos_flag(vm, command_line::get_arg(vm, arg_tos_flag) ) )
|
|
|
|
return false;
|
2015-01-05 12:30:17 -07:00
|
|
|
|
2015-12-13 21:54:39 -07:00
|
|
|
if ( !set_rate_up_limit(vm, command_line::get_arg(vm, arg_limit_rate_up) ) )
|
|
|
|
return false;
|
2015-01-05 12:30:17 -07:00
|
|
|
|
2015-12-13 21:54:39 -07:00
|
|
|
if ( !set_rate_down_limit(vm, command_line::get_arg(vm, arg_limit_rate_down) ) )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if ( !set_rate_limit(vm, command_line::get_arg(vm, arg_limit_rate) ) )
|
|
|
|
return false;
|
2014-05-25 11:06:40 -06:00
|
|
|
|
|
|
|
return true;
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
2018-06-10 21:43:18 -06:00
|
|
|
inline bool append_net_address(
|
2017-05-27 04:35:54 -06:00
|
|
|
std::vector<epee::net_utils::network_address> & seed_nodes
|
2014-09-24 06:45:34 -06:00
|
|
|
, std::string const & addr
|
2018-06-10 21:43:18 -06:00
|
|
|
, uint16_t default_port
|
2014-09-24 06:45:34 -06:00
|
|
|
)
|
2014-03-20 05:46:11 -06:00
|
|
|
{
|
2014-09-24 06:45:34 -06:00
|
|
|
using namespace boost::asio;
|
|
|
|
|
2018-06-10 21:43:18 -06:00
|
|
|
std::string host = addr;
|
|
|
|
std::string port = std::to_string(default_port);
|
2014-09-24 06:45:34 -06:00
|
|
|
size_t pos = addr.find_last_of(':');
|
2018-06-10 21:43:18 -06:00
|
|
|
if (std::string::npos != pos)
|
|
|
|
{
|
|
|
|
CHECK_AND_ASSERT_MES(addr.length() - 1 != pos && 0 != pos, false, "Failed to parse seed address from string: '" << addr << '\'');
|
|
|
|
host = addr.substr(0, pos);
|
|
|
|
port = addr.substr(pos + 1);
|
|
|
|
}
|
|
|
|
MINFO("Resolving node address: host=" << host << ", port=" << port);
|
2014-09-24 06:45:34 -06:00
|
|
|
|
|
|
|
io_service io_srv;
|
|
|
|
ip::tcp::resolver resolver(io_srv);
|
2016-11-23 16:08:53 -07:00
|
|
|
ip::tcp::resolver::query query(host, port, boost::asio::ip::tcp::resolver::query::canonical_name);
|
2014-09-24 06:45:34 -06:00
|
|
|
boost::system::error_code ec;
|
|
|
|
ip::tcp::resolver::iterator i = resolver.resolve(query, ec);
|
2018-06-10 21:43:18 -06:00
|
|
|
CHECK_AND_ASSERT_MES(!ec, false, "Failed to resolve host name '" << host << "': " << ec.message() << ':' << ec.value());
|
2014-09-24 06:45:34 -06:00
|
|
|
|
|
|
|
ip::tcp::resolver::iterator iend;
|
|
|
|
for (; i != iend; ++i)
|
2014-09-09 10:15:42 -06:00
|
|
|
{
|
2014-09-24 06:45:34 -06:00
|
|
|
ip::tcp::endpoint endpoint = *i;
|
|
|
|
if (endpoint.address().is_v4())
|
2014-03-20 05:46:11 -06:00
|
|
|
{
|
2017-08-25 09:14:46 -06:00
|
|
|
epee::net_utils::network_address na{epee::net_utils::ipv4_network_address{boost::asio::detail::socket_ops::host_to_network_long(endpoint.address().to_v4().to_ulong()), endpoint.port()}};
|
2014-09-24 06:45:34 -06:00
|
|
|
seed_nodes.push_back(na);
|
2018-06-10 21:43:18 -06:00
|
|
|
MINFO("Added node: " << na.str());
|
2014-09-09 10:15:42 -06:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
MWARNING("IPv6 unsupported, skip '" << host << "' -> " << endpoint.address().to_v6().to_string(ec));
|
2014-03-20 05:46:11 -06:00
|
|
|
}
|
|
|
|
}
|
2018-06-10 21:43:18 -06:00
|
|
|
return true;
|
2014-03-20 05:46:11 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------------
|
2014-03-03 15:07:58 -07:00
|
|
|
template<class t_payload_net_handler>
|
2018-02-16 04:04:04 -07:00
|
|
|
std::set<std::string> node_server<t_payload_net_handler>::get_seed_nodes(cryptonote::network_type nettype) const
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
2015-05-25 23:11:44 -06:00
|
|
|
std::set<std::string> full_addrs;
|
2018-02-16 04:04:04 -07:00
|
|
|
if (nettype == cryptonote::TESTNET)
|
2014-09-09 07:10:30 -06:00
|
|
|
{
|
2017-02-21 13:40:26 -07:00
|
|
|
full_addrs.insert("212.83.175.67:28080");
|
2016-09-18 12:10:46 -06:00
|
|
|
full_addrs.insert("5.9.100.248:28080");
|
2017-02-21 13:40:26 -07:00
|
|
|
full_addrs.insert("163.172.182.165:28080");
|
|
|
|
full_addrs.insert("195.154.123.123:28080");
|
|
|
|
full_addrs.insert("212.83.172.165:28080");
|
2014-09-09 07:10:30 -06:00
|
|
|
}
|
2018-02-16 04:04:04 -07:00
|
|
|
else if (nettype == cryptonote::STAGENET)
|
|
|
|
{
|
|
|
|
full_addrs.insert("162.210.173.150:38080");
|
|
|
|
full_addrs.insert("162.210.173.151:38080");
|
|
|
|
}
|
2018-06-14 13:11:49 -06:00
|
|
|
else if (nettype == cryptonote::FAKECHAIN)
|
|
|
|
{
|
|
|
|
}
|
2014-09-09 07:10:30 -06:00
|
|
|
else
|
2017-03-17 17:39:47 -06:00
|
|
|
{
|
|
|
|
full_addrs.insert("107.152.130.98:18080");
|
|
|
|
full_addrs.insert("212.83.175.67:18080");
|
|
|
|
full_addrs.insert("5.9.100.248:18080");
|
|
|
|
full_addrs.insert("163.172.182.165:18080");
|
|
|
|
full_addrs.insert("161.67.132.39:18080");
|
|
|
|
full_addrs.insert("198.74.231.92:18080");
|
2018-03-21 23:46:49 -06:00
|
|
|
full_addrs.insert("195.154.123.123:18080");
|
|
|
|
full_addrs.insert("212.83.172.165:18080");
|
2017-03-17 17:39:47 -06:00
|
|
|
}
|
|
|
|
return full_addrs;
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::init(const boost::program_options::variables_map& vm)
|
|
|
|
{
|
|
|
|
std::set<std::string> full_addrs;
|
2018-01-17 05:01:42 -07:00
|
|
|
|
|
|
|
bool res = handle_command_line(vm);
|
|
|
|
CHECK_AND_ASSERT_MES(res, false, "Failed to handle command line");
|
2017-03-17 17:39:47 -06:00
|
|
|
|
2018-04-29 07:57:08 -06:00
|
|
|
m_fallback_seed_nodes_added = false;
|
2018-02-16 04:04:04 -07:00
|
|
|
if (m_nettype == cryptonote::TESTNET)
|
2017-03-17 17:39:47 -06:00
|
|
|
{
|
|
|
|
memcpy(&m_network_id, &::config::testnet::NETWORK_ID, 16);
|
2018-02-16 04:04:04 -07:00
|
|
|
full_addrs = get_seed_nodes(cryptonote::TESTNET);
|
|
|
|
}
|
|
|
|
else if (m_nettype == cryptonote::STAGENET)
|
|
|
|
{
|
|
|
|
memcpy(&m_network_id, &::config::stagenet::NETWORK_ID, 16);
|
|
|
|
full_addrs = get_seed_nodes(cryptonote::STAGENET);
|
2017-03-17 17:39:47 -06:00
|
|
|
}
|
2018-03-13 05:20:49 -06:00
|
|
|
else
|
2014-09-09 07:10:30 -06:00
|
|
|
{
|
2015-01-29 15:10:53 -07:00
|
|
|
memcpy(&m_network_id, &::config::NETWORK_ID, 16);
|
2018-03-13 05:20:49 -06:00
|
|
|
if (m_exclusive_peers.empty())
|
|
|
|
{
|
2014-09-17 13:35:52 -06:00
|
|
|
// for each hostname in the seed nodes list, attempt to DNS resolve and
|
|
|
|
// add the result addresses as seed nodes
|
|
|
|
// TODO: at some point add IPv6 support, but that won't be relevant
|
|
|
|
// for some time yet.
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2014-12-15 15:23:42 -07:00
|
|
|
std::vector<std::vector<std::string>> dns_results;
|
|
|
|
dns_results.resize(m_seed_nodes_list.size());
|
2014-12-15 15:43:12 -07:00
|
|
|
|
2017-07-28 15:23:05 -06:00
|
|
|
std::list<boost::thread> dns_threads;
|
2014-12-15 15:23:42 -07:00
|
|
|
uint64_t result_index = 0;
|
2014-09-17 13:35:52 -06:00
|
|
|
for (const std::string& addr_str : m_seed_nodes_list)
|
|
|
|
{
|
2017-07-28 15:23:05 -06:00
|
|
|
boost::thread th = boost::thread([=, &dns_results, &addr_str]
|
2014-12-15 15:23:42 -07:00
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MDEBUG("dns_threads[" << result_index << "] created for: " << addr_str);
|
2014-12-15 15:23:42 -07:00
|
|
|
// TODO: care about dnssec avail/valid
|
|
|
|
bool avail, valid;
|
2015-01-14 14:14:01 -07:00
|
|
|
std::vector<std::string> addr_list;
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
2015-08-14 22:04:29 -06:00
|
|
|
addr_list = tools::DNSResolver::instance().get_ipv4(addr_str, avail, valid);
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MDEBUG("dns_threads[" << result_index << "] DNS resolve done");
|
2015-01-14 14:14:01 -07:00
|
|
|
boost::this_thread::interruption_point();
|
|
|
|
}
|
|
|
|
catch(const boost::thread_interrupted&)
|
|
|
|
{
|
|
|
|
// thread interruption request
|
|
|
|
// even if we now have results, finish thread without setting
|
|
|
|
// result variables, which are now out of scope in main thread
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MWARNING("dns_threads[" << result_index << "] interrupted");
|
2015-01-14 14:14:01 -07:00
|
|
|
return;
|
|
|
|
}
|
2014-12-15 15:23:42 -07:00
|
|
|
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MINFO("dns_threads[" << result_index << "] addr_str: " << addr_str << " number of results: " << addr_list.size());
|
2015-01-14 14:14:01 -07:00
|
|
|
dns_results[result_index] = addr_list;
|
2014-12-15 15:23:42 -07:00
|
|
|
});
|
|
|
|
|
2017-07-28 15:23:05 -06:00
|
|
|
dns_threads.push_back(std::move(th));
|
2015-01-14 14:14:01 -07:00
|
|
|
++result_index;
|
2014-12-15 15:23:42 -07:00
|
|
|
}
|
|
|
|
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MDEBUG("dns_threads created, now waiting for completion or timeout of " << CRYPTONOTE_DNS_TIMEOUT_MS << "ms");
|
2015-01-14 14:14:01 -07:00
|
|
|
boost::chrono::system_clock::time_point deadline = boost::chrono::system_clock::now() + boost::chrono::milliseconds(CRYPTONOTE_DNS_TIMEOUT_MS);
|
|
|
|
uint64_t i = 0;
|
2017-07-28 15:23:05 -06:00
|
|
|
for (boost::thread& th : dns_threads)
|
2014-12-15 15:23:42 -07:00
|
|
|
{
|
2017-07-28 15:23:05 -06:00
|
|
|
if (! th.try_join_until(deadline))
|
2014-12-15 15:23:42 -07:00
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MWARNING("dns_threads[" << i << "] timed out, sending interrupt");
|
2017-07-28 15:23:05 -06:00
|
|
|
th.interrupt();
|
2014-12-15 15:23:42 -07:00
|
|
|
}
|
2015-01-14 14:14:01 -07:00
|
|
|
++i;
|
2014-12-15 15:23:42 -07:00
|
|
|
}
|
|
|
|
|
2015-01-14 14:14:01 -07:00
|
|
|
i = 0;
|
2014-12-15 15:23:42 -07:00
|
|
|
for (const auto& result : dns_results)
|
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MDEBUG("DNS lookup for " << m_seed_nodes_list[i] << ": " << result.size() << " results");
|
2015-01-14 14:14:01 -07:00
|
|
|
// if no results for node, thread's lookup likely timed out
|
|
|
|
if (result.size())
|
2014-09-17 13:35:52 -06:00
|
|
|
{
|
2015-01-14 14:14:01 -07:00
|
|
|
for (const auto& addr_string : result)
|
2018-06-10 21:16:29 -06:00
|
|
|
full_addrs.insert(addr_string + ":" + std::to_string(cryptonote::get_config(m_nettype).P2P_DEFAULT_PORT));
|
2014-09-17 13:35:52 -06:00
|
|
|
}
|
2015-01-14 14:14:01 -07:00
|
|
|
++i;
|
2014-09-17 13:35:52 -06:00
|
|
|
}
|
|
|
|
|
2017-03-17 17:39:47 -06:00
|
|
|
// append the fallback nodes if we have too few seed nodes to start with
|
|
|
|
if (full_addrs.size() < MIN_WANTED_SEED_NODES)
|
2014-09-17 13:35:52 -06:00
|
|
|
{
|
2017-03-17 17:39:47 -06:00
|
|
|
if (full_addrs.empty())
|
|
|
|
MINFO("DNS seed node lookup either timed out or failed, falling back to defaults");
|
|
|
|
else
|
|
|
|
MINFO("Not enough DNS seed nodes found, using fallback defaults too");
|
|
|
|
|
2018-02-16 04:04:04 -07:00
|
|
|
for (const auto &peer: get_seed_nodes(cryptonote::MAINNET))
|
2017-03-17 17:39:47 -06:00
|
|
|
full_addrs.insert(peer);
|
2018-04-29 07:57:08 -06:00
|
|
|
m_fallback_seed_nodes_added = true;
|
2014-09-17 13:35:52 -06:00
|
|
|
}
|
2014-07-16 11:30:15 -06:00
|
|
|
}
|
2018-03-13 05:20:49 -06:00
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
|
2015-05-25 23:11:44 -06:00
|
|
|
for (const auto& full_addr : full_addrs)
|
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MDEBUG("Seed node: " << full_addr);
|
2018-06-10 21:43:18 -06:00
|
|
|
append_net_address(m_seed_nodes, full_addr, cryptonote::get_config(m_nettype).P2P_DEFAULT_PORT);
|
2015-05-25 23:11:44 -06:00
|
|
|
}
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MDEBUG("Number of seed nodes: " << m_seed_nodes.size());
|
2015-05-25 23:11:44 -06:00
|
|
|
|
2018-01-21 08:29:55 -07:00
|
|
|
m_config_folder = command_line::get_arg(vm, cryptonote::arg_data_dir);
|
2014-03-03 15:07:58 -07:00
|
|
|
|
2018-02-16 04:04:04 -07:00
|
|
|
if ((m_nettype == cryptonote::MAINNET && m_port != std::to_string(::config::P2P_DEFAULT_PORT))
|
|
|
|
|| (m_nettype == cryptonote::TESTNET && m_port != std::to_string(::config::testnet::P2P_DEFAULT_PORT))
|
|
|
|
|| (m_nettype == cryptonote::STAGENET && m_port != std::to_string(::config::stagenet::P2P_DEFAULT_PORT))) {
|
2017-01-27 17:36:39 -07:00
|
|
|
m_config_folder = m_config_folder + "/" + m_port;
|
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
res = init_config();
|
|
|
|
CHECK_AND_ASSERT_MES(res, false, "Failed to init config.");
|
|
|
|
|
|
|
|
res = m_peerlist.init(m_allow_local_ip);
|
|
|
|
CHECK_AND_ASSERT_MES(res, false, "Failed to init peerlist.");
|
|
|
|
|
|
|
|
|
|
|
|
for(auto& p: m_command_line_peers)
|
|
|
|
m_peerlist.append_with_peer_white(p);
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
//only in case if we really sure that we have external visible ip
|
|
|
|
m_have_address = true;
|
|
|
|
m_ip_address = 0;
|
|
|
|
m_last_stat_request_time = 0;
|
|
|
|
|
|
|
|
//configure self
|
|
|
|
m_net_server.set_threads_prefix("P2P");
|
2017-10-09 09:46:42 -06:00
|
|
|
m_net_server.get_config_object().set_handler(this);
|
2014-03-03 15:07:58 -07:00
|
|
|
m_net_server.get_config_object().m_invoke_timeout = P2P_DEFAULT_INVOKE_TIMEOUT;
|
2015-11-23 10:34:55 -07:00
|
|
|
m_net_server.set_connection_filter(this);
|
2014-03-03 15:07:58 -07:00
|
|
|
|
2015-12-07 13:21:45 -07:00
|
|
|
// from here onwards, it's online stuff
|
|
|
|
if (m_offline)
|
|
|
|
return res;
|
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
//try to bind
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MINFO("Binding on " << m_bind_ip << ":" << m_port);
|
2014-03-03 15:07:58 -07:00
|
|
|
res = m_net_server.init_server(m_port, m_bind_ip);
|
|
|
|
CHECK_AND_ASSERT_MES(res, false, "Failed to bind server");
|
|
|
|
|
2017-09-01 01:50:22 -06:00
|
|
|
m_listening_port = m_net_server.get_binded_port();
|
|
|
|
MLOG_GREEN(el::Level::Info, "Net service bound to " << m_bind_ip << ":" << m_listening_port);
|
2014-03-03 15:07:58 -07:00
|
|
|
if(m_external_port)
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MDEBUG("External port defined as " << m_external_port);
|
2014-04-09 06:14:35 -06:00
|
|
|
|
2017-08-29 15:28:23 -06:00
|
|
|
// add UPnP port mapping
|
|
|
|
if(!m_no_igd)
|
2017-09-01 01:50:22 -06:00
|
|
|
add_upnp_port_mapping(m_listening_port);
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
return res;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
typename node_server<t_payload_net_handler>::payload_net_handler& node_server<t_payload_net_handler>::get_payload_object()
|
|
|
|
{
|
|
|
|
return m_payload_handler;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::run()
|
|
|
|
{
|
2015-12-13 21:54:39 -07:00
|
|
|
// creating thread to log number of connections
|
2016-02-18 14:30:10 -07:00
|
|
|
mPeersLoggerThread.reset(new boost::thread([&]()
|
2015-12-13 21:54:39 -07:00
|
|
|
{
|
|
|
|
_note("Thread monitor number of peers - start");
|
2015-12-22 05:29:53 -07:00
|
|
|
while (!is_closing && !m_net_server.is_stop_signal_sent())
|
2015-12-13 21:54:39 -07:00
|
|
|
{ // main loop of thread
|
|
|
|
//number_of_peers = m_net_server.get_config_object().get_connections_count();
|
2018-01-20 14:44:23 -07:00
|
|
|
unsigned int number_of_in_peers = 0;
|
|
|
|
unsigned int number_of_out_peers = 0;
|
2015-12-13 21:54:39 -07:00
|
|
|
m_net_server.get_config_object().foreach_connection([&](const p2p_connection_context& cntxt)
|
|
|
|
{
|
2018-01-20 14:44:23 -07:00
|
|
|
if (cntxt.m_is_income)
|
|
|
|
{
|
|
|
|
++number_of_in_peers;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
++number_of_out_peers;
|
|
|
|
}
|
2015-12-13 21:54:39 -07:00
|
|
|
return true;
|
|
|
|
}); // lambda
|
|
|
|
|
2018-01-20 14:44:23 -07:00
|
|
|
m_current_number_of_in_peers = number_of_in_peers;
|
|
|
|
m_current_number_of_out_peers = number_of_out_peers;
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2016-03-11 05:25:28 -07:00
|
|
|
boost::this_thread::sleep_for(boost::chrono::seconds(1));
|
2015-12-13 21:54:39 -07:00
|
|
|
} // main loop of thread
|
|
|
|
_note("Thread monitor number of peers - done");
|
|
|
|
})); // lambda
|
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
//here you can set worker threads count
|
|
|
|
int thrds_count = 10;
|
|
|
|
|
|
|
|
m_net_server.add_idle_handler(boost::bind(&node_server<t_payload_net_handler>::idle_worker, this), 1000);
|
|
|
|
m_net_server.add_idle_handler(boost::bind(&t_payload_net_handler::on_idle, &m_payload_handler), 1000);
|
|
|
|
|
2014-04-30 14:50:06 -06:00
|
|
|
boost::thread::attributes attrs;
|
|
|
|
attrs.set_stack_size(THREAD_STACK_SIZE);
|
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
//go to loop
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MINFO("Run net_service loop( " << thrds_count << " threads)...");
|
2014-04-30 14:50:06 -06:00
|
|
|
if(!m_net_server.run_server(thrds_count, true, attrs))
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
LOG_ERROR("Failed to run net tcp server!");
|
|
|
|
}
|
|
|
|
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MINFO("net_service loop stopped.");
|
2014-03-03 15:07:58 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
uint64_t node_server<t_payload_net_handler>::get_connections_count()
|
|
|
|
{
|
|
|
|
return m_net_server.get_config_object().get_connections_count();
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::deinit()
|
|
|
|
{
|
2015-12-13 21:54:39 -07:00
|
|
|
kill();
|
2014-03-03 15:07:58 -07:00
|
|
|
m_peerlist.deinit();
|
2018-10-16 03:17:21 -06:00
|
|
|
|
|
|
|
if (!m_offline)
|
|
|
|
{
|
|
|
|
m_net_server.deinit_server();
|
|
|
|
// remove UPnP port mapping
|
|
|
|
if(!m_no_igd)
|
|
|
|
delete_upnp_port_mapping(m_listening_port);
|
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
return store_config();
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::store_config()
|
|
|
|
{
|
|
|
|
|
|
|
|
TRY_ENTRY();
|
|
|
|
if (!tools::create_directories_if_necessary(m_config_folder))
|
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MWARNING("Failed to create data directory: " << m_config_folder);
|
2014-03-03 15:07:58 -07:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string state_file_path = m_config_folder + "/" + P2P_NET_DATA_FILENAME;
|
|
|
|
std::ofstream p2p_data;
|
|
|
|
p2p_data.open( state_file_path , std::ios_base::binary | std::ios_base::out| std::ios::trunc);
|
|
|
|
if(p2p_data.fail())
|
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MWARNING("Failed to save config to file " << state_file_path);
|
2014-03-03 15:07:58 -07:00
|
|
|
return false;
|
|
|
|
};
|
|
|
|
|
2016-12-19 21:04:19 -07:00
|
|
|
boost::archive::portable_binary_oarchive a(p2p_data);
|
2014-03-03 15:07:58 -07:00
|
|
|
a << *this;
|
|
|
|
return true;
|
|
|
|
CATCH_ENTRY_L0("blockchain_storage::save", false);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::send_stop_signal()
|
|
|
|
{
|
2017-12-15 03:28:15 -07:00
|
|
|
MDEBUG("[node] sending stop signal");
|
|
|
|
m_net_server.send_stop_signal();
|
|
|
|
MDEBUG("[node] Stop signal sent");
|
|
|
|
|
2017-07-29 03:03:37 -06:00
|
|
|
std::list<boost::uuids::uuid> connection_ids;
|
|
|
|
m_net_server.get_config_object().foreach_connection([&](const p2p_connection_context& cntxt) {
|
|
|
|
connection_ids.push_back(cntxt.m_connection_id);
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
for (const auto &connection_id: connection_ids)
|
|
|
|
m_net_server.get_config_object().close(connection_id);
|
|
|
|
|
2016-12-04 05:27:45 -07:00
|
|
|
m_payload_handler.stop();
|
2017-12-15 03:28:15 -07:00
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::do_handshake_with_peer(peerid_type& pi, p2p_connection_context& context_, bool just_take_peerlist)
|
|
|
|
{
|
|
|
|
typename COMMAND_HANDSHAKE::request arg;
|
|
|
|
typename COMMAND_HANDSHAKE::response rsp;
|
|
|
|
get_local_node_data(arg.node_data);
|
|
|
|
m_payload_handler.get_payload_sync_data(arg.payload_data);
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2014-05-25 11:06:40 -06:00
|
|
|
epee::simple_event ev;
|
2014-03-03 15:07:58 -07:00
|
|
|
std::atomic<bool> hsh_result(false);
|
2015-12-13 21:54:39 -07:00
|
|
|
|
|
|
|
bool r = epee::net_utils::async_invoke_remote_command2<typename COMMAND_HANDSHAKE::response>(context_.m_connection_id, COMMAND_HANDSHAKE::ID, arg, m_net_server.get_config_object(),
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
[this, &pi, &ev, &hsh_result, &just_take_peerlist, &context_](int code, const typename COMMAND_HANDSHAKE::response& rsp, p2p_connection_context& context)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
2014-05-25 11:06:40 -06:00
|
|
|
epee::misc_utils::auto_scope_leave_caller scope_exit_handler = epee::misc_utils::create_scope_leave_handler([&](){ev.raise();});
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
if(code < 0)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(context, "COMMAND_HANDSHAKE invoke failed. (" << code << ", " << epee::levin::get_err_descr(code) << ")");
|
2014-03-03 15:07:58 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-07-16 11:30:15 -06:00
|
|
|
if(rsp.node_data.network_id != m_network_id)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
2018-12-17 17:05:27 -07:00
|
|
|
LOG_WARNING_CC(context, "COMMAND_HANDSHAKE Failed, wrong network! (" << rsp.node_data.network_id << "), closing connection.");
|
2014-03-03 15:07:58 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-05-27 04:35:54 -06:00
|
|
|
if(!handle_remote_peerlist(rsp.local_peerlist_new, rsp.node_data.local_time, context))
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(context, "COMMAND_HANDSHAKE: failed to handle_remote_peerlist(...), closing connection.");
|
2017-05-27 04:35:54 -06:00
|
|
|
add_host_fail(context.m_remote_address);
|
2014-03-03 15:07:58 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
hsh_result = true;
|
|
|
|
if(!just_take_peerlist)
|
|
|
|
{
|
|
|
|
if(!m_payload_handler.process_payload_sync_data(rsp.payload_data, context, true))
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(context, "COMMAND_HANDSHAKE invoked, but process_payload_sync_data returned false, dropping connection.");
|
2014-03-03 15:07:58 -07:00
|
|
|
hsh_result = false;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
pi = context.peer_id = rsp.node_data.peer_id;
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
m_peerlist.set_peer_just_seen(rsp.node_data.peer_id, context.m_remote_address, context.m_pruning_seed);
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
if(rsp.node_data.peer_id == m_config.m_peer_id)
|
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
LOG_DEBUG_CC(context, "Connection to self detected, dropping connection");
|
2014-03-03 15:07:58 -07:00
|
|
|
hsh_result = false;
|
|
|
|
return;
|
|
|
|
}
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
LOG_INFO_CC(context, "New connection handshaked, pruning seed " << epee::string_tools::to_string_hex(context.m_pruning_seed));
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
LOG_DEBUG_CC(context, " COMMAND_HANDSHAKE INVOKED OK");
|
2014-03-03 15:07:58 -07:00
|
|
|
}else
|
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
LOG_DEBUG_CC(context, " COMMAND_HANDSHAKE(AND CLOSE) INVOKED OK");
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
context_ = context;
|
2014-03-03 15:07:58 -07:00
|
|
|
}, P2P_DEFAULT_HANDSHAKE_INVOKE_TIMEOUT);
|
|
|
|
|
|
|
|
if(r)
|
|
|
|
{
|
|
|
|
ev.wait();
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!hsh_result)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(context_, "COMMAND_HANDSHAKE Failed");
|
2014-03-03 15:07:58 -07:00
|
|
|
m_net_server.get_config_object().close(context_.m_connection_id);
|
|
|
|
}
|
2016-10-26 13:00:08 -06:00
|
|
|
else
|
|
|
|
{
|
|
|
|
try_get_support_flags(context_, [](p2p_connection_context& flags_context, const uint32_t& support_flags)
|
|
|
|
{
|
|
|
|
flags_context.support_flags = support_flags;
|
|
|
|
});
|
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
return hsh_result;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2014-05-25 11:06:40 -06:00
|
|
|
bool node_server<t_payload_net_handler>::do_peer_timed_sync(const epee::net_utils::connection_context_base& context_, peerid_type peer_id)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
typename COMMAND_TIMED_SYNC::request arg = AUTO_VAL_INIT(arg);
|
|
|
|
m_payload_handler.get_payload_sync_data(arg.payload_data);
|
|
|
|
|
2015-12-13 21:54:39 -07:00
|
|
|
bool r = epee::net_utils::async_invoke_remote_command2<typename COMMAND_TIMED_SYNC::response>(context_.m_connection_id, COMMAND_TIMED_SYNC::ID, arg, m_net_server.get_config_object(),
|
2014-03-03 15:07:58 -07:00
|
|
|
[this](int code, const typename COMMAND_TIMED_SYNC::response& rsp, p2p_connection_context& context)
|
|
|
|
{
|
2017-06-04 15:37:53 -06:00
|
|
|
context.m_in_timedsync = false;
|
2014-03-03 15:07:58 -07:00
|
|
|
if(code < 0)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(context, "COMMAND_TIMED_SYNC invoke failed. (" << code << ", " << epee::levin::get_err_descr(code) << ")");
|
2014-03-03 15:07:58 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-05-27 04:35:54 -06:00
|
|
|
if(!handle_remote_peerlist(rsp.local_peerlist_new, rsp.local_time, context))
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
LOG_WARNING_CC(context, "COMMAND_TIMED_SYNC: failed to handle_remote_peerlist(...), closing connection.");
|
2014-03-03 15:07:58 -07:00
|
|
|
m_net_server.get_config_object().close(context.m_connection_id );
|
2017-05-27 04:35:54 -06:00
|
|
|
add_host_fail(context.m_remote_address);
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
|
|
|
if(!context.m_is_income)
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
m_peerlist.set_peer_just_seen(context.peer_id, context.m_remote_address, context.m_pruning_seed);
|
2014-03-03 15:07:58 -07:00
|
|
|
m_payload_handler.process_payload_sync_data(rsp.payload_data, context, false);
|
|
|
|
});
|
|
|
|
|
|
|
|
if(!r)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(context_, "COMMAND_TIMED_SYNC Failed");
|
2014-03-03 15:07:58 -07:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
size_t node_server<t_payload_net_handler>::get_random_index_with_fixed_probability(size_t max_index)
|
|
|
|
{
|
|
|
|
//divide by zero workaround
|
|
|
|
if(!max_index)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
size_t x = crypto::rand<size_t>()%(max_index+1);
|
|
|
|
size_t res = (x*x*x)/(max_index*max_index); //parabola \/
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MDEBUG("Random connection index=" << res << "(x="<< x << ", max_index=" << max_index << ")");
|
2014-03-03 15:07:58 -07:00
|
|
|
return res;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::is_peer_used(const peerlist_entry& peer)
|
|
|
|
{
|
|
|
|
|
|
|
|
if(m_config.m_peer_id == peer.id)
|
|
|
|
return true;//dont make connections to ourself
|
|
|
|
|
|
|
|
bool used = false;
|
|
|
|
m_net_server.get_config_object().foreach_connection([&](const p2p_connection_context& cntxt)
|
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
if(cntxt.peer_id == peer.id || (!cntxt.m_is_income && peer.adr == cntxt.m_remote_address))
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
used = true;
|
|
|
|
return false;//stop enumerating
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
|
|
|
return used;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-02-08 17:11:58 -07:00
|
|
|
bool node_server<t_payload_net_handler>::is_peer_used(const anchor_peerlist_entry& peer)
|
|
|
|
{
|
|
|
|
if(m_config.m_peer_id == peer.id) {
|
|
|
|
return true;//dont make connections to ourself
|
|
|
|
}
|
|
|
|
|
|
|
|
bool used = false;
|
|
|
|
|
|
|
|
m_net_server.get_config_object().foreach_connection([&](const p2p_connection_context& cntxt)
|
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
if(cntxt.peer_id == peer.id || (!cntxt.m_is_income && peer.adr == cntxt.m_remote_address))
|
2017-02-08 17:11:58 -07:00
|
|
|
{
|
|
|
|
used = true;
|
|
|
|
|
|
|
|
return false;//stop enumerating
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
|
|
|
return used;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-05-27 04:35:54 -06:00
|
|
|
bool node_server<t_payload_net_handler>::is_addr_connected(const epee::net_utils::network_address& peer)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
bool connected = false;
|
|
|
|
m_net_server.get_config_object().foreach_connection([&](const p2p_connection_context& cntxt)
|
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
if(!cntxt.m_is_income && peer == cntxt.m_remote_address)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
connected = true;
|
|
|
|
return false;//stop enumerating
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
|
|
|
return connected;
|
|
|
|
}
|
|
|
|
|
2014-05-25 11:06:40 -06:00
|
|
|
#define LOG_PRINT_CC_PRIORITY_NODE(priority, con, msg) \
|
|
|
|
do { \
|
|
|
|
if (priority) {\
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
LOG_INFO_CC(con, "[priority]" << msg); \
|
2014-05-25 11:06:40 -06:00
|
|
|
} else {\
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
LOG_INFO_CC(con, msg); \
|
2014-05-25 11:06:40 -06:00
|
|
|
} \
|
|
|
|
} while(0)
|
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
template<class t_payload_net_handler>
|
2017-05-27 04:35:54 -06:00
|
|
|
bool node_server<t_payload_net_handler>::try_to_connect_and_handshake_with_new_peer(const epee::net_utils::network_address& na, bool just_take_peerlist, uint64_t last_seen_stamp, PeerType peer_type, uint64_t first_seen_stamp)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
2018-01-19 23:36:19 -07:00
|
|
|
if (m_current_number_of_out_peers == m_config.m_net_config.max_out_connection_count) // out peers limit
|
2015-12-13 21:54:39 -07:00
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2018-01-19 23:36:19 -07:00
|
|
|
else if (m_current_number_of_out_peers > m_config.m_net_config.max_out_connection_count)
|
2015-12-13 21:54:39 -07:00
|
|
|
{
|
|
|
|
m_net_server.get_config_object().del_out_connections(1);
|
|
|
|
m_current_number_of_out_peers --; // atomic variable, update time = 1s
|
|
|
|
return false;
|
|
|
|
}
|
2017-05-27 04:35:54 -06:00
|
|
|
MDEBUG("Connecting to " << na.str() << "(peer_type=" << peer_type << ", last_seen: "
|
2014-05-25 11:06:40 -06:00
|
|
|
<< (last_seen_stamp ? epee::misc_utils::get_time_interval_string(time(NULL) - last_seen_stamp):"never")
|
|
|
|
<< ")...");
|
2014-03-03 15:07:58 -07:00
|
|
|
|
2017-06-28 02:00:29 -06:00
|
|
|
CHECK_AND_ASSERT_MES(na.get_type_id() == epee::net_utils::ipv4_network_address::ID, false,
|
|
|
|
"Only IPv4 addresses are supported here");
|
2017-05-27 04:35:54 -06:00
|
|
|
const epee::net_utils::ipv4_network_address &ipv4 = na.as<const epee::net_utils::ipv4_network_address>();
|
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
typename net_server::t_connection_context con = AUTO_VAL_INIT(con);
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
con.m_anchor = peer_type == anchor;
|
2017-05-27 04:35:54 -06:00
|
|
|
bool res = m_net_server.connect(epee::string_tools::get_ip_string_from_int32(ipv4.ip()),
|
|
|
|
epee::string_tools::num_to_string_fast(ipv4.port()),
|
2014-03-03 15:07:58 -07:00
|
|
|
m_config.m_net_config.connection_timeout,
|
2018-10-13 04:19:17 -06:00
|
|
|
con);
|
2014-05-25 11:06:40 -06:00
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
if(!res)
|
|
|
|
{
|
2014-05-25 11:06:40 -06:00
|
|
|
bool is_priority = is_priority_node(na);
|
2017-05-27 04:35:54 -06:00
|
|
|
LOG_PRINT_CC_PRIORITY_NODE(is_priority, con, "Connect failed to " << na.str()
|
2014-03-03 15:07:58 -07:00
|
|
|
/*<< ", try " << try_count*/);
|
|
|
|
//m_peerlist.set_peer_unreachable(pe);
|
|
|
|
return false;
|
|
|
|
}
|
2014-05-25 11:06:40 -06:00
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
peerid_type pi = AUTO_VAL_INIT(pi);
|
|
|
|
res = do_handshake_with_peer(pi, con, just_take_peerlist);
|
2014-05-25 11:06:40 -06:00
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
if(!res)
|
|
|
|
{
|
2014-05-25 11:06:40 -06:00
|
|
|
bool is_priority = is_priority_node(na);
|
|
|
|
LOG_PRINT_CC_PRIORITY_NODE(is_priority, con, "Failed to HANDSHAKE with peer "
|
2017-05-27 04:35:54 -06:00
|
|
|
<< na.str()
|
2014-03-03 15:07:58 -07:00
|
|
|
/*<< ", try " << try_count*/);
|
|
|
|
return false;
|
|
|
|
}
|
2014-05-25 11:06:40 -06:00
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
if(just_take_peerlist)
|
|
|
|
{
|
|
|
|
m_net_server.get_config_object().close(con.m_connection_id);
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
LOG_DEBUG_CC(con, "CONNECTION HANDSHAKED OK AND CLOSED.");
|
2014-03-03 15:07:58 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
peerlist_entry pe_local = AUTO_VAL_INIT(pe_local);
|
|
|
|
pe_local.adr = na;
|
|
|
|
pe_local.id = pi;
|
2014-08-20 09:57:29 -06:00
|
|
|
time_t last_seen;
|
|
|
|
time(&last_seen);
|
|
|
|
pe_local.last_seen = static_cast<int64_t>(last_seen);
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
pe_local.pruning_seed = con.m_pruning_seed;
|
2014-03-03 15:07:58 -07:00
|
|
|
m_peerlist.append_with_peer_white(pe_local);
|
|
|
|
//update last seen and push it to peerlist manager
|
|
|
|
|
2017-02-08 17:11:58 -07:00
|
|
|
anchor_peerlist_entry ape = AUTO_VAL_INIT(ape);
|
|
|
|
ape.adr = na;
|
|
|
|
ape.id = pi;
|
|
|
|
ape.first_seen = first_seen_stamp ? first_seen_stamp : time(nullptr);
|
|
|
|
|
|
|
|
m_peerlist.append_with_peer_anchor(ape);
|
|
|
|
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
LOG_DEBUG_CC(con, "CONNECTION HANDSHAKED OK.");
|
2014-03-03 15:07:58 -07:00
|
|
|
return true;
|
|
|
|
}
|
2014-05-25 11:06:40 -06:00
|
|
|
|
2017-01-20 16:59:04 -07:00
|
|
|
template<class t_payload_net_handler>
|
2017-05-27 04:35:54 -06:00
|
|
|
bool node_server<t_payload_net_handler>::check_connection_and_handshake_with_peer(const epee::net_utils::network_address& na, uint64_t last_seen_stamp)
|
2017-01-20 16:59:04 -07:00
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
LOG_PRINT_L1("Connecting to " << na.str() << "(last_seen: "
|
2017-01-20 16:59:04 -07:00
|
|
|
<< (last_seen_stamp ? epee::misc_utils::get_time_interval_string(time(NULL) - last_seen_stamp):"never")
|
|
|
|
<< ")...");
|
|
|
|
|
2017-06-28 02:00:29 -06:00
|
|
|
CHECK_AND_ASSERT_MES(na.get_type_id() == epee::net_utils::ipv4_network_address::ID, false,
|
|
|
|
"Only IPv4 addresses are supported here");
|
2017-05-27 04:35:54 -06:00
|
|
|
const epee::net_utils::ipv4_network_address &ipv4 = na.as<epee::net_utils::ipv4_network_address>();
|
|
|
|
|
2017-01-20 16:59:04 -07:00
|
|
|
typename net_server::t_connection_context con = AUTO_VAL_INIT(con);
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
con.m_anchor = false;
|
2017-05-27 04:35:54 -06:00
|
|
|
bool res = m_net_server.connect(epee::string_tools::get_ip_string_from_int32(ipv4.ip()),
|
|
|
|
epee::string_tools::num_to_string_fast(ipv4.port()),
|
2017-01-20 16:59:04 -07:00
|
|
|
m_config.m_net_config.connection_timeout,
|
2018-10-13 04:19:17 -06:00
|
|
|
con);
|
2017-01-20 16:59:04 -07:00
|
|
|
|
|
|
|
if (!res) {
|
|
|
|
bool is_priority = is_priority_node(na);
|
|
|
|
|
2017-05-27 04:35:54 -06:00
|
|
|
LOG_PRINT_CC_PRIORITY_NODE(is_priority, con, "Connect failed to " << na.str());
|
2017-01-20 16:59:04 -07:00
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
peerid_type pi = AUTO_VAL_INIT(pi);
|
|
|
|
res = do_handshake_with_peer(pi, con, true);
|
|
|
|
|
|
|
|
if (!res) {
|
|
|
|
bool is_priority = is_priority_node(na);
|
|
|
|
|
2017-05-27 04:35:54 -06:00
|
|
|
LOG_PRINT_CC_PRIORITY_NODE(is_priority, con, "Failed to HANDSHAKE with peer " << na.str());
|
2017-01-20 16:59:04 -07:00
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
m_net_server.get_config_object().close(con.m_connection_id);
|
|
|
|
|
2017-01-21 03:22:04 -07:00
|
|
|
LOG_DEBUG_CC(con, "CONNECTION HANDSHAKED OK AND CLOSED.");
|
2017-01-20 16:59:04 -07:00
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2014-05-25 11:06:40 -06:00
|
|
|
#undef LOG_PRINT_CC_PRIORITY_NODE
|
|
|
|
|
2015-11-23 10:34:55 -07:00
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-05-27 04:35:54 -06:00
|
|
|
bool node_server<t_payload_net_handler>::is_addr_recently_failed(const epee::net_utils::network_address& addr)
|
2015-11-23 10:34:55 -07:00
|
|
|
{
|
|
|
|
CRITICAL_REGION_LOCAL(m_conn_fails_cache_lock);
|
|
|
|
auto it = m_conn_fails_cache.find(addr);
|
|
|
|
if(it == m_conn_fails_cache.end())
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if(time(NULL) - it->second > P2P_FAILED_ADDR_FORGET_SECONDS)
|
|
|
|
return false;
|
|
|
|
else
|
|
|
|
return true;
|
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-02-08 17:11:58 -07:00
|
|
|
bool node_server<t_payload_net_handler>::make_new_connection_from_anchor_peerlist(const std::vector<anchor_peerlist_entry>& anchor_peerlist)
|
|
|
|
{
|
|
|
|
for (const auto& pe: anchor_peerlist) {
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
_note("Considering connecting (out) to anchor peer: " << peerid_type(pe.id) << " " << pe.adr.str());
|
2017-02-08 17:11:58 -07:00
|
|
|
|
|
|
|
if(is_peer_used(pe)) {
|
|
|
|
_note("Peer is used");
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2017-05-27 04:35:54 -06:00
|
|
|
if(!is_remote_host_allowed(pe.adr)) {
|
2017-02-08 17:11:58 -07:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(is_addr_recently_failed(pe.adr)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2017-08-20 14:15:53 -06:00
|
|
|
MDEBUG("Selected peer: " << peerid_to_string(pe.id) << " " << pe.adr.str()
|
2017-02-08 17:11:58 -07:00
|
|
|
<< "[peer_type=" << anchor
|
|
|
|
<< "] first_seen: " << epee::misc_utils::get_time_interval_string(time(NULL) - pe.first_seen));
|
|
|
|
|
|
|
|
if(!try_to_connect_and_handshake_with_new_peer(pe.adr, false, 0, anchor, pe.first_seen)) {
|
|
|
|
_note("Handshake failed");
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2014-03-03 15:07:58 -07:00
|
|
|
bool node_server<t_payload_net_handler>::make_new_connection_from_peerlist(bool use_white_list)
|
|
|
|
{
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
size_t max_random_index = 0;
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
std::set<size_t> tried_peers;
|
|
|
|
|
|
|
|
size_t try_count = 0;
|
|
|
|
size_t rand_count = 0;
|
|
|
|
while(rand_count < (max_random_index+1)*3 && try_count < 10 && !m_net_server.is_stop_signal_sent())
|
|
|
|
{
|
|
|
|
++rand_count;
|
2017-02-28 09:39:39 -07:00
|
|
|
size_t random_index;
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
const uint32_t next_needed_pruning_stripe = m_payload_handler.get_next_needed_pruning_stripe().second;
|
2017-02-28 09:39:39 -07:00
|
|
|
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
std::deque<size_t> filtered;
|
|
|
|
const size_t limit = use_white_list ? 20 : std::numeric_limits<size_t>::max();
|
|
|
|
size_t idx = 0;
|
|
|
|
m_peerlist.foreach (use_white_list, [&filtered, &idx, limit, next_needed_pruning_stripe](const peerlist_entry &pe){
|
|
|
|
if (filtered.size() >= limit)
|
2018-01-18 09:54:52 -07:00
|
|
|
return false;
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
if (next_needed_pruning_stripe == 0 || pe.pruning_seed == 0)
|
|
|
|
filtered.push_back(idx);
|
|
|
|
else if (next_needed_pruning_stripe == tools::get_pruning_stripe(pe.pruning_seed))
|
|
|
|
filtered.push_front(idx);
|
|
|
|
++idx;
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
if (filtered.empty())
|
|
|
|
{
|
|
|
|
MDEBUG("No available peer in " << (use_white_list ? "white" : "gray") << " list filtered by " << next_needed_pruning_stripe);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (use_white_list)
|
|
|
|
{
|
|
|
|
// if using the white list, we first pick in the set of peers we've already been using earlier
|
|
|
|
random_index = get_random_index_with_fixed_probability(std::min<uint64_t>(filtered.size() - 1, 20));
|
|
|
|
CRITICAL_REGION_LOCAL(m_used_stripe_peers_mutex);
|
|
|
|
if (next_needed_pruning_stripe > 0 && next_needed_pruning_stripe <= (1ul << CRYPTONOTE_PRUNING_LOG_STRIPES) && !m_used_stripe_peers[next_needed_pruning_stripe-1].empty())
|
|
|
|
{
|
|
|
|
const epee::net_utils::network_address na = m_used_stripe_peers[next_needed_pruning_stripe-1].front();
|
|
|
|
m_used_stripe_peers[next_needed_pruning_stripe-1].pop_front();
|
|
|
|
for (size_t i = 0; i < filtered.size(); ++i)
|
|
|
|
{
|
|
|
|
peerlist_entry pe;
|
|
|
|
if (m_peerlist.get_white_peer_by_index(pe, filtered[i]) && pe.adr == na)
|
|
|
|
{
|
|
|
|
MDEBUG("Reusing stripe " << next_needed_pruning_stripe << " peer " << pe.adr.str());
|
|
|
|
random_index = i;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2017-02-28 09:39:39 -07:00
|
|
|
}
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
else
|
|
|
|
random_index = crypto::rand<size_t>() % filtered.size();
|
2017-02-28 09:39:39 -07:00
|
|
|
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
CHECK_AND_ASSERT_MES(random_index < filtered.size(), false, "random_index < filtered.size() failed!!");
|
|
|
|
random_index = filtered[random_index];
|
|
|
|
CHECK_AND_ASSERT_MES(random_index < (use_white_list ? m_peerlist.get_white_peers_count() : m_peerlist.get_gray_peers_count()),
|
|
|
|
false, "random_index < peers size failed!!");
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
if(tried_peers.count(random_index))
|
|
|
|
continue;
|
|
|
|
|
|
|
|
tried_peers.insert(random_index);
|
|
|
|
peerlist_entry pe = AUTO_VAL_INIT(pe);
|
|
|
|
bool r = use_white_list ? m_peerlist.get_white_peer_by_index(pe, random_index):m_peerlist.get_gray_peer_by_index(pe, random_index);
|
|
|
|
CHECK_AND_ASSERT_MES(r, false, "Failed to get random peer from peerlist(white:" << use_white_list << ")");
|
|
|
|
|
|
|
|
++try_count;
|
|
|
|
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
_note("Considering connecting (out) to " << (use_white_list ? "white" : "gray") << " list peer: " <<
|
|
|
|
peerid_to_string(pe.id) << " " << pe.adr.str() << ", pruning seed " << epee::string_tools::to_string_hex(pe.pruning_seed) <<
|
|
|
|
" (stripe " << next_needed_pruning_stripe << " needed)");
|
2015-02-12 12:59:39 -07:00
|
|
|
|
|
|
|
if(is_peer_used(pe)) {
|
2015-12-13 21:54:39 -07:00
|
|
|
_note("Peer is used");
|
2014-03-03 15:07:58 -07:00
|
|
|
continue;
|
2015-12-13 21:54:39 -07:00
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
|
2017-05-27 04:35:54 -06:00
|
|
|
if(!is_remote_host_allowed(pe.adr))
|
2015-11-23 10:34:55 -07:00
|
|
|
continue;
|
|
|
|
|
|
|
|
if(is_addr_recently_failed(pe.adr))
|
|
|
|
continue;
|
|
|
|
|
2017-08-20 14:15:53 -06:00
|
|
|
MDEBUG("Selected peer: " << peerid_to_string(pe.id) << " " << pe.adr.str()
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
<< ", pruning seed " << epee::string_tools::to_string_hex(pe.pruning_seed) << " "
|
2017-02-08 17:11:58 -07:00
|
|
|
<< "[peer_list=" << (use_white_list ? white : gray)
|
2014-05-25 11:06:40 -06:00
|
|
|
<< "] last_seen: " << (pe.last_seen ? epee::misc_utils::get_time_interval_string(time(NULL) - pe.last_seen) : "never"));
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2017-02-08 17:11:58 -07:00
|
|
|
if(!try_to_connect_and_handshake_with_new_peer(pe.adr, false, pe.last_seen, use_white_list ? white : gray)) {
|
2015-12-13 21:54:39 -07:00
|
|
|
_note("Handshake failed");
|
2014-03-03 15:07:58 -07:00
|
|
|
continue;
|
2015-12-13 21:54:39 -07:00
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-08-09 15:44:39 -06:00
|
|
|
bool node_server<t_payload_net_handler>::connect_to_seed()
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
2018-01-17 04:17:21 -07:00
|
|
|
if (m_seed_nodes.empty() || m_offline || !m_exclusive_peers.empty())
|
2017-08-09 15:44:39 -06:00
|
|
|
return true;
|
2014-05-25 11:06:40 -06:00
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
size_t try_count = 0;
|
|
|
|
size_t current_index = crypto::rand<size_t>()%m_seed_nodes.size();
|
|
|
|
while(true)
|
2015-12-13 21:54:39 -07:00
|
|
|
{
|
2014-03-03 15:07:58 -07:00
|
|
|
if(m_net_server.is_stop_signal_sent())
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if(try_to_connect_and_handshake_with_new_peer(m_seed_nodes[current_index], true))
|
|
|
|
break;
|
|
|
|
if(++try_count > m_seed_nodes.size())
|
|
|
|
{
|
2018-04-29 07:57:08 -06:00
|
|
|
if (!m_fallback_seed_nodes_added)
|
2017-03-17 17:39:47 -06:00
|
|
|
{
|
|
|
|
MWARNING("Failed to connect to any of seed peers, trying fallback seeds");
|
2018-04-29 07:57:08 -06:00
|
|
|
current_index = m_seed_nodes.size();
|
2018-02-16 04:04:04 -07:00
|
|
|
for (const auto &peer: get_seed_nodes(m_nettype))
|
2017-03-17 17:39:47 -06:00
|
|
|
{
|
|
|
|
MDEBUG("Fallback seed node: " << peer);
|
2018-06-10 21:43:18 -06:00
|
|
|
append_net_address(m_seed_nodes, peer, cryptonote::get_config(m_nettype).P2P_DEFAULT_PORT);
|
2017-03-17 17:39:47 -06:00
|
|
|
}
|
2018-04-29 07:57:08 -06:00
|
|
|
m_fallback_seed_nodes_added = true;
|
|
|
|
if (current_index == m_seed_nodes.size())
|
|
|
|
{
|
|
|
|
MWARNING("No fallback seeds, continuing without seeds");
|
|
|
|
break;
|
|
|
|
}
|
2017-03-17 17:39:47 -06:00
|
|
|
// continue for another few cycles
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
MWARNING("Failed to connect to any of seed peers, continuing without seeds");
|
|
|
|
break;
|
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
2014-03-20 05:46:11 -06:00
|
|
|
if(++current_index >= m_seed_nodes.size())
|
2014-03-03 15:07:58 -07:00
|
|
|
current_index = 0;
|
|
|
|
}
|
2017-08-09 15:44:39 -06:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::connections_maker()
|
|
|
|
{
|
2018-02-01 04:48:03 -07:00
|
|
|
if (m_offline) return true;
|
2017-08-09 15:44:39 -06:00
|
|
|
if (!connect_to_peerlist(m_exclusive_peers)) return false;
|
|
|
|
|
|
|
|
if (!m_exclusive_peers.empty()) return true;
|
|
|
|
|
|
|
|
size_t start_conn_count = get_outgoing_connections_count();
|
|
|
|
if(!m_peerlist.get_white_peers_count() && m_seed_nodes.size())
|
|
|
|
{
|
|
|
|
if (!connect_to_seed())
|
|
|
|
return false;
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
|
|
|
|
2014-05-25 11:06:40 -06:00
|
|
|
if (!connect_to_peerlist(m_priority_peers)) return false;
|
2014-03-03 15:07:58 -07:00
|
|
|
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
size_t base_expected_white_connections = (m_config.m_net_config.max_out_connection_count*P2P_DEFAULT_WHITELIST_CONNECTIONS_PERCENT)/100;
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
size_t conn_count = get_outgoing_connections_count();
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
while(conn_count < m_config.m_net_config.max_out_connection_count)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
const size_t expected_white_connections = m_payload_handler.get_next_needed_pruning_stripe().second ? m_config.m_net_config.max_out_connection_count : base_expected_white_connections;
|
2014-03-03 15:07:58 -07:00
|
|
|
if(conn_count < expected_white_connections)
|
|
|
|
{
|
2017-02-08 17:11:58 -07:00
|
|
|
//start from anchor list
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
while (get_outgoing_connections_count() < P2P_DEFAULT_ANCHOR_CONNECTIONS_COUNT
|
|
|
|
&& make_expected_connections_count(anchor, P2P_DEFAULT_ANCHOR_CONNECTIONS_COUNT));
|
2017-02-08 17:11:58 -07:00
|
|
|
//then do white list
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
while (get_outgoing_connections_count() < expected_white_connections
|
|
|
|
&& make_expected_connections_count(white, expected_white_connections));
|
2017-02-08 17:11:58 -07:00
|
|
|
//then do grey list
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
while (get_outgoing_connections_count() < m_config.m_net_config.max_out_connection_count
|
|
|
|
&& make_expected_connections_count(gray, m_config.m_net_config.max_out_connection_count));
|
2014-03-03 15:07:58 -07:00
|
|
|
}else
|
|
|
|
{
|
|
|
|
//start from grey list
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
while (get_outgoing_connections_count() < m_config.m_net_config.max_out_connection_count
|
|
|
|
&& make_expected_connections_count(gray, m_config.m_net_config.max_out_connection_count));
|
2014-03-03 15:07:58 -07:00
|
|
|
//and then do white list
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
while (get_outgoing_connections_count() < m_config.m_net_config.max_out_connection_count
|
|
|
|
&& make_expected_connections_count(white, m_config.m_net_config.max_out_connection_count));
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
if(m_net_server.is_stop_signal_sent())
|
|
|
|
return false;
|
|
|
|
conn_count = get_outgoing_connections_count();
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
|
|
|
|
2018-01-19 23:36:19 -07:00
|
|
|
if (start_conn_count == get_outgoing_connections_count() && start_conn_count < m_config.m_net_config.max_out_connection_count)
|
2017-08-09 15:44:39 -06:00
|
|
|
{
|
|
|
|
MINFO("Failed to connect to any, trying seeds");
|
|
|
|
if (!connect_to_seed())
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2017-02-08 17:11:58 -07:00
|
|
|
bool node_server<t_payload_net_handler>::make_expected_connections_count(PeerType peer_type, size_t expected_connections)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
2015-12-07 13:21:45 -07:00
|
|
|
if (m_offline)
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
return false;
|
2015-12-07 13:21:45 -07:00
|
|
|
|
2017-02-08 17:11:58 -07:00
|
|
|
std::vector<anchor_peerlist_entry> apl;
|
|
|
|
|
|
|
|
if (peer_type == anchor) {
|
|
|
|
m_peerlist.get_and_empty_anchor_peerlist(apl);
|
|
|
|
}
|
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
size_t conn_count = get_outgoing_connections_count();
|
|
|
|
//add new connections from white peers
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
if(conn_count < expected_connections)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
if(m_net_server.is_stop_signal_sent())
|
|
|
|
return false;
|
|
|
|
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
MDEBUG("Making expected connection, type " << peer_type << ", " << conn_count << "/" << expected_connections << " connections");
|
|
|
|
|
2017-02-08 17:11:58 -07:00
|
|
|
if (peer_type == anchor && !make_new_connection_from_anchor_peerlist(apl)) {
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
return false;
|
2017-02-08 17:11:58 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
if (peer_type == white && !make_new_connection_from_peerlist(true)) {
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
return false;
|
2017-02-08 17:11:58 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
if (peer_type == gray && !make_new_connection_from_peerlist(false)) {
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
return false;
|
2017-02-08 17:11:58 -07:00
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
size_t node_server<t_payload_net_handler>::get_outgoing_connections_count()
|
|
|
|
{
|
|
|
|
size_t count = 0;
|
|
|
|
m_net_server.get_config_object().foreach_connection([&](const p2p_connection_context& cntxt)
|
|
|
|
{
|
|
|
|
if(!cntxt.m_is_income)
|
|
|
|
++count;
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
|
|
|
return count;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2018-01-20 14:44:23 -07:00
|
|
|
size_t node_server<t_payload_net_handler>::get_incoming_connections_count()
|
|
|
|
{
|
|
|
|
size_t count = 0;
|
|
|
|
m_net_server.get_config_object().foreach_connection([&](const p2p_connection_context& cntxt)
|
|
|
|
{
|
|
|
|
if(cntxt.m_is_income)
|
|
|
|
++count;
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
|
|
|
return count;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2014-03-03 15:07:58 -07:00
|
|
|
bool node_server<t_payload_net_handler>::idle_worker()
|
|
|
|
{
|
|
|
|
m_peer_handshake_idle_maker_interval.do_call(boost::bind(&node_server<t_payload_net_handler>::peer_sync_idle_maker, this));
|
|
|
|
m_connections_maker_interval.do_call(boost::bind(&node_server<t_payload_net_handler>::connections_maker, this));
|
2017-01-20 16:59:04 -07:00
|
|
|
m_gray_peerlist_housekeeping_interval.do_call(boost::bind(&node_server<t_payload_net_handler>::gray_peerlist_housekeeping, this));
|
2014-03-03 15:07:58 -07:00
|
|
|
m_peerlist_store_interval.do_call(boost::bind(&node_server<t_payload_net_handler>::store_config, this));
|
2018-05-25 05:34:52 -06:00
|
|
|
m_incoming_connections_interval.do_call(boost::bind(&node_server<t_payload_net_handler>::check_incoming_connections, this));
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::check_incoming_connections()
|
|
|
|
{
|
2018-11-01 08:51:08 -06:00
|
|
|
if (m_offline)
|
2018-05-25 05:34:52 -06:00
|
|
|
return true;
|
|
|
|
if (get_incoming_connections_count() == 0)
|
|
|
|
{
|
2018-11-01 08:51:08 -06:00
|
|
|
if (m_hide_my_port || m_config.m_net_config.max_in_connection_count == 0)
|
|
|
|
{
|
|
|
|
MGINFO("Incoming connections disabled, enable them for full connectivity");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
const el::Level level = el::Level::Warning;
|
|
|
|
MCLOG_RED(level, "global", "No incoming connections - check firewalls/routers allow port " << get_this_peer_port());
|
|
|
|
}
|
2018-05-25 05:34:52 -06:00
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::peer_sync_idle_maker()
|
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MDEBUG("STARTED PEERLIST IDLE HANDSHAKE");
|
2014-05-25 11:06:40 -06:00
|
|
|
typedef std::list<std::pair<epee::net_utils::connection_context_base, peerid_type> > local_connects_type;
|
2014-03-03 15:07:58 -07:00
|
|
|
local_connects_type cncts;
|
2017-06-04 15:37:53 -06:00
|
|
|
m_net_server.get_config_object().foreach_connection([&](p2p_connection_context& cntxt)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
2017-06-04 15:37:53 -06:00
|
|
|
if(cntxt.peer_id && !cntxt.m_in_timedsync)
|
|
|
|
{
|
|
|
|
cntxt.m_in_timedsync = true;
|
2014-03-03 15:07:58 -07:00
|
|
|
cncts.push_back(local_connects_type::value_type(cntxt, cntxt.peer_id));//do idle sync only with handshaked connections
|
2017-06-04 15:37:53 -06:00
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
|
|
|
std::for_each(cncts.begin(), cncts.end(), [&](const typename local_connects_type::value_type& vl){do_peer_timed_sync(vl.first, vl.second);});
|
|
|
|
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MDEBUG("FINISHED PEERLIST IDLE HANDSHAKE");
|
2014-03-03 15:07:58 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2018-12-05 15:25:27 -07:00
|
|
|
bool node_server<t_payload_net_handler>::fix_time_delta(std::vector<peerlist_entry>& local_peerlist, time_t local_time, int64_t& delta)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
//fix time delta
|
|
|
|
time_t now = 0;
|
|
|
|
time(&now);
|
|
|
|
delta = now - local_time;
|
|
|
|
|
2017-01-22 13:38:10 -07:00
|
|
|
for(peerlist_entry& be: local_peerlist)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
if(be.last_seen > local_time)
|
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
MWARNING("FOUND FUTURE peerlist for entry " << be.adr.str() << " last_seen: " << be.last_seen << ", local_time(on remote node):" << local_time);
|
2014-03-03 15:07:58 -07:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
be.last_seen += delta;
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
#ifdef CRYPTONOTE_PRUNING_DEBUG_SPOOF_SEED
|
|
|
|
be.pruning_seed = tools::make_pruning_seed(1 + (be.adr.as<epee::net_utils::ipv4_network_address>().ip()) % (1ul << CRYPTONOTE_PRUNING_LOG_STRIPES), CRYPTONOTE_PRUNING_LOG_STRIPES);
|
|
|
|
#endif
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2018-12-05 15:25:27 -07:00
|
|
|
bool node_server<t_payload_net_handler>::handle_remote_peerlist(const std::vector<peerlist_entry>& peerlist, time_t local_time, const epee::net_utils::connection_context_base& context)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
int64_t delta = 0;
|
2018-12-05 15:25:27 -07:00
|
|
|
std::vector<peerlist_entry> peerlist_ = peerlist;
|
2014-03-03 15:07:58 -07:00
|
|
|
if(!fix_time_delta(peerlist_, local_time, delta))
|
|
|
|
return false;
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
LOG_DEBUG_CC(context, "REMOTE PEERLIST: TIME_DELTA: " << delta << ", remote peerlist size=" << peerlist_.size());
|
|
|
|
LOG_DEBUG_CC(context, "REMOTE PEERLIST: " << print_peerlist_to_string(peerlist_));
|
2014-03-03 15:07:58 -07:00
|
|
|
return m_peerlist.merge_peerlist(peerlist_);
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::get_local_node_data(basic_node_data& node_data)
|
|
|
|
{
|
2014-04-30 11:52:21 -06:00
|
|
|
time_t local_time;
|
|
|
|
time(&local_time);
|
|
|
|
node_data.local_time = local_time;
|
2014-03-03 15:07:58 -07:00
|
|
|
node_data.peer_id = m_config.m_peer_id;
|
|
|
|
if(!m_hide_my_port)
|
2017-09-01 01:50:22 -06:00
|
|
|
node_data.my_port = m_external_port ? m_external_port : m_listening_port;
|
2015-12-13 21:54:39 -07:00
|
|
|
else
|
2014-03-03 15:07:58 -07:00
|
|
|
node_data.my_port = 0;
|
2014-07-16 11:30:15 -06:00
|
|
|
node_data.network_id = m_network_id;
|
2014-03-03 15:07:58 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
#ifdef ALLOW_DEBUG_COMMANDS
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::check_trust(const proof_of_trust& tr)
|
|
|
|
{
|
|
|
|
uint64_t local_time = time(NULL);
|
|
|
|
uint64_t time_delata = local_time > tr.time ? local_time - tr.time: tr.time - local_time;
|
|
|
|
if(time_delata > 24*60*60 )
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
MWARNING("check_trust failed to check time conditions, local_time=" << local_time << ", proof_time=" << tr.time);
|
2014-03-03 15:07:58 -07:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if(m_last_stat_request_time >= tr.time )
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
MWARNING("check_trust failed to check time conditions, last_stat_request_time=" << m_last_stat_request_time << ", proof_time=" << tr.time);
|
2014-03-03 15:07:58 -07:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if(m_config.m_peer_id != tr.peer_id)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
MWARNING("check_trust failed: peer_id mismatch (passed " << tr.peer_id << ", expected " << m_config.m_peer_id<< ")");
|
2014-03-03 15:07:58 -07:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
crypto::public_key pk = AUTO_VAL_INIT(pk);
|
2014-09-04 20:14:36 -06:00
|
|
|
epee::string_tools::hex_to_pod(::config::P2P_REMOTE_DEBUG_TRUSTED_PUB_KEY, pk);
|
2017-07-27 08:46:47 -06:00
|
|
|
crypto::hash h = get_proof_of_trust_hash(tr);
|
2014-03-03 15:07:58 -07:00
|
|
|
if(!crypto::check_signature(h, pk, tr.sign))
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
MWARNING("check_trust failed: sign check failed");
|
2014-03-03 15:07:58 -07:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
//update last request time
|
|
|
|
m_last_stat_request_time = tr.time;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
int node_server<t_payload_net_handler>::handle_get_stat_info(int command, typename COMMAND_REQUEST_STAT_INFO::request& arg, typename COMMAND_REQUEST_STAT_INFO::response& rsp, p2p_connection_context& context)
|
|
|
|
{
|
|
|
|
if(!check_trust(arg.tr))
|
|
|
|
{
|
|
|
|
drop_connection(context);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
rsp.connections_count = m_net_server.get_config_object().get_connections_count();
|
|
|
|
rsp.incoming_connections_count = rsp.connections_count - get_outgoing_connections_count();
|
2014-09-12 05:06:51 -06:00
|
|
|
rsp.version = MONERO_VERSION_FULL;
|
2014-03-03 15:07:58 -07:00
|
|
|
rsp.os_version = tools::get_os_version_string();
|
|
|
|
m_payload_handler.get_stat_info(rsp.payload_info);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
int node_server<t_payload_net_handler>::handle_get_network_state(int command, COMMAND_REQUEST_NETWORK_STATE::request& arg, COMMAND_REQUEST_NETWORK_STATE::response& rsp, p2p_connection_context& context)
|
|
|
|
{
|
|
|
|
if(!check_trust(arg.tr))
|
|
|
|
{
|
|
|
|
drop_connection(context);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
m_net_server.get_config_object().foreach_connection([&](const p2p_connection_context& cntxt)
|
|
|
|
{
|
|
|
|
connection_entry ce;
|
2017-05-27 04:35:54 -06:00
|
|
|
ce.adr = cntxt.m_remote_address;
|
2014-03-03 15:07:58 -07:00
|
|
|
ce.id = cntxt.peer_id;
|
|
|
|
ce.is_income = cntxt.m_is_income;
|
|
|
|
rsp.connections_list.push_back(ce);
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
|
|
|
m_peerlist.get_peerlist_full(rsp.local_peerlist_gray, rsp.local_peerlist_white);
|
|
|
|
rsp.my_id = m_config.m_peer_id;
|
|
|
|
rsp.local_time = time(NULL);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
int node_server<t_payload_net_handler>::handle_get_peer_id(int command, COMMAND_REQUEST_PEER_ID::request& arg, COMMAND_REQUEST_PEER_ID::response& rsp, p2p_connection_context& context)
|
|
|
|
{
|
|
|
|
rsp.my_id = m_config.m_peer_id;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
#endif
|
2016-10-26 13:00:08 -06:00
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
int node_server<t_payload_net_handler>::handle_get_support_flags(int command, COMMAND_REQUEST_SUPPORT_FLAGS::request& arg, COMMAND_REQUEST_SUPPORT_FLAGS::response& rsp, p2p_connection_context& context)
|
|
|
|
{
|
|
|
|
rsp.support_flags = m_config.m_support_flags;
|
|
|
|
return 1;
|
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
void node_server<t_payload_net_handler>::request_callback(const epee::net_utils::connection_context_base& context)
|
|
|
|
{
|
|
|
|
m_net_server.get_config_object().request_callback(context.m_connection_id);
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2018-12-06 11:04:33 -07:00
|
|
|
bool node_server<t_payload_net_handler>::relay_notify_to_list(int command, const epee::span<const uint8_t> data_buff, const std::list<boost::uuids::uuid> &connections)
|
2016-11-29 09:21:33 -07:00
|
|
|
{
|
2017-01-22 13:38:10 -07:00
|
|
|
for(const auto& c_id: connections)
|
2016-11-29 09:21:33 -07:00
|
|
|
{
|
|
|
|
m_net_server.get_config_object().notify(command, data_buff, c_id);
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2018-12-06 11:04:33 -07:00
|
|
|
bool node_server<t_payload_net_handler>::relay_notify_to_all(int command, const epee::span<const uint8_t> data_buff, const epee::net_utils::connection_context_base& context)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
std::list<boost::uuids::uuid> connections;
|
|
|
|
m_net_server.get_config_object().foreach_connection([&](const p2p_connection_context& cntxt)
|
|
|
|
{
|
|
|
|
if(cntxt.peer_id && context.m_connection_id != cntxt.m_connection_id)
|
|
|
|
connections.push_back(cntxt.m_connection_id);
|
|
|
|
return true;
|
|
|
|
});
|
2016-11-29 09:21:33 -07:00
|
|
|
return relay_notify_to_list(command, data_buff, connections);
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
void node_server<t_payload_net_handler>::callback(p2p_connection_context& context)
|
|
|
|
{
|
|
|
|
m_payload_handler.on_callback(context);
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2018-12-06 11:04:33 -07:00
|
|
|
bool node_server<t_payload_net_handler>::invoke_notify_to_peer(int command, const epee::span<const uint8_t> req_buff, const epee::net_utils::connection_context_base& context)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
int res = m_net_server.get_config_object().notify(command, req_buff, context.m_connection_id);
|
|
|
|
return res > 0;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2018-12-06 11:04:33 -07:00
|
|
|
bool node_server<t_payload_net_handler>::invoke_command_to_peer(int command, const epee::span<const uint8_t> req_buff, std::string& resp_buff, const epee::net_utils::connection_context_base& context)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
int res = m_net_server.get_config_object().invoke(command, req_buff, resp_buff, context.m_connection_id);
|
|
|
|
return res > 0;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::drop_connection(const epee::net_utils::connection_context_base& context)
|
|
|
|
{
|
|
|
|
m_net_server.get_config_object().close(context.m_connection_id);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler> template<class t_callback>
|
2018-02-02 11:45:12 -07:00
|
|
|
bool node_server<t_payload_net_handler>::try_ping(basic_node_data& node_data, p2p_connection_context& context, const t_callback &cb)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
if(!node_data.my_port)
|
|
|
|
return false;
|
|
|
|
|
2017-06-28 02:00:29 -06:00
|
|
|
CHECK_AND_ASSERT_MES(context.m_remote_address.get_type_id() == epee::net_utils::ipv4_network_address::ID, false,
|
|
|
|
"Only IPv4 addresses are supported here");
|
2017-05-27 04:35:54 -06:00
|
|
|
|
|
|
|
const epee::net_utils::network_address na = context.m_remote_address;
|
|
|
|
uint32_t actual_ip = na.as<const epee::net_utils::ipv4_network_address>().ip();
|
|
|
|
if(!m_peerlist.is_host_allowed(context.m_remote_address))
|
2014-03-03 15:07:58 -07:00
|
|
|
return false;
|
2014-05-25 11:06:40 -06:00
|
|
|
std::string ip = epee::string_tools::get_ip_string_from_int32(actual_ip);
|
|
|
|
std::string port = epee::string_tools::num_to_string_fast(node_data.my_port);
|
2017-08-25 09:14:46 -06:00
|
|
|
epee::net_utils::network_address address{epee::net_utils::ipv4_network_address(actual_ip, node_data.my_port)};
|
2014-03-03 15:07:58 -07:00
|
|
|
peerid_type pr = node_data.peer_id;
|
2017-05-27 04:35:54 -06:00
|
|
|
bool r = m_net_server.connect_async(ip, port, m_config.m_net_config.ping_connection_timeout, [cb, /*context,*/ address, pr, this](
|
2014-03-03 15:07:58 -07:00
|
|
|
const typename net_server::t_connection_context& ping_context,
|
|
|
|
const boost::system::error_code& ec)->bool
|
|
|
|
{
|
|
|
|
if(ec)
|
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
LOG_WARNING_CC(ping_context, "back ping connect failed to " << address.str());
|
2014-03-03 15:07:58 -07:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
COMMAND_PING::request req;
|
|
|
|
COMMAND_PING::response rsp;
|
|
|
|
//vc2010 workaround
|
|
|
|
/*std::string ip_ = ip;
|
|
|
|
std::string port_=port;
|
|
|
|
peerid_type pr_ = pr;
|
|
|
|
auto cb_ = cb;*/
|
2015-05-25 23:07:17 -06:00
|
|
|
|
|
|
|
// GCC 5.1.0 gives error with second use of uint64_t (peerid_type) variable.
|
|
|
|
peerid_type pr_ = pr;
|
|
|
|
|
2014-05-25 11:06:40 -06:00
|
|
|
bool inv_call_res = epee::net_utils::async_invoke_remote_command2<COMMAND_PING::response>(ping_context.m_connection_id, COMMAND_PING::ID, req, m_net_server.get_config_object(),
|
2014-03-03 15:07:58 -07:00
|
|
|
[=](int code, const COMMAND_PING::response& rsp, p2p_connection_context& context)
|
|
|
|
{
|
|
|
|
if(code <= 0)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(ping_context, "Failed to invoke COMMAND_PING to " << address.str() << "(" << code << ", " << epee::levin::get_err_descr(code) << ")");
|
2014-03-03 15:07:58 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(rsp.status != PING_OK_RESPONSE_STATUS_TEXT || pr != rsp.peer_id)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(ping_context, "back ping invoke wrong response \"" << rsp.status << "\" from" << address.str() << ", hsh_peer_id=" << pr_ << ", rsp.peer_id=" << rsp.peer_id);
|
2016-03-13 11:53:27 -06:00
|
|
|
m_net_server.get_config_object().close(ping_context.m_connection_id);
|
2014-03-03 15:07:58 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
m_net_server.get_config_object().close(ping_context.m_connection_id);
|
|
|
|
cb();
|
|
|
|
});
|
|
|
|
|
|
|
|
if(!inv_call_res)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(ping_context, "back ping invoke failed to " << address.str());
|
2014-03-03 15:07:58 -07:00
|
|
|
m_net_server.get_config_object().close(ping_context.m_connection_id);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
2018-10-13 04:19:17 -06:00
|
|
|
});
|
2014-03-03 15:07:58 -07:00
|
|
|
if(!r)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(context, "Failed to call connect_async, network error.");
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2016-10-26 13:00:08 -06:00
|
|
|
bool node_server<t_payload_net_handler>::try_get_support_flags(const p2p_connection_context& context, std::function<void(p2p_connection_context&, const uint32_t&)> f)
|
|
|
|
{
|
|
|
|
COMMAND_REQUEST_SUPPORT_FLAGS::request support_flags_request;
|
|
|
|
bool r = epee::net_utils::async_invoke_remote_command2<typename COMMAND_REQUEST_SUPPORT_FLAGS::response>
|
|
|
|
(
|
|
|
|
context.m_connection_id,
|
|
|
|
COMMAND_REQUEST_SUPPORT_FLAGS::ID,
|
|
|
|
support_flags_request,
|
|
|
|
m_net_server.get_config_object(),
|
|
|
|
[=](int code, const typename COMMAND_REQUEST_SUPPORT_FLAGS::response& rsp, p2p_connection_context& context_)
|
|
|
|
{
|
|
|
|
if(code < 0)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(context_, "COMMAND_REQUEST_SUPPORT_FLAGS invoke failed. (" << code << ", " << epee::levin::get_err_descr(code) << ")");
|
2016-10-26 13:00:08 -06:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
f(context_, rsp.support_flags);
|
|
|
|
},
|
|
|
|
P2P_DEFAULT_HANDSHAKE_INVOKE_TIMEOUT
|
|
|
|
);
|
|
|
|
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
2014-03-03 15:07:58 -07:00
|
|
|
int node_server<t_payload_net_handler>::handle_timed_sync(int command, typename COMMAND_TIMED_SYNC::request& arg, typename COMMAND_TIMED_SYNC::response& rsp, p2p_connection_context& context)
|
|
|
|
{
|
|
|
|
if(!m_payload_handler.process_payload_sync_data(arg.payload_data, context, false))
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(context, "Failed to process_payload_sync_data(), dropping connection");
|
2014-03-03 15:07:58 -07:00
|
|
|
drop_connection(context);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
//fill response
|
|
|
|
rsp.local_time = time(NULL);
|
2017-05-27 04:35:54 -06:00
|
|
|
m_peerlist.get_peerlist_head(rsp.local_peerlist_new);
|
2014-03-03 15:07:58 -07:00
|
|
|
m_payload_handler.get_payload_sync_data(rsp.payload_data);
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
LOG_DEBUG_CC(context, "COMMAND_TIMED_SYNC");
|
2014-03-03 15:07:58 -07:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
int node_server<t_payload_net_handler>::handle_handshake(int command, typename COMMAND_HANDSHAKE::request& arg, typename COMMAND_HANDSHAKE::response& rsp, p2p_connection_context& context)
|
|
|
|
{
|
2014-07-16 11:30:15 -06:00
|
|
|
if(arg.node_data.network_id != m_network_id)
|
2014-03-03 15:07:58 -07:00
|
|
|
{
|
|
|
|
|
2018-12-17 17:05:27 -07:00
|
|
|
LOG_INFO_CC(context, "WRONG NETWORK AGENT CONNECTED! id=" << arg.node_data.network_id);
|
2014-03-03 15:07:58 -07:00
|
|
|
drop_connection(context);
|
2017-05-27 04:35:54 -06:00
|
|
|
add_host_fail(context.m_remote_address);
|
2014-03-03 15:07:58 -07:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!context.m_is_income)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(context, "COMMAND_HANDSHAKE came not from incoming connection");
|
2014-03-03 15:07:58 -07:00
|
|
|
drop_connection(context);
|
2017-05-27 04:35:54 -06:00
|
|
|
add_host_fail(context.m_remote_address);
|
2014-03-03 15:07:58 -07:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(context.peer_id)
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(context, "COMMAND_HANDSHAKE came, but seems that connection already have associated peer_id (double COMMAND_HANDSHAKE?)");
|
2014-03-03 15:07:58 -07:00
|
|
|
drop_connection(context);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2018-01-20 14:44:23 -07:00
|
|
|
if (m_current_number_of_in_peers >= m_config.m_net_config.max_in_connection_count) // in peers limit
|
|
|
|
{
|
|
|
|
LOG_WARNING_CC(context, "COMMAND_HANDSHAKE came, but already have max incoming connections, so dropping this one.");
|
|
|
|
drop_connection(context);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
if(!m_payload_handler.process_payload_sync_data(arg.payload_data, context, true))
|
|
|
|
{
|
2017-08-01 03:39:36 -06:00
|
|
|
LOG_WARNING_CC(context, "COMMAND_HANDSHAKE came, but process_payload_sync_data returned false, dropping connection.");
|
2014-03-03 15:07:58 -07:00
|
|
|
drop_connection(context);
|
|
|
|
return 1;
|
|
|
|
}
|
2017-01-14 05:21:20 -07:00
|
|
|
|
2017-05-27 04:35:54 -06:00
|
|
|
if(has_too_many_connections(context.m_remote_address))
|
2017-01-14 05:21:20 -07:00
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
LOG_PRINT_CCONTEXT_L1("CONNECTION FROM " << context.m_remote_address.host_str() << " REFUSED, too many connections from the same address");
|
2017-01-14 05:21:20 -07:00
|
|
|
drop_connection(context);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2014-03-03 15:07:58 -07:00
|
|
|
//associate peer_id with this connection
|
|
|
|
context.peer_id = arg.node_data.peer_id;
|
2017-08-08 10:23:02 -06:00
|
|
|
context.m_in_timedsync = false;
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
if(arg.node_data.peer_id != m_config.m_peer_id && arg.node_data.my_port)
|
|
|
|
{
|
|
|
|
peerid_type peer_id_l = arg.node_data.peer_id;
|
2017-08-25 09:14:46 -06:00
|
|
|
uint32_t port_l = arg.node_data.my_port;
|
2014-03-03 15:07:58 -07:00
|
|
|
//try ping to be sure that we can add this peer to peer_list
|
|
|
|
try_ping(arg.node_data, context, [peer_id_l, port_l, context, this]()
|
|
|
|
{
|
2017-06-28 02:00:29 -06:00
|
|
|
CHECK_AND_ASSERT_MES(context.m_remote_address.get_type_id() == epee::net_utils::ipv4_network_address::ID, void(),
|
|
|
|
"Only IPv4 addresses are supported here");
|
2014-03-03 15:07:58 -07:00
|
|
|
//called only(!) if success pinged, update local peerlist
|
|
|
|
peerlist_entry pe;
|
2017-05-27 04:35:54 -06:00
|
|
|
const epee::net_utils::network_address na = context.m_remote_address;
|
2017-08-25 09:14:46 -06:00
|
|
|
pe.adr = epee::net_utils::ipv4_network_address(na.as<epee::net_utils::ipv4_network_address>().ip(), port_l);
|
2014-08-20 09:57:29 -06:00
|
|
|
time_t last_seen;
|
|
|
|
time(&last_seen);
|
|
|
|
pe.last_seen = static_cast<int64_t>(last_seen);
|
2014-03-03 15:07:58 -07:00
|
|
|
pe.id = peer_id_l;
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
pe.pruning_seed = context.m_pruning_seed;
|
2014-03-03 15:07:58 -07:00
|
|
|
this->m_peerlist.append_with_peer_white(pe);
|
2017-05-27 04:35:54 -06:00
|
|
|
LOG_DEBUG_CC(context, "PING SUCCESS " << context.m_remote_address.host_str() << ":" << port_l);
|
2014-03-03 15:07:58 -07:00
|
|
|
});
|
|
|
|
}
|
2016-10-26 13:00:08 -06:00
|
|
|
|
|
|
|
try_get_support_flags(context, [](p2p_connection_context& flags_context, const uint32_t& support_flags)
|
|
|
|
{
|
|
|
|
flags_context.support_flags = support_flags;
|
|
|
|
});
|
2014-03-03 15:07:58 -07:00
|
|
|
|
|
|
|
//fill response
|
2017-05-27 04:35:54 -06:00
|
|
|
m_peerlist.get_peerlist_head(rsp.local_peerlist_new);
|
2014-03-03 15:07:58 -07:00
|
|
|
get_local_node_data(rsp.node_data);
|
|
|
|
m_payload_handler.get_payload_sync_data(rsp.payload_data);
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
LOG_DEBUG_CC(context, "COMMAND_HANDSHAKE");
|
2014-03-03 15:07:58 -07:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
int node_server<t_payload_net_handler>::handle_ping(int command, COMMAND_PING::request& arg, COMMAND_PING::response& rsp, p2p_connection_context& context)
|
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
LOG_DEBUG_CC(context, "COMMAND_PING");
|
2014-03-03 15:07:58 -07:00
|
|
|
rsp.status = PING_OK_RESPONSE_STATUS_TEXT;
|
|
|
|
rsp.peer_id = m_config.m_peer_id;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::log_peerlist()
|
|
|
|
{
|
2018-12-05 15:25:27 -07:00
|
|
|
std::vector<peerlist_entry> pl_white;
|
|
|
|
std::vector<peerlist_entry> pl_gray;
|
2016-12-04 06:13:54 -07:00
|
|
|
m_peerlist.get_peerlist_full(pl_gray, pl_white);
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MINFO(ENDL << "Peerlist white:" << ENDL << print_peerlist_to_string(pl_white) << ENDL << "Peerlist gray:" << ENDL << print_peerlist_to_string(pl_gray) );
|
2014-03-03 15:07:58 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::log_connections()
|
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MINFO("Connections: \r\n" << print_connections_container() );
|
2014-03-03 15:07:58 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
std::string node_server<t_payload_net_handler>::print_connections_container()
|
|
|
|
{
|
|
|
|
|
|
|
|
std::stringstream ss;
|
|
|
|
m_net_server.get_config_object().foreach_connection([&](const p2p_connection_context& cntxt)
|
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
ss << cntxt.m_remote_address.str()
|
2014-03-03 15:07:58 -07:00
|
|
|
<< " \t\tpeer_id " << cntxt.peer_id
|
2018-12-17 17:05:27 -07:00
|
|
|
<< " \t\tconn_id " << cntxt.m_connection_id << (cntxt.m_is_income ? " INC":" OUT")
|
2014-03-03 15:07:58 -07:00
|
|
|
<< std::endl;
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
std::string s = ss.str();
|
|
|
|
return s;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
void node_server<t_payload_net_handler>::on_connection_new(p2p_connection_context& context)
|
|
|
|
{
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MINFO("["<< epee::net_utils::print_connection_context(context) << "] NEW CONNECTION");
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
void node_server<t_payload_net_handler>::on_connection_close(p2p_connection_context& context)
|
|
|
|
{
|
2017-02-08 17:11:58 -07:00
|
|
|
if (!m_net_server.is_stop_signal_sent() && !context.m_is_income) {
|
2017-05-27 04:35:54 -06:00
|
|
|
epee::net_utils::network_address na = AUTO_VAL_INIT(na);
|
|
|
|
na = context.m_remote_address;
|
2017-02-08 17:11:58 -07:00
|
|
|
|
|
|
|
m_peerlist.remove_from_peer_anchor(na);
|
|
|
|
}
|
|
|
|
|
2017-08-18 13:14:23 -06:00
|
|
|
m_payload_handler.on_connection_close(context);
|
|
|
|
|
Change logging to easylogging++
This replaces the epee and data_loggers logging systems with
a single one, and also adds filename:line and explicit severity
levels. Categories may be defined, and logging severity set
by category (or set of categories). epee style 0-4 log level
maps to a sensible severity configuration. Log files now also
rotate when reaching 100 MB.
To select which logs to output, use the MONERO_LOGS environment
variable, with a comma separated list of categories (globs are
supported), with their requested severity level after a colon.
If a log matches more than one such setting, the last one in
the configuration string applies. A few examples:
This one is (mostly) silent, only outputting fatal errors:
MONERO_LOGS=*:FATAL
This one is very verbose:
MONERO_LOGS=*:TRACE
This one is totally silent (logwise):
MONERO_LOGS=""
This one outputs all errors and warnings, except for the
"verify" category, which prints just fatal errors (the verify
category is used for logs about incoming transactions and
blocks, and it is expected that some/many will fail to verify,
hence we don't want the spam):
MONERO_LOGS=*:WARNING,verify:FATAL
Log levels are, in decreasing order of priority:
FATAL, ERROR, WARNING, INFO, DEBUG, TRACE
Subcategories may be added using prefixes and globs. This
example will output net.p2p logs at the TRACE level, but all
other net* logs only at INFO:
MONERO_LOGS=*:ERROR,net*:INFO,net.p2p:TRACE
Logs which are intended for the user (which Monero was using
a lot through epee, but really isn't a nice way to go things)
should use the "global" category. There are a few helper macros
for using this category, eg: MGINFO("this shows up by default")
or MGINFO_RED("this is red"), to try to keep a similar look
and feel for now.
Existing epee log macros still exist, and map to the new log
levels, but since they're used as a "user facing" UI element
as much as a logging system, they often don't map well to log
severities (ie, a log level 0 log may be an error, or may be
something we want the user to see, such as an important info).
In those cases, I tried to use the new macros. In other cases,
I left the existing macros in. When modifying logs, it is
probably best to switch to the new macros with explicit levels.
The --log-level options and set_log commands now also accept
category settings, in addition to the epee style log levels.
2017-01-01 09:34:23 -07:00
|
|
|
MINFO("["<< epee::net_utils::print_connection_context(context) << "] CLOSE CONNECTION");
|
2014-05-25 11:06:40 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
template<class t_payload_net_handler>
|
2017-05-27 04:35:54 -06:00
|
|
|
bool node_server<t_payload_net_handler>::is_priority_node(const epee::net_utils::network_address& na)
|
2014-05-25 11:06:40 -06:00
|
|
|
{
|
|
|
|
return (std::find(m_priority_peers.begin(), m_priority_peers.end(), na) != m_priority_peers.end()) || (std::find(m_exclusive_peers.begin(), m_exclusive_peers.end(), na) != m_exclusive_peers.end());
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class t_payload_net_handler> template <class Container>
|
|
|
|
bool node_server<t_payload_net_handler>::connect_to_peerlist(const Container& peers)
|
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
for(const epee::net_utils::network_address& na: peers)
|
2014-05-25 11:06:40 -06:00
|
|
|
{
|
|
|
|
if(m_net_server.is_stop_signal_sent())
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if(is_addr_connected(na))
|
|
|
|
continue;
|
|
|
|
|
|
|
|
try_to_connect_and_handshake_with_new_peer(na);
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class t_payload_net_handler> template <class Container>
|
|
|
|
bool node_server<t_payload_net_handler>::parse_peers_and_add_to_container(const boost::program_options::variables_map& vm, const command_line::arg_descriptor<std::vector<std::string> > & arg, Container& container)
|
|
|
|
{
|
|
|
|
std::vector<std::string> perrs = command_line::get_arg(vm, arg);
|
|
|
|
|
|
|
|
for(const std::string& pr_str: perrs)
|
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
epee::net_utils::network_address na = AUTO_VAL_INIT(na);
|
2018-06-10 21:16:29 -06:00
|
|
|
const uint16_t default_port = cryptonote::get_config(m_nettype).P2P_DEFAULT_PORT;
|
2017-05-27 04:35:54 -06:00
|
|
|
bool r = parse_peer_from_string(na, pr_str, default_port);
|
2018-06-10 21:43:18 -06:00
|
|
|
if (r)
|
|
|
|
{
|
|
|
|
container.push_back(na);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
std::vector<epee::net_utils::network_address> resolved_addrs;
|
|
|
|
r = append_net_address(resolved_addrs, pr_str, default_port);
|
|
|
|
CHECK_AND_ASSERT_MES(r, false, "Failed to parse or resolve address from string: " << pr_str);
|
|
|
|
for (const epee::net_utils::network_address& addr : resolved_addrs)
|
|
|
|
{
|
|
|
|
container.push_back(addr);
|
|
|
|
}
|
2014-05-25 11:06:40 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2015-01-05 12:30:17 -07:00
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::set_max_out_peers(const boost::program_options::variables_map& vm, int64_t max)
|
2015-12-13 21:54:39 -07:00
|
|
|
{
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
if(max == -1)
|
|
|
|
max = P2P_DEFAULT_CONNECTIONS_COUNT;
|
2018-01-19 23:36:19 -07:00
|
|
|
m_config.m_net_config.max_out_connection_count = max;
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
m_payload_handler.set_max_out_peers(max);
|
2015-12-13 21:54:39 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2018-01-20 14:44:23 -07:00
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::set_max_in_peers(const boost::program_options::variables_map& vm, int64_t max)
|
|
|
|
{
|
|
|
|
m_config.m_net_config.max_in_connection_count = max;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2015-01-05 12:30:17 -07:00
|
|
|
template<class t_payload_net_handler>
|
2018-01-19 17:57:02 -07:00
|
|
|
void node_server<t_payload_net_handler>::delete_out_connections(size_t count)
|
2015-01-05 12:30:17 -07:00
|
|
|
{
|
2015-12-13 21:54:39 -07:00
|
|
|
m_net_server.get_config_object().del_out_connections(count);
|
2015-01-05 12:30:17 -07:00
|
|
|
}
|
2015-12-13 21:54:39 -07:00
|
|
|
|
2018-01-20 14:44:23 -07:00
|
|
|
template<class t_payload_net_handler>
|
|
|
|
void node_server<t_payload_net_handler>::delete_in_connections(size_t count)
|
|
|
|
{
|
|
|
|
m_net_server.get_config_object().del_in_connections(count);
|
|
|
|
}
|
|
|
|
|
2015-12-13 21:54:39 -07:00
|
|
|
template<class t_payload_net_handler>
|
2015-01-05 12:30:17 -07:00
|
|
|
bool node_server<t_payload_net_handler>::set_tos_flag(const boost::program_options::variables_map& vm, int flag)
|
2015-12-13 21:54:39 -07:00
|
|
|
{
|
|
|
|
if(flag==-1){
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
epee::net_utils::connection<epee::levin::async_protocol_handler<p2p_connection_context> >::set_tos_flag(flag);
|
|
|
|
_dbg1("Set ToS flag " << flag);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2015-01-05 12:30:17 -07:00
|
|
|
template<class t_payload_net_handler>
|
2015-12-13 21:54:39 -07:00
|
|
|
bool node_server<t_payload_net_handler>::set_rate_up_limit(const boost::program_options::variables_map& vm, int64_t limit)
|
|
|
|
{
|
|
|
|
this->islimitup=true;
|
|
|
|
|
|
|
|
if (limit==-1) {
|
|
|
|
limit=default_limit_up;
|
|
|
|
this->islimitup=false;
|
|
|
|
}
|
|
|
|
|
|
|
|
epee::net_utils::connection<epee::levin::async_protocol_handler<p2p_connection_context> >::set_rate_up_limit( limit );
|
2017-11-26 07:26:17 -07:00
|
|
|
MINFO("Set limit-up to " << limit << " kB/s");
|
2015-12-13 21:54:39 -07:00
|
|
|
return true;
|
|
|
|
}
|
2015-01-05 12:30:17 -07:00
|
|
|
|
|
|
|
template<class t_payload_net_handler>
|
2015-12-13 21:54:39 -07:00
|
|
|
bool node_server<t_payload_net_handler>::set_rate_down_limit(const boost::program_options::variables_map& vm, int64_t limit)
|
|
|
|
{
|
|
|
|
this->islimitdown=true;
|
|
|
|
if(limit==-1) {
|
|
|
|
limit=default_limit_down;
|
|
|
|
this->islimitdown=false;
|
|
|
|
}
|
|
|
|
epee::net_utils::connection<epee::levin::async_protocol_handler<p2p_connection_context> >::set_rate_down_limit( limit );
|
2017-11-26 07:26:17 -07:00
|
|
|
MINFO("Set limit-down to " << limit << " kB/s");
|
2015-12-13 21:54:39 -07:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::set_rate_limit(const boost::program_options::variables_map& vm, int64_t limit)
|
|
|
|
{
|
|
|
|
int64_t limit_up = 0;
|
|
|
|
int64_t limit_down = 0;
|
2015-01-05 12:30:17 -07:00
|
|
|
|
2015-12-13 21:54:39 -07:00
|
|
|
if(limit == -1)
|
|
|
|
{
|
2017-11-26 07:26:17 -07:00
|
|
|
limit_up = default_limit_up;
|
|
|
|
limit_down = default_limit_down;
|
2015-12-13 21:54:39 -07:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-11-26 07:26:17 -07:00
|
|
|
limit_up = limit;
|
|
|
|
limit_down = limit;
|
2015-12-13 21:54:39 -07:00
|
|
|
}
|
|
|
|
if(!this->islimitup) {
|
|
|
|
epee::net_utils::connection<epee::levin::async_protocol_handler<p2p_connection_context> >::set_rate_up_limit(limit_up);
|
2017-11-26 07:26:17 -07:00
|
|
|
MINFO("Set limit-up to " << limit_up << " kB/s");
|
2015-12-13 21:54:39 -07:00
|
|
|
}
|
|
|
|
if(!this->islimitdown) {
|
|
|
|
epee::net_utils::connection<epee::levin::async_protocol_handler<p2p_connection_context> >::set_rate_down_limit(limit_down);
|
2017-11-26 07:26:17 -07:00
|
|
|
MINFO("Set limit-down to " << limit_down << " kB/s");
|
2015-12-13 21:54:39 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
2017-01-14 05:21:20 -07:00
|
|
|
|
|
|
|
template<class t_payload_net_handler>
|
2017-05-27 04:35:54 -06:00
|
|
|
bool node_server<t_payload_net_handler>::has_too_many_connections(const epee::net_utils::network_address &address)
|
2017-01-14 05:21:20 -07:00
|
|
|
{
|
2017-12-07 15:44:55 -07:00
|
|
|
const size_t max_connections = 1;
|
|
|
|
size_t count = 0;
|
2017-01-14 05:21:20 -07:00
|
|
|
|
|
|
|
m_net_server.get_config_object().foreach_connection([&](const p2p_connection_context& cntxt)
|
|
|
|
{
|
2017-05-27 04:35:54 -06:00
|
|
|
if (cntxt.m_is_income && cntxt.m_remote_address.is_same_host(address)) {
|
2017-01-14 05:21:20 -07:00
|
|
|
count++;
|
|
|
|
|
|
|
|
if (count > max_connections) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
|
|
|
return count > max_connections;
|
|
|
|
}
|
2017-01-20 16:59:04 -07:00
|
|
|
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
bool node_server<t_payload_net_handler>::gray_peerlist_housekeeping()
|
|
|
|
{
|
2018-02-01 04:48:03 -07:00
|
|
|
if (m_offline) return true;
|
2017-09-10 06:11:42 -06:00
|
|
|
if (!m_exclusive_peers.empty()) return true;
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
if (m_payload_handler.needs_new_sync_connections()) return true;
|
2017-09-10 06:11:42 -06:00
|
|
|
|
2017-01-20 16:59:04 -07:00
|
|
|
peerlist_entry pe = AUTO_VAL_INIT(pe);
|
|
|
|
|
2017-08-16 08:44:52 -06:00
|
|
|
if (m_net_server.is_stop_signal_sent())
|
|
|
|
return false;
|
|
|
|
|
2017-01-21 05:04:49 -07:00
|
|
|
if (!m_peerlist.get_random_gray_peer(pe)) {
|
2018-12-30 12:32:38 -07:00
|
|
|
return true;
|
2017-01-20 16:59:04 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
bool success = check_connection_and_handshake_with_peer(pe.adr, pe.last_seen);
|
|
|
|
|
|
|
|
if (!success) {
|
|
|
|
m_peerlist.remove_from_peer_gray(pe);
|
|
|
|
|
2017-08-20 14:15:53 -06:00
|
|
|
LOG_PRINT_L2("PEER EVICTED FROM GRAY PEER LIST IP address: " << pe.adr.host_str() << " Peer ID: " << peerid_type(pe.id));
|
2017-01-20 16:59:04 -07:00
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
m_peerlist.set_peer_just_seen(pe.id, pe.adr, pe.pruning_seed);
|
2017-01-20 16:59:04 -07:00
|
|
|
|
2017-08-20 14:15:53 -06:00
|
|
|
LOG_PRINT_L2("PEER PROMOTED TO WHITE PEER LIST IP address: " << pe.adr.host_str() << " Peer ID: " << peerid_type(pe.id));
|
2017-01-20 16:59:04 -07:00
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
2017-08-29 15:28:23 -06:00
|
|
|
|
Pruning
The blockchain prunes seven eighths of prunable tx data.
This saves about two thirds of the blockchain size, while
keeping the node useful as a sync source for an eighth
of the blockchain.
No other data is currently pruned.
There are three ways to prune a blockchain:
- run monerod with --prune-blockchain
- run "prune_blockchain" in the monerod console
- run the monero-blockchain-prune utility
The first two will prune in place. Due to how LMDB works, this
will not reduce the blockchain size on disk. Instead, it will
mark parts of the file as free, so that future data will use
that free space, causing the file to not grow until free space
grows scarce.
The third way will create a second database, a pruned copy of
the original one. Since this is a new file, this one will be
smaller than the original one.
Once the database is pruned, it will stay pruned as it syncs.
That is, there is no need to use --prune-blockchain again, etc.
2018-04-29 16:30:51 -06:00
|
|
|
template<class t_payload_net_handler>
|
|
|
|
void node_server<t_payload_net_handler>::add_used_stripe_peer(const typename t_payload_net_handler::connection_context &context)
|
|
|
|
{
|
|
|
|
const uint32_t stripe = tools::get_pruning_stripe(context.m_pruning_seed);
|
|
|
|
if (stripe == 0 || stripe > (1ul << CRYPTONOTE_PRUNING_LOG_STRIPES))
|
|
|
|
return;
|
|
|
|
const uint32_t index = stripe - 1;
|
|
|
|
CRITICAL_REGION_LOCAL(m_used_stripe_peers_mutex);
|
|
|
|
MINFO("adding stripe " << stripe << " peer: " << context.m_remote_address.str());
|
|
|
|
std::remove_if(m_used_stripe_peers[index].begin(), m_used_stripe_peers[index].end(),
|
|
|
|
[&context](const epee::net_utils::network_address &na){ return context.m_remote_address == na; });
|
|
|
|
m_used_stripe_peers[index].push_back(context.m_remote_address);
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
void node_server<t_payload_net_handler>::remove_used_stripe_peer(const typename t_payload_net_handler::connection_context &context)
|
|
|
|
{
|
|
|
|
const uint32_t stripe = tools::get_pruning_stripe(context.m_pruning_seed);
|
|
|
|
if (stripe == 0 || stripe > (1ul << CRYPTONOTE_PRUNING_LOG_STRIPES))
|
|
|
|
return;
|
|
|
|
const uint32_t index = stripe - 1;
|
|
|
|
CRITICAL_REGION_LOCAL(m_used_stripe_peers_mutex);
|
|
|
|
MINFO("removing stripe " << stripe << " peer: " << context.m_remote_address.str());
|
|
|
|
std::remove_if(m_used_stripe_peers[index].begin(), m_used_stripe_peers[index].end(),
|
|
|
|
[&context](const epee::net_utils::network_address &na){ return context.m_remote_address == na; });
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
void node_server<t_payload_net_handler>::clear_used_stripe_peers()
|
|
|
|
{
|
|
|
|
CRITICAL_REGION_LOCAL(m_used_stripe_peers_mutex);
|
|
|
|
MINFO("clearing used stripe peers");
|
|
|
|
for (auto &e: m_used_stripe_peers)
|
|
|
|
e.clear();
|
|
|
|
}
|
|
|
|
|
2017-08-29 15:28:23 -06:00
|
|
|
template<class t_payload_net_handler>
|
|
|
|
void node_server<t_payload_net_handler>::add_upnp_port_mapping(uint32_t port)
|
|
|
|
{
|
|
|
|
MDEBUG("Attempting to add IGD port mapping.");
|
|
|
|
int result;
|
|
|
|
#if MINIUPNPC_API_VERSION > 13
|
|
|
|
// default according to miniupnpc.h
|
|
|
|
unsigned char ttl = 2;
|
|
|
|
UPNPDev* deviceList = upnpDiscover(1000, NULL, NULL, 0, 0, ttl, &result);
|
|
|
|
#else
|
|
|
|
UPNPDev* deviceList = upnpDiscover(1000, NULL, NULL, 0, 0, &result);
|
|
|
|
#endif
|
|
|
|
UPNPUrls urls;
|
|
|
|
IGDdatas igdData;
|
|
|
|
char lanAddress[64];
|
|
|
|
result = UPNP_GetValidIGD(deviceList, &urls, &igdData, lanAddress, sizeof lanAddress);
|
|
|
|
freeUPNPDevlist(deviceList);
|
2018-10-15 16:39:51 -06:00
|
|
|
if (result > 0) {
|
2017-08-29 15:28:23 -06:00
|
|
|
if (result == 1) {
|
|
|
|
std::ostringstream portString;
|
|
|
|
portString << port;
|
|
|
|
|
|
|
|
// Delete the port mapping before we create it, just in case we have dangling port mapping from the daemon not being shut down correctly
|
|
|
|
UPNP_DeletePortMapping(urls.controlURL, igdData.first.servicetype, portString.str().c_str(), "TCP", 0);
|
|
|
|
|
|
|
|
int portMappingResult;
|
|
|
|
portMappingResult = UPNP_AddPortMapping(urls.controlURL, igdData.first.servicetype, portString.str().c_str(), portString.str().c_str(), lanAddress, CRYPTONOTE_NAME, "TCP", 0, "0");
|
|
|
|
if (portMappingResult != 0) {
|
|
|
|
LOG_ERROR("UPNP_AddPortMapping failed, error: " << strupnperror(portMappingResult));
|
|
|
|
} else {
|
|
|
|
MLOG_GREEN(el::Level::Info, "Added IGD port mapping.");
|
|
|
|
}
|
|
|
|
} else if (result == 2) {
|
|
|
|
MWARNING("IGD was found but reported as not connected.");
|
|
|
|
} else if (result == 3) {
|
|
|
|
MWARNING("UPnP device was found but not recognized as IGD.");
|
|
|
|
} else {
|
|
|
|
MWARNING("UPNP_GetValidIGD returned an unknown result code.");
|
|
|
|
}
|
|
|
|
|
|
|
|
FreeUPNPUrls(&urls);
|
|
|
|
} else {
|
|
|
|
MINFO("No IGD was found.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class t_payload_net_handler>
|
|
|
|
void node_server<t_payload_net_handler>::delete_upnp_port_mapping(uint32_t port)
|
|
|
|
{
|
|
|
|
MDEBUG("Attempting to delete IGD port mapping.");
|
|
|
|
int result;
|
|
|
|
#if MINIUPNPC_API_VERSION > 13
|
|
|
|
// default according to miniupnpc.h
|
|
|
|
unsigned char ttl = 2;
|
|
|
|
UPNPDev* deviceList = upnpDiscover(1000, NULL, NULL, 0, 0, ttl, &result);
|
|
|
|
#else
|
|
|
|
UPNPDev* deviceList = upnpDiscover(1000, NULL, NULL, 0, 0, &result);
|
|
|
|
#endif
|
|
|
|
UPNPUrls urls;
|
|
|
|
IGDdatas igdData;
|
|
|
|
char lanAddress[64];
|
|
|
|
result = UPNP_GetValidIGD(deviceList, &urls, &igdData, lanAddress, sizeof lanAddress);
|
|
|
|
freeUPNPDevlist(deviceList);
|
2018-10-15 16:39:51 -06:00
|
|
|
if (result > 0) {
|
2017-08-29 15:28:23 -06:00
|
|
|
if (result == 1) {
|
|
|
|
std::ostringstream portString;
|
|
|
|
portString << port;
|
|
|
|
|
|
|
|
int portMappingResult;
|
|
|
|
portMappingResult = UPNP_DeletePortMapping(urls.controlURL, igdData.first.servicetype, portString.str().c_str(), "TCP", 0);
|
|
|
|
if (portMappingResult != 0) {
|
|
|
|
LOG_ERROR("UPNP_DeletePortMapping failed, error: " << strupnperror(portMappingResult));
|
|
|
|
} else {
|
|
|
|
MLOG_GREEN(el::Level::Info, "Deleted IGD port mapping.");
|
|
|
|
}
|
|
|
|
} else if (result == 2) {
|
|
|
|
MWARNING("IGD was found but reported as not connected.");
|
|
|
|
} else if (result == 3) {
|
|
|
|
MWARNING("UPnP device was found but not recognized as IGD.");
|
|
|
|
} else {
|
|
|
|
MWARNING("UPNP_GetValidIGD returned an unknown result code.");
|
|
|
|
}
|
|
|
|
|
|
|
|
FreeUPNPUrls(&urls);
|
|
|
|
} else {
|
|
|
|
MINFO("No IGD was found.");
|
|
|
|
}
|
|
|
|
}
|
2014-03-03 15:07:58 -07:00
|
|
|
}
|