This is an automated email from the ASF dual-hosted git repository.

junchao pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/incubator-resilientdb.git


The following commit(s) were added to refs/heads/master by this push:
     new d8ddf673 Use custom Ports (#165)
d8ddf673 is described below

commit d8ddf673a6f3be7a133e12c46291e59699ffa2d2
Author: cjcchen <[email protected]>
AuthorDate: Sun Dec 8 12:35:41 2024 +0800

    Use custom Ports (#165)
    
    * add port reset
---
 README.md                                        | 16 +++++
 service/tools/config/generate_config.sh          | 92 ++++++++++++++++++++++++
 service/tools/kv/server_tools/generate_config.sh | 34 +++++++++
 3 files changed, 142 insertions(+)

diff --git a/README.md b/README.md
index 6d3fea22..c2f30236 100644
--- a/README.md
+++ b/README.md
@@ -368,3 +368,19 @@ We also provide access to a [deployment 
script](https://github.com/resilientdb/r
    ```
 
    Verify the functionality of the service by performing set and get 
operations provided above [functions](README.md#functions).
+
+
+## Custom Ports ##
+When starting the service locally, current services are running on 10000 
port-base with 5 services where the server config is located 
[here](https://github.com/apache/incubator-resilientdb/blob/master/service/tools/config/server/server.config)
+
+If you want to change the setting,  you need to generate the certificates.
+
+Go the the workspace where the resilientdb repo is localted.
+
+Change the setting parameters here and run the script:
+  ./service/tools/kv/server_tools/generate_config.sh
+
+Then re-run the start script:
+  ./service/tools/kv/server_tools/start_kv_service.sh
+
+
diff --git a/service/tools/config/generate_config.sh 
b/service/tools/config/generate_config.sh
new file mode 100755
index 00000000..8d493c55
--- /dev/null
+++ b/service/tools/config/generate_config.sh
@@ -0,0 +1,92 @@
+#
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License.  You may obtain a copy of the License at
+#
+#   http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied.  See the License for the
+# specific language governing permissions and limitations
+# under the License.
+#
+base_path=$1; shift
+key_path=$1; shift
+output_cert_path=$1; shift
+output_path=$1; shift
+admin_key_path=$1; shift
+client_num=$1; shift
+base_port=$1; shift
+
+iplist=$@
+
+echo "generage certificates"
+
+echo "base path:"$base_path
+echo "key path:"$key_path
+echo "output cert path:"$output_cert_path
+echo "output path:"$output_path
+echo "admin_key_path:"$admin_key_path
+
+cd ${output_path}
+
+ADMIN_PRIVATE_KEY=${admin_key_path}/admin.key.pri
+ADMIN_PUBLIC_KEY=${admin_key_path}/admin.key.pub
+
+CERT_TOOLS_BIN=${base_path}/bazel-bin/tools/certificate_tools
+CONFIG_TOOLS_BIN=${base_path}/bazel-bin/tools/generate_region_config
+
+USERNAME=ubuntu
+BASE_PORT=${base_port}
+CLIENT_NUM=${client_num}
+
+
+echo "" > client.config
+echo "" > server.config
+
+bazel build //tools:certificate_tools
+bazel build //tools:generate_region_config
+
+idx=1
+tot=0
+for _ in ${iplist[@]};
+do
+  tot=$(($tot+1))
+done
+
+echo $PWD
+echo "node num:"$tot
+echo "base port:"${BASE_PORT}
+echo "client num:" ${CLIENT_NUM}
+
+for ip in ${iplist[@]};
+do
+  port=$((${BASE_PORT}+${idx}))
+  public_key=${key_path}/node${idx}.key.pub 
+  echo "get ip:"${ip}
+
+  # create public key
+  # create server config
+  # create the public key and certificate
+  if [ $(($idx+$CLIENT_NUM)) -gt $tot ] ; then
+    $CERT_TOOLS_BIN ${output_cert_path} ${ADMIN_PRIVATE_KEY} 
${ADMIN_PUBLIC_KEY} ${public_key} ${idx} ${ip} ${port} client
+    echo "${idx} ${ip} ${port}" >> client.config
+  else
+    $CERT_TOOLS_BIN ${output_cert_path} ${ADMIN_PRIVATE_KEY} 
${ADMIN_PUBLIC_KEY} ${public_key} ${idx} ${ip} ${port} replica
+    echo "${idx} ${ip} ${port}" >> server.config
+  fi
+
+  idx=$(($idx+1))
+done
+
+python3 ${CONFIG_TOOLS_BIN} ./server.config ./server.config.json 
+mv server.config.json ${output_path}/server/server.config
+mv client.config ${output_path}/interface/service.config
+echo "config done:" ${output_path}/server/server.config
+
diff --git a/service/tools/kv/server_tools/generate_config.sh 
b/service/tools/kv/server_tools/generate_config.sh
new file mode 100755
index 00000000..5f494434
--- /dev/null
+++ b/service/tools/kv/server_tools/generate_config.sh
@@ -0,0 +1,34 @@
+#
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License.  You may obtain a copy of the License at
+#
+#   http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied.  See the License for the
+# specific language governing permissions and limitations
+# under the License.
+#
+
+iplist=(
+127.0.0.1
+127.0.0.1
+127.0.0.1
+127.0.0.1
+127.0.0.1
+)
+
+WORKSPACE=$PWD
+CERT_PATH=$PWD/service/tools/data/cert/
+CONFIG_PATH=$PWD/service/tools/config/
+PORT_BASE=20000
+CLIENT_NUM=1
+
+./service/tools/config/generate_config.sh ${WORKSPACE} ${CERT_PATH} 
${CERT_PATH} ${CONFIG_PATH} ${CERT_PATH} ${CLIENT_NUM} ${PORT_BASE} 
${iplist[@]} 

Reply via email to