From 4f8a0d6aa138acf9c883face006c98cfd60a1212 Mon Sep 17 00:00:00 2001 From: Bugen Zhao Date: Wed, 13 Mar 2024 18:13:32 +0800 Subject: [PATCH] refactor(risedev): deprecate steps for building dashboard (#15655) Signed-off-by: Bugen Zhao --- Makefile.toml | 42 ------------------- ci/scripts/standalone-utils.sh | 6 +-- dashboard/README.md | 35 +++++++--------- src/cmd_all/scripts/standalone-demo-full.sh | 5 +-- src/risedevtool/common.toml | 1 - src/risedevtool/config/src/main.rs | 7 +++- src/risedevtool/src/task/meta_node_service.rs | 3 -- 7 files changed, 24 insertions(+), 75 deletions(-) diff --git a/Makefile.toml b/Makefile.toml index ed39ea0fc9425..f60b624f19c0b 100644 --- a/Makefile.toml +++ b/Makefile.toml @@ -352,46 +352,6 @@ alias = "build-risingwave" [tasks.build] alias = "build-risingwave" -[tasks.extract-dashboard-artifact] -private = true -category = "RiseDev - Build" -description = "Extract dashboard artifact" -condition = { env_not_set = ["ENABLE_BUILD_DASHBOARD"] } -script = ''' -#!/usr/bin/env bash - -# we allow this script to fail - -echo "Extracting dashboard artifacts to ${PREFIX_UI}" - -rm -rf "${PREFIX_UI}" -git worktree prune -git worktree add "${PREFIX_UI}" origin/dashboard-artifact -''' - -[tasks.export-dashboard] -private = true -category = "RiseDev - Build" -description = "Build dashboard" -condition = { env_set = [ - "ENABLE_BUILD_DASHBOARD", -], files_modified = { input = [ - "./dashboard/**/*.js", - "./dashboard/**/*.ts*", - "./dashboard/package.json", - "./dashboard/next.config.js", -], output = [ - "./dashboard/out/**/*.html", -] } } -script = """ -#!/usr/bin/env bash -set -e - -rm -rf "${PREFIX_UI}" -cd dashboard && npm run build-static -cd .. && ln -s "$(pwd)/dashboard/out" "${PREFIX_UI}" -""" - [tasks.build-risingwave] category = "RiseDev - Build" description = "Build Rust components" @@ -548,8 +508,6 @@ dependencies = [ "build-risingwave", "build-connector-node", "post-build-risingwave", - "extract-dashboard-artifact", - "export-dashboard", "prepare-config", ] diff --git a/ci/scripts/standalone-utils.sh b/ci/scripts/standalone-utils.sh index 438f413ebe4dc..630d99f9bb9bd 100755 --- a/ci/scripts/standalone-utils.sh +++ b/ci/scripts/standalone-utils.sh @@ -20,8 +20,7 @@ start_standalone_without_compactor() { --backend etcd \ --etcd-endpoints 127.0.0.1:2388 \ --state-store hummock+minio://hummockadmin:hummockadmin@127.0.0.1:9301/hummock001 \ - --data-directory hummock_001 \ - --dashboard-ui-path $RW_PREFIX/ui" \ + --data-directory hummock_001" \ --compute-opts=" \ --listen-addr 127.0.0.1:5688 \ --prometheus-listener-addr 127.0.0.1:1222 \ @@ -55,8 +54,7 @@ start_standalone() { --backend etcd \ --etcd-endpoints 127.0.0.1:2388 \ --state-store hummock+minio://hummockadmin:hummockadmin@127.0.0.1:9301/hummock001 \ - --data-directory hummock_001 \ - --dashboard-ui-path $RW_PREFIX/ui" \ + --data-directory hummock_001" \ --compute-opts=" \ --listen-addr 127.0.0.1:5688 \ --prometheus-listener-addr 127.0.0.1:1222 \ diff --git a/dashboard/README.md b/dashboard/README.md index fd4986b4b5bc3..0c321a2a07de6 100644 --- a/dashboard/README.md +++ b/dashboard/README.md @@ -28,44 +28,37 @@ TODO: Find a suitable testing framework ## Development -Start the RisingWave database, and create tables by removing drop tables from `tpch_snapshot.slt` +Start a RisingWave cluster, create some tables and materialized views for testing purposes. +For example: ```bash ./risedev d -sqllogictest -p 4566 -d dev './e2e_test/streaming/tpch_snapshot.slt' +sqllogictest -p 4566 -d dev './e2e_test/nexmark/create_tables.slt.part' +sqllogictest -p 4566 -d dev './e2e_test/streaming/nexmark/create_views.slt.part' ``` -Install Dependencies. +Install dependencies and start the development server. ```bash npm i -``` - -The website will be served at port 3000. It requests data from the mock server at port 32333. - -```bash npm run dev ``` -You should also run: - -```bash -./mock/fetch.sh # dump current data from RisingWave meta node to be used by mock server -node mock-server.js -``` - -To start a mock API server when developing. +The dashboard is now served at port 3000. +Go to the Settings page at `http://localhost:3000/settings/` and set the API endpoint to +`http://localhost:5691/api` in order to connect to the meta node of the running cluster. ## Test with RisingWave meta node -To replace the built static files in RisingWave with your newest code, -run the following scripts in the root directory. +The approach above is the best way to develop the dashboard since it supports hot reload and debugging. +However, if you still want to test how the dashboard behaves when it's served as static files within the meta node, +you can ask RiseDev to build the dashboard from the source code by running the following command. ```bash -./risedev export-dashboard +./risedev configure enable dashboard ``` -The dashboard will be served by meta node at port 5691. +The dashboard built with the latest sources will be served by meta node at port 5691. ## Deployment @@ -79,7 +72,7 @@ Build static files for standalone deployment without node.js. The built files ar Check more details at [Static HTML Export](https://nextjs.org/docs/advanced-features/static-html-export). ```bash -npm run build-static +npm run build ``` The built files are generated at `./out`. diff --git a/src/cmd_all/scripts/standalone-demo-full.sh b/src/cmd_all/scripts/standalone-demo-full.sh index 46ca69b982593..28135e7453669 100755 --- a/src/cmd_all/scripts/standalone-demo-full.sh +++ b/src/cmd_all/scripts/standalone-demo-full.sh @@ -22,8 +22,7 @@ start_standalone() { --etcd-endpoints 127.0.0.1:2388 \ --state-store hummock+minio://hummockadmin:hummockadmin@127.0.0.1:9301/hummock001 \ --data-directory hummock_001 \ - --config-path src/config/standalone-example.toml \ - --dashboard-ui-path $RW_PREFIX/ui" \ + --config-path src/config/standalone-example.toml" \ --compute-opts=" \ --config-path src/config/standalone-example.toml \ --listen-addr 127.0.0.1:5688 \ @@ -49,4 +48,4 @@ start_standalone() { --meta-address http://127.0.0.1:5690" } -start_standalone \ No newline at end of file +start_standalone diff --git a/src/risedevtool/common.toml b/src/risedevtool/common.toml index 9e0b30ae7e561..97ddcd0485f9d 100644 --- a/src/risedevtool/common.toml +++ b/src/risedevtool/common.toml @@ -14,7 +14,6 @@ PREFIX_CONFIG = "${PREFIX}/config" PREFIX_DATA = "${PREFIX}/data" PREFIX_LOG = "${PREFIX}/log" PREFIX_TMP = "${PREFIX}/tmp" -PREFIX_UI = "${PREFIX}/ui" PREFIX_DOCKER = "${PREFIX}/rw-docker" PREFIX_PROFILING = "${PREFIX}/profiling" diff --git a/src/risedevtool/config/src/main.rs b/src/risedevtool/config/src/main.rs index e8874456bb50b..7d36cc8d4646f 100644 --- a/src/risedevtool/config/src/main.rs +++ b/src/risedevtool/config/src/main.rs @@ -136,7 +136,12 @@ to RiseDev directory." } Self::Dashboard => { " -Required if you want to build dashboard from source." +Required if you want to build dashboard from source. +This is generally not the option you want to use to develop the +dashboard. Instead, directly run `npm run dev` in the dashboard +directory to start the development server, set the API endpoint +to a running RisingWave cluster in the settings page. +" } Self::Tracing => { " diff --git a/src/risedevtool/src/task/meta_node_service.rs b/src/risedevtool/src/task/meta_node_service.rs index d88580618763a..91288538303a0 100644 --- a/src/risedevtool/src/task/meta_node_service.rs +++ b/src/risedevtool/src/task/meta_node_service.rs @@ -196,9 +196,6 @@ impl Task for MetaNodeService { cmd.arg("--config-path") .arg(Path::new(&prefix_config).join("risingwave.toml")); - cmd.arg("--dashboard-ui-path") - .arg(env::var("PREFIX_UI").unwrap_or_else(|_| ".risingwave/ui".to_owned())); - if !self.config.user_managed { ctx.run_command(ctx.tmux_run(cmd)?)?; ctx.pb.set_message("started");