Fixes to net-shaper, and net.sh option to start/stop shaper (#6981)
* Fixes to net-shaper, and net.sh option to start/stop shaper * fix shellcheck * more shellchecks
This commit is contained in:
		| @@ -50,6 +50,7 @@ fn run( | |||||||
|     status_err_msg: &str, |     status_err_msg: &str, | ||||||
|     ignore_err: bool, |     ignore_err: bool, | ||||||
| ) -> bool { | ) -> bool { | ||||||
|  |     println!("Running {:?}", std::process::Command::new(cmd).args(args)); | ||||||
|     let output = std::process::Command::new(cmd) |     let output = std::process::Command::new(cmd) | ||||||
|         .args(args) |         .args(args) | ||||||
|         .output() |         .output() | ||||||
| @@ -73,8 +74,8 @@ fn run( | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| fn insert_iptables_rule(my_partition: usize) -> bool { | fn insert_iptables_rule(tos: u8) -> bool { | ||||||
|     let my_tos = my_partition.to_string(); |     let my_tos = tos.to_string(); | ||||||
|  |  | ||||||
|     // iptables -t mangle -A PREROUTING -p udp -j TOS --set-tos <my_parition_index> |     // iptables -t mangle -A PREROUTING -p udp -j TOS --set-tos <my_parition_index> | ||||||
|     run( |     run( | ||||||
| @@ -83,7 +84,7 @@ fn insert_iptables_rule(my_partition: usize) -> bool { | |||||||
|             "-t", |             "-t", | ||||||
|             "mangle", |             "mangle", | ||||||
|             "-A", |             "-A", | ||||||
|             "PREROUTING", |             "OUTPUT", | ||||||
|             "-p", |             "-p", | ||||||
|             "udp", |             "udp", | ||||||
|             "-j", |             "-j", | ||||||
| @@ -198,7 +199,15 @@ fn identify_my_partition(partitions: &[u8], index: u64, size: u64) -> usize { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     my_partition + 1 |     my_partition | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fn partition_id_to_tos(partition: usize) -> u8 { | ||||||
|  |     if partition < 4 { | ||||||
|  |         2u8.pow(partition as u32 + 1) | ||||||
|  |     } else { | ||||||
|  |         0 | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| fn shape_network(matches: &ArgMatches) { | fn shape_network(matches: &ArgMatches) { | ||||||
| @@ -217,12 +226,12 @@ fn shape_network(matches: &ArgMatches) { | |||||||
|  |  | ||||||
|     assert!(my_index < network_size); |     assert!(my_index < network_size); | ||||||
|  |  | ||||||
|     let my_partition = identify_my_partition(&topology.partitions, my_index, network_size); |     let my_partition = identify_my_partition(&topology.partitions, my_index + 1, network_size); | ||||||
|     println!("My partition is {}", my_partition); |     println!("My partition is {}", my_partition); | ||||||
|  |  | ||||||
|     flush_iptables_rule(); |     flush_iptables_rule(); | ||||||
|  |  | ||||||
|     if !insert_iptables_rule(my_partition) { |     if !insert_iptables_rule(partition_id_to_tos(my_partition)) { | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -234,26 +243,28 @@ fn shape_network(matches: &ArgMatches) { | |||||||
|  |  | ||||||
|     topology.interconnects.iter().for_each(|i| { |     topology.interconnects.iter().for_each(|i| { | ||||||
|         if i.b as usize == my_partition { |         if i.b as usize == my_partition { | ||||||
|             let handle = (i.a + 1).to_string(); |             let tos = partition_id_to_tos(i.a as usize); | ||||||
|             let tos_string = i.a.to_string(); |             if tos == 0 { | ||||||
|             let class = format!("1:{}", i.a); |                 println!("Incorrect value of TOS/Partition in config {}", i.a); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             let tos_string = tos.to_string(); | ||||||
|  |             let class = format!("1:{}", i.a + 1); | ||||||
|             if !insert_tc_netem( |             if !insert_tc_netem( | ||||||
|                 interface.as_str(), |                 interface.as_str(), | ||||||
|                 class.as_str(), |                 class.as_str(), | ||||||
|                 handle.as_str(), |                 tos_string.as_str(), | ||||||
|                 i.config.as_str(), |                 i.config.as_str(), | ||||||
|             ) { |             ) { | ||||||
|                 flush_iptables_rule(); |  | ||||||
|                 delete_tc_root(interface.as_str()); |                 delete_tc_root(interface.as_str()); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             if !insert_tos_filter(interface.as_str(), class.as_str(), tos_string.as_str()) { |             if !insert_tos_filter(interface.as_str(), class.as_str(), tos_string.as_str()) { | ||||||
|                 flush_iptables_rule(); |  | ||||||
|                 delete_tc_netem( |                 delete_tc_netem( | ||||||
|                     interface.as_str(), |                     interface.as_str(), | ||||||
|                     class.as_str(), |                     class.as_str(), | ||||||
|                     handle.as_str(), |                     tos_string.as_str(), | ||||||
|                     i.config.as_str(), |                     i.config.as_str(), | ||||||
|                 ); |                 ); | ||||||
|                 delete_tc_root(interface.as_str()); |                 delete_tc_root(interface.as_str()); | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								net/net.sh
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								net/net.sh
									
									
									
									
									
								
							| @@ -102,6 +102,8 @@ Operate a configured testnet | |||||||
|  netem-specific options: |  netem-specific options: | ||||||
|    --config            - Netem configuration (as a double quoted string) |    --config            - Netem configuration (as a double quoted string) | ||||||
|    --parition          - Percentage of network that should be configured with netem |    --parition          - Percentage of network that should be configured with netem | ||||||
|  |    --config-file       - Configuration file for partition and netem configuration | ||||||
|  |    --netem-cmd         - Optional command argument to netem. Default is "add". Use "cleanup" to remove rules. | ||||||
|  |  | ||||||
|  update-specific options: |  update-specific options: | ||||||
|    --platform linux|osx|windows       - Deploy the tarball using 'solana-install deploy ...' for the |    --platform linux|osx|windows       - Deploy the tarball using 'solana-install deploy ...' for the | ||||||
| @@ -147,6 +149,8 @@ gpuMode=auto | |||||||
| maybeUseMove="" | maybeUseMove="" | ||||||
| netemPartition="" | netemPartition="" | ||||||
| netemConfig="" | netemConfig="" | ||||||
|  | netemConfigFile="" | ||||||
|  | netemCommand="add" | ||||||
|  |  | ||||||
| command=$1 | command=$1 | ||||||
| [[ -n $command ]] || usage | [[ -n $command ]] || usage | ||||||
| @@ -216,6 +220,12 @@ while [[ -n $1 ]]; do | |||||||
|     elif [[ $1 = --config ]]; then |     elif [[ $1 = --config ]]; then | ||||||
|       netemConfig=$2 |       netemConfig=$2 | ||||||
|       shift 2 |       shift 2 | ||||||
|  |     elif [[ $1 == --config-file ]]; then | ||||||
|  |       netemConfigFile=$2 | ||||||
|  |       shift 2 | ||||||
|  |     elif [[ $1 == --netem-cmd ]]; then | ||||||
|  |       netemCommand=$2 | ||||||
|  |       shift 2 | ||||||
|     elif [[ $1 = --gpu-mode ]]; then |     elif [[ $1 = --gpu-mode ]]; then | ||||||
|       gpuMode=$2 |       gpuMode=$2 | ||||||
|       case "$gpuMode" in |       case "$gpuMode" in | ||||||
| @@ -996,6 +1006,15 @@ logs) | |||||||
|   done |   done | ||||||
|   ;; |   ;; | ||||||
| netem) | netem) | ||||||
|  |   if [[ -n $netemConfigFile ]]; then | ||||||
|  |     for ipAddress in "${validatorIpList[@]}"; do | ||||||
|  |       "$here"/scp.sh "$netemConfigFile" solana@"$ipAddress":~/solana | ||||||
|  |     done | ||||||
|  |     for i in "${!validatorIpList[@]}"; do | ||||||
|  |       "$here"/ssh.sh solana@"${validatorIpList[$i]}" 'solana/scripts/net-shaper.sh' \ | ||||||
|  |       "$netemCommand" solana/"$netemConfigFile" "${#validatorIpList[@]}" "$i" | ||||||
|  |     done | ||||||
|  |   else | ||||||
|     num_nodes=$((${#validatorIpList[@]}*netemPartition/100)) |     num_nodes=$((${#validatorIpList[@]}*netemPartition/100)) | ||||||
|     if [[ $((${#validatorIpList[@]}*netemPartition%100)) -gt 0 ]]; then |     if [[ $((${#validatorIpList[@]}*netemPartition%100)) -gt 0 ]]; then | ||||||
|       num_nodes=$((num_nodes+1)) |       num_nodes=$((num_nodes+1)) | ||||||
| @@ -1013,6 +1032,7 @@ netem) | |||||||
|     for ((i=0; i<num_nodes; i++ )); do : |     for ((i=0; i<num_nodes; i++ )); do : | ||||||
|       "$here"/ssh.sh solana@"${validatorIpList[$i]}" "echo $netemConfig > solana/netem.cfg; solana/scripts/netem.sh add \"$netemConfig\"" |       "$here"/ssh.sh solana@"${validatorIpList[$i]}" "echo $netemConfig > solana/netem.cfg; solana/scripts/netem.sh add \"$netemConfig\"" | ||||||
|     done |     done | ||||||
|  |   fi | ||||||
|   ;; |   ;; | ||||||
| *) | *) | ||||||
|   echo "Internal error: Unknown command: $command" |   echo "Internal error: Unknown command: $command" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user