Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: use NMT to install and start network nodes #178

Merged
merged 44 commits into from
Jul 27, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
a5529a5
feat: add resources to run platform software inside root-container
leninmehedy Jul 13, 2023
7739727
fix: remove debug code
leninmehedy Jul 13, 2023
ce02e0a
fix: bump memory for network node
leninmehedy Jul 13, 2023
fd697f1
fix: use correct env variable
leninmehedy Jul 13, 2023
d5045d5
fix: update script and use artifacts from local-node repo
leninmehedy Jul 16, 2023
ef7331a
fix: working copy of running node using NMT
leninmehedy Jul 18, 2023
70f11b1
style: add missing new lines
leninmehedy Jul 18, 2023
83e81d8
style: add missing new lines
leninmehedy Jul 18, 2023
ee86dd3
rename script file and cleanup
leninmehedy Jul 18, 2023
c1f036a
ci: show logs from helm tests
leninmehedy Jul 18, 2023
279b270
code cleanup
leninmehedy Jul 18, 2023
d448d47
fix helm test
leninmehedy Jul 18, 2023
daaefc6
ci: cleanup
leninmehedy Jul 18, 2023
536350a
ci: remove debug code
leninmehedy Jul 18, 2023
8f09481
feat: generate address book with pod IP addresses
leninmehedy Jul 20, 2023
f54d2d6
feat: add logging of script execution time
leninmehedy Jul 20, 2023
9ebdf83
feat: add helper function to replace keys
leninmehedy Jul 20, 2023
feb3f3a
add _all suffix to functions that run for all nodes for clarity
leninmehedy Jul 20, 2023
9e54cfa
fix: config template and scripts
leninmehedy Jul 21, 2023
ebe3ff5
support address book generation for latest platform version
leninmehedy Jul 24, 2023
cc835e2
enable trace level logging
leninmehedy Jul 24, 2023
c380d4c
Merge branch 'main' into 176-use-nmt-to-install-node-software
leninmehedy Jul 24, 2023
0f932f2
fix helper script
leninmehedy Jul 25, 2023
43fa200
fix address book generation for v.0.40.0
leninmehedy Jul 25, 2023
d69bc5e
fix service ports mapping
leninmehedy Jul 27, 2023
03c8a06
fix address book generation
leninmehedy Jul 27, 2023
9dadaae
fix log4j2 for jrs and main profile
leninmehedy Jul 27, 2023
3a082d2
use temp dir for generated files
leninmehedy Jul 27, 2023
5200845
add hedera.crt for local dev
leninmehedy Jul 27, 2023
ecc8849
rename to local-node dir
leninmehedy Jul 27, 2023
1a4e037
fix helper script
leninmehedy Jul 27, 2023
8d4f288
show logs
leninmehedy Jul 27, 2023
c590b48
cleanup stopped container during stop-nodes command
leninmehedy Jul 27, 2023
7c5f609
change log level to TRACE
leninmehedy Jul 27, 2023
2d31421
add logs
leninmehedy Jul 27, 2023
5568ca6
fix logging
leninmehedy Jul 27, 2023
0f1770a
Merge branch 'main' into 176-use-nmt-to-install-node-software
leninmehedy Jul 27, 2023
8276eca
fix helper script
leninmehedy Jul 27, 2023
3914c9d
fix check
leninmehedy Jul 27, 2023
98e6f4e
add additional helper make commands
leninmehedy Jul 27, 2023
25ab43d
start account id from 0.0.3 as default
leninmehedy Jul 27, 2023
1ff8730
doc: update README
leninmehedy Jul 27, 2023
b2f3875
docs: update README
leninmehedy Jul 27, 2023
82e591b
fix: resolve minor typos
nathanklick Jul 27, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fix address book generation
Signed-off-by: Lenin Mehedy <lenin.mehedy@swirldslabs.com>
  • Loading branch information
leninmehedy committed Jul 27, 2023
commit 03c8a06041fb98945d0c4b258e26853f12e94479
77 changes: 62 additions & 15 deletions dev/network-node/config.template
Original file line number Diff line number Diff line change
@@ -1,15 +1,62 @@
###############################################################################################
# Configuration file
###############################################################################################
swirld, 123
app, HederaNode.jar
###################################### ADDRESS BOOK ###########################################
# Format:
# address, <NODE_ID>, <NODE_NICK_NAME>, <NODE_NAME>, <NODE_STAKE_AMOUNT>, <INTERNAL_IP>, <INTERNAL_PORT>, <EXTERNAL_IP>, <EXTERNAL_PORT>, <ACCOUNT_ID>
#
# Example:
#address, 0, node0000, node0000, 2685636917, 10.128.0.27, 30124, 35.223.93.31, 30124, 0.0.3
#address, 1, node0001, node0001, 15745067016, 10.128.0.26, 30125, 35.238.137.246, 30125, 0.0.4
#address, 2, node0002, node0002, 15152326407, 10.128.0.15, 30126, 34.68.231.89, 30126, 0.0.5
#address, 3, node0003, node0003, 16416969660, 10.128.0.4, 30127, 35.238.246.241, 30127, 0.0.6
#nextNodeId, 4
# ======================================================================================================================
# Address book Format Description
# ======================================================================================================================
# Address book format varies across versions since it evolved over time. As of July 27, 2023 the below formats were
# relevant for recent versions. Latest version is available in the file: hedera-services/hedera-node/config.txt
#
# - v.0.39.* (or before) format:
# Fields: address, <NODE_ID>, <NODE_NAME>, <NODE_STAKE_AMOUNT>, <INTERNAL_IP>, <INTERNAL_GOSSIP_PORT>, <EXTERNAL_IP>, <EXTERNAL_GOSSIP_PORT>, <ACCOUNT_ID>
# Example: address, 0, node0, 1, 10.128.0.27, 50111, 35.223.93.31, 30124, 0.0.3
#
# - v.0.40.* format:
# Fields: address, <NODE_ID>, <NODE_NICK_NAME>, <NODE_NAME>, <NODE_STAKE_AMOUNT>, <INTERNAL_IP>, <INTERNAL_GOSSIP_PORT>, <EXTERNAL_IP>, <EXTERNAL_GOSSIP_PORT>, <ACCOUNT_ID>
# Example: address, 0, n0, node0, 1, 10.128.0.27, 50111, 35.223.93.31, 30124, 0.0.3
#
# - v.0.41.* (onward) we need to append the below formatted line with next node ID after the list of "address" lines
# <address book lines>
# nextNodeId, <NEXT_NODE_ID>
#
# Field descriptions:
# ===========================
# NODE_ID: This increments for each node and starts from 0.
# NEXT_NODE_ID: The id for the next node (i.e. last node ID + 1)
# NODE_NICK_NAME: This is a string (alphanumeric). e.g. node0
# NODE_NAME: This is a string (alphanumeric). e.g. node0 or n0
# NODE_STAKE_AMOUNT: A long value. e.g. 1 or a larger number
# INTERNAL_IP: This is the pod IP
# INTERNAL_GOSSIP_PORT: Default gossip port is 50111. So use the exposed port that is mapped to 50111 in container.
# EXTERNAL_IP: This is the service IP
# EXTERNAL_GOSSIP_PORT: Default gossip port is 50111. This is usually same as INTERNAL_GOSSIP_PORT unless mapped differently.
# ACCOUNT_ID: Must start from 0.0.3
#

# Account restrictions:
# ===========================
# All ACCOUNT_ID should start from 0.0.3 because of restricted accounts as below:
# - 0.0.0 restricted and not usable
# - 0.0.1 minting account and not usable
# - 0.0.2 treasury account
#
# Default Ports
# ===========================
# We only need to specify the gossip port (INTERNAL_GOSSIP_PORT, EXTERNAL_GOSSIP_PORT). Below are some details on other
# ports that a node may expose:
# - 50111: gossip port
# - 50211: grpc non-tls (for platform services)
# - 50212: grpc tls (for platform services)
#
# IP Address
# ===========================
# When deploying in a kubernetes cluster, we need to use the following IP mapping:
# - INTERNAL_IP: This should be the Pod IP exposing gossip port (i.e. 50111)
# - EXTERNAL_IP: This should be the cluster IP of the service exposing gossip port (i.e. 50111)
#
#
# Example config.txt (for v0.41.* onward)
# ===========================
# swirld, 123
# app, HederaNode.jar
# address, 0, node0, node0, 1, 10.244.0.197, 56789, 10.96.61.84, 50111, 0.0.0
# address, 1, node1, node1, 1, 10.244.0.198, 56789, 10.96.163.93, 50111, 0.0.1
# nextNodeId, 2
# ======================================================================================================================
60 changes: 41 additions & 19 deletions dev/scripts/helper.sh
Original file line number Diff line number Diff line change
Expand Up @@ -309,41 +309,63 @@ function prep_address_book() {
echo "-----------------------------------------------------------------------------------------------------"

local config_file="${SCRIPT_DIR}/../network-node/config.txt"
cp "${SCRIPT_DIR}/../network-node/config.template" "${config_file}"

local node_IP=""
local node_id=0
local internal_port=50211
local external_port=50211
local node_seq="${NODE_SEQ:-0}" # this also used as the account ID suffix
local account_id_prefix="${ACCOUNT_ID_PREFIX:-0.0}"
local internal_port="${INTERNAL_GOSSIP_PORT:-50111}"
local external_port="${EXTERNAL_GOSSIP_PORT:-50111}"
local ledger_name="${LEDGER_NAME:-123}"
local app_jar_file="${APP_NAME:-HederaNode.jar}"
local node_stake="${NODE_DEFAULT_STAKE:-1}"


# prepare config lines
local config_lines=()
config_lines+=("swirld, ${ledger_name}")
config_lines+=("app, ${app_jar_file}")

# prepare address book lines
local addresses=()
for node_name in "${NODE_NAMES[@]}";do
local pod="network-${node_name}-0" # pod name
echo "${KCTL} get pod ${pod} -o jsonpath='{.status.podIP}' | xargs"
POD_IP=$("${KCTL}" get pod "${pod}" -o jsonpath='{.status.podIP}' | xargs)
local POD_IP=$("${KCTL}" get pod "${pod}" -o jsonpath='{.status.podIP}' | xargs)
if [ -z "${POD_IP}" ]; then
echo "Could not detect pod IP for ${pod}"
return "${EX_ERR}"
fi

echo "pod IP: ${POD_IP}"
echo "${KCTL} get svc network-${node_name}-service -o jsonpath='{.spec.clusterIP}' | xargs"
local SVC_IP=$("${KCTL}" get svc "network-${node_name}-service" -o jsonpath='{.spec.clusterIP}' | xargs)
if [ -z "${SVC_IP}" ]; then
echo "Could not detect service IP for ${pod}"
return "${EX_ERR}"
fi

echo "pod IP: ${POD_IP}, svc IP: ${SVC_IP}"

# render template
local account="0.0.${node_id}"
local account="${account_id_prefix}.${node_seq}"
local internal_ip="${POD_IP}"
local external_ip="${POD_IP}"
local node_stake=1
echo "address, ${node_id}, ${node_name}, ${node_name}, ${node_stake}, ${internal_ip}, ${internal_port}, ${external_ip}, ${external_port}, ${account}" >> "${config_file}"
# node_ip="${node_name}_IP"
# echo "${node_IP}: ${POD_IP}"
# echo "${node_IP}=${POD_IP} envsubst '\$${node_IP}' < ${SCRIPT_DIR}/../network-node/config.txt"
# config_content=$(bash -c "${node_IP}=${POD_IP} envsubst '\$${node_IP}' < ${SCRIPT_DIR}/../network-node/config.txt")
# echo "${config_content}" > "${SCRIPT_DIR}/../network-node/config.txt"
local external_ip="${SVC_IP}"

# for v.40.* onward
local node_nick_name="${node_name}"
config_lines+=("address, ${node_seq}, ${node_nick_name}, ${node_name}, ${node_stake}, ${internal_ip}, ${internal_port}, ${external_ip}, ${external_port}, ${account}")

# increment node id
node_id=$((node_id+1))
node_seq=$((node_seq+1))
done

# echo "nextNodeId, ${node_id}" >> "${config_file}"
# for v.41.* onward
# config_lines+=("nextNodeId, ${node_seq}")

# write contents to config file
cp "${SCRIPT_DIR}/../network-node/config.template" "${config_file}"
for line in "${config_lines[@]}";do
echo "${line}" >> "${config_file}"
done

# display config file contents
echo ""
cat "${SCRIPT_DIR}/../network-node/config.txt"

Expand Down