add plumbing to allow for arbitrary tpu address in gossip (#22703)

* add plumbing to allow for arbitrary tpu address in gossip

* make clippy happy

* Review comments

Co-authored-by: CherryWorm <nico.gruendel@web.de>
This commit is contained in:
sakridge 2022-03-02 09:42:14 +01:00 committed by GitHub
parent d3ebe8d8f5
commit a4f4ac5279
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 24 additions and 1 deletions

View File

@ -2899,6 +2899,7 @@ impl Node {
gossip_addr: &SocketAddr,
port_range: PortRange,
bind_ip_addr: IpAddr,
overwrite_tpu_addr: Option<SocketAddr>,
) -> Node {
let (gossip_port, (gossip, ip_echo)) =
Self::get_gossip_port(gossip_addr, port_range, bind_ip_addr);
@ -2940,7 +2941,7 @@ impl Node {
tvu: SocketAddr::new(gossip_addr.ip(), tvu_port),
tvu_forwards: SocketAddr::new(gossip_addr.ip(), tvu_forwards_port),
repair: SocketAddr::new(gossip_addr.ip(), repair_port),
tpu: SocketAddr::new(gossip_addr.ip(), tpu_port),
tpu: overwrite_tpu_addr.unwrap_or_else(|| SocketAddr::new(gossip_addr.ip(), tpu_port)),
tpu_forwards: SocketAddr::new(gossip_addr.ip(), tpu_forwards_port),
tpu_vote: SocketAddr::new(gossip_addr.ip(), tpu_vote_port),
rpc: socketaddr_any!(),
@ -3500,6 +3501,7 @@ mod tests {
&socketaddr!(ip, 0),
VALIDATOR_PORT_RANGE,
IpAddr::V4(ip),
None,
);
check_node_sockets(&node, IpAddr::V4(ip), VALIDATOR_PORT_RANGE);
@ -3521,6 +3523,7 @@ mod tests {
&socketaddr!(0, port),
port_range,
ip,
None,
);
check_node_sockets(&node, ip, port_range);

View File

@ -291,6 +291,7 @@ pub fn main() {
&gossip_addr,
dynamic_port_range,
bind_address,
None,
);
let ledger_path = PathBuf::from(matches.value_of("ledger_path").unwrap());

View File

@ -252,6 +252,7 @@ fn test_replica_bootstrap() {
&gossip_addr,
dynamic_port_range,
bind_address,
None,
);
info!("The peer id: {:?}", &contact_info.id);

View File

@ -775,6 +775,16 @@ pub fn main() {
.help("Gossip DNS name or IP address for the validator to advertise in gossip \
[default: ask --entrypoint, or 127.0.0.1 when --entrypoint is not provided]"),
)
.arg(
Arg::with_name("tpu_host_addr")
.long("tpu-host-addr")
.value_name("HOST:PORT")
.takes_value(true)
.validator(solana_net_utils::is_host_port)
.help("Specify TPU address to advertise in gossip [default: ask --entrypoint or localhost\
when --entrypoint is not provided]"),
)
.arg(
Arg::with_name("public_rpc_addr")
.long("public-rpc-address")
@ -2602,6 +2612,13 @@ pub fn main() {
}),
);
let overwrite_tpu_addr = matches.value_of("tpu_host_addr").map(|tpu_addr| {
solana_net_utils::parse_host_port(tpu_addr).unwrap_or_else(|err| {
eprintln!("Failed to parse --overwrite-tpu-addr: {}", err);
exit(1);
})
});
let cluster_entrypoints = entrypoint_addrs
.iter()
.map(ContactInfo::new_gossip_entry_point)
@ -2612,6 +2629,7 @@ pub fn main() {
&gossip_addr,
dynamic_port_range,
bind_address,
overwrite_tpu_addr,
);
if restricted_repair_only_mode {