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

DNM: TiUP Cluster UI #706

Closed
wants to merge 147 commits into from
Closed
Changes from 1 commit
Commits
Show all changes
147 commits
Select commit Hold shift + click to select a range
c33c6a2
test listener
baurine Aug 21, 2020
331db68
add vagrant for test
baurine Aug 21, 2020
e293bcc
update vagrant config
baurine Aug 21, 2020
4bba02f
add comments
baurine Aug 21, 2020
22909d6
calc progress
baurine Aug 22, 2020
1d0af1f
move web to tiup
baurine Aug 22, 2020
e8698b0
run deploy in a routine
baurine Aug 22, 2020
e3325df
update Deploy parameter
baurine Aug 22, 2020
3be76e2
move web ui
baurine Aug 22, 2020
247f532
list cluster frontend
baurine Aug 22, 2020
2448965
show cluster detail
baurine Aug 22, 2020
79dd983
destroy cluster
baurine Aug 22, 2020
48325fa
deploy status
baurine Aug 22, 2020
ad54704
refine
baurine Aug 22, 2020
99dd507
revert
baurine Aug 22, 2020
886306f
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Aug 22, 2020
f6bd841
refine api
baurine Aug 22, 2020
daf6b10
refine
baurine Aug 22, 2020
94f4c19
refine
baurine Aug 22, 2020
1988e58
save cluster name and tidb version
baurine Aug 22, 2020
29b1875
get cluster topo
baurine Aug 22, 2020
1742586
show cluster topo
baurine Aug 22, 2020
bdf27ef
refine
baurine Aug 22, 2020
00d770f
update generate topo
baurine Aug 22, 2020
5e011c1
fix missed error
baurine Aug 22, 2020
5b86dd7
set global login options
baurine Aug 24, 2020
9ce7594
refine
baurine Aug 24, 2020
2dce800
start and stop cluster
baurine Aug 24, 2020
89d74e1
scale in cluster
baurine Aug 24, 2020
263e30c
refine
baurine Aug 24, 2020
6e981e7
revert vagrantfile
baurine Aug 25, 2020
ce5e697
prepare scale out
baurine Aug 25, 2020
d95335f
refine
baurine Aug 25, 2020
457f487
record scale out status
baurine Aug 25, 2020
43cb6b5
scale out frontend
baurine Aug 25, 2020
6c6bd5a
refine
baurine Aug 25, 2020
7042039
refine
baurine Aug 25, 2020
23f072e
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Aug 25, 2020
75a6f18
refine, only show started steps
baurine Aug 25, 2020
aed394d
fix
baurine Aug 25, 2020
9a92132
refine save progress and status for scale out
baurine Aug 26, 2020
541e1cd
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Aug 26, 2020
7896fdc
refine
baurine Aug 27, 2020
820bd3e
Merge remote-tracking branch 'origin' into tiup-web
baurine Aug 27, 2020
023518e
update save deploy and scale out status logic
baurine Aug 27, 2020
d592948
update start cluster, record status as well
baurine Aug 27, 2020
299c066
update stop cluster, record status as well
baurine Aug 27, 2020
d3ad4f1
update scale in cluster, record status as well
baurine Aug 27, 2020
7000f93
update destroy cluster, record status as well
baurine Aug 27, 2020
cee5dcc
adjust router
baurine Aug 27, 2020
6a5400a
update status page
baurine Aug 27, 2020
c356c8b
refine
baurine Aug 27, 2020
18b657c
add scale out page
baurine Aug 27, 2020
2cb3203
move OperationStatus
baurine Aug 27, 2020
9394152
extract CompsManager
baurine Aug 27, 2020
4460b5d
edit and delete component
baurine Aug 27, 2020
d2a09cb
auto get topo
baurine Aug 27, 2020
fcbfc51
refine
baurine Aug 27, 2020
8cfce30
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Aug 28, 2020
b9a36ca
fix compile
baurine Aug 28, 2020
76b3d3c
revert
baurine Aug 28, 2020
2c2499a
wip
baurine Aug 28, 2020
810920f
wip
baurine Aug 28, 2020
2e54aba
handle location labels
baurine Aug 28, 2020
833de2e
sync scale out
baurine Aug 28, 2020
d2fe18f
wip
baurine Aug 28, 2020
bc86612
embed assets
baurine Aug 28, 2020
ff62f32
wip
baurine Aug 28, 2020
11d3ab9
wip
baurine Aug 28, 2020
d4ee68d
use hashrouter
baurine Aug 28, 2020
7a3a493
refine
baurine Aug 28, 2020
f26acef
refine
baurine Aug 29, 2020
eb126d1
fix routers
baurine Aug 29, 2020
4b0baa9
refine, add redirect
baurine Aug 29, 2020
cee57a4
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Aug 29, 2020
201ae0b
refine
baurine Aug 31, 2020
f9c0219
support assign password
baurine Aug 31, 2020
01149df
refine
baurine Aug 31, 2020
17137cd
extract types
baurine Aug 31, 2020
8bd384f
wip
baurine Aug 31, 2020
615e57b
refine
baurine Sep 1, 2020
fe2b3b6
refine
baurine Sep 1, 2020
bc05c60
support setting deploy dir and data dir
baurine Sep 1, 2020
dbe5688
set alias
baurine Sep 1, 2020
af4b9e0
wip
baurine Sep 1, 2020
c7c2e98
fix compile error
baurine Sep 1, 2020
960d9a1
refine
baurine Sep 1, 2020
af8b247
rename utils to apis
baurine Sep 1, 2020
9429443
refine
baurine Sep 1, 2020
0764786
refine
baurine Sep 1, 2020
f010f10
refine
baurine Sep 1, 2020
c3b82a1
refine
baurine Sep 1, 2020
aa746c4
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Sep 1, 2020
5af2a18
refine ListCluster
baurine Sep 1, 2020
ee6ea25
refine Display
baurine Sep 1, 2020
e713d2e
fix deploy progress
baurine Sep 1, 2020
d9eb614
refine
baurine Sep 1, 2020
0f5e2e3
support global dir
baurine Sep 2, 2020
066a2a0
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Sep 2, 2020
5231734
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Sep 9, 2020
68ea2f7
fix compile
baurine Sep 9, 2020
1d8b1e8
fix pd and alertmanger increasePorts method
baurine Sep 10, 2020
62f136e
fix crash when scale out
baurine Sep 10, 2020
13c7418
run cluster web ui by `tiup-cluster --ui`
baurine Sep 10, 2020
31900e3
fix
baurine Sep 11, 2020
a2749d0
rename web-ui to cluster-ui
baurine Sep 11, 2020
fd4a164
update embed assets
baurine Sep 11, 2020
1589547
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Sep 11, 2020
42b82b8
add missed react hook dependency
baurine Sep 11, 2020
7dc97c9
close eslint href check
baurine Sep 11, 2020
d57d330
dismiss react hook warning
baurine Sep 11, 2020
c2864ab
Merge branch 'master' into tiup-web
baurine Sep 14, 2020
d334a3a
Merge branch 'master' into tiup-web
lonng Sep 14, 2020
ab47793
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Sep 16, 2020
f82a768
add v4.0.6 option and support input the version manually
baurine Sep 16, 2020
ea0a9f4
Merge branch 'master' into tiup-web
baurine Sep 17, 2020
d4fdb0c
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Oct 10, 2020
eb717c7
fix compile error
baurine Oct 10, 2020
539c434
support modify cluster configuration by integrate tidb-dashboard
baurine Oct 10, 2020
0e93281
check whether configuration feature is enabled in responding tidb
baurine Oct 12, 2020
d5d90d2
support to supply tidb offline download address
baurine Oct 14, 2020
2c7a95d
support config mirror address when deploying
baurine Oct 14, 2020
6fc3ad6
move setting mirror address to a single page
baurine Oct 15, 2020
d57a6ff
fix set mirror failed bug and refine
baurine Oct 15, 2020
5aed034
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Oct 15, 2020
33550f9
add more entries for dashboard
baurine Oct 16, 2020
b71c7bb
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Oct 16, 2020
a6422ae
refine wording
baurine Oct 16, 2020
26b6c71
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Oct 21, 2020
ef8cf3a
ignore label check when deploying and scaling out
baurine Oct 21, 2020
03165c7
add changelog and a shell for build linux tiup cluster
baurine Oct 21, 2020
5c6b6c0
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Oct 21, 2020
ffa34e7
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Oct 26, 2020
6520a29
fix compile
baurine Oct 26, 2020
89f4c98
change location labels
baurine Oct 26, 2020
a3a4c17
support modify topo manually
baurine Oct 26, 2020
660054c
support config numa_node
baurine Oct 26, 2020
ce6490f
refine
baurine Oct 26, 2020
29975d3
add changelog
baurine Oct 26, 2020
7f75414
refine
baurine Nov 3, 2020
0fc71b9
update changelog
baurine Nov 4, 2020
54545a1
support config arch for machine
baurine Nov 4, 2020
bb5a48a
update CHANGELOG
baurine Nov 4, 2020
83e22f9
refine cluster topo table
baurine Nov 4, 2020
b456ce1
Merge remote-tracking branch 'origin/master' into tiup-web
baurine Nov 12, 2020
307be0b
audit for web commands
baurine Nov 13, 2020
27e1bca
update changelog
baurine Nov 13, 2020
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
wip
  • Loading branch information
baurine committed Aug 31, 2020
commit 8bd384fb98805ebb7817dc52f37df9d30d8b92e6
4 changes: 2 additions & 2 deletions web-ui/src/pages/Clusters/ClusterDetail.tsx
Original file line number Diff line number Diff line change
@@ -13,7 +13,7 @@ import {
} from '../../utils/api'
import { Root } from '../../components/Root'
import { ICluster } from '.'
import { IComponent } from '../Deployment/DeploymentTable'
import { BaseComp } from '../../types/comps'

export interface IClusterInstInfo {
id: string
@@ -44,7 +44,7 @@ export default function ClusterDetailPage() {
scale_out_nodes: any[]
}>('cur_scale_out_nodes', { cluster_name: '', scale_out_nodes: [] })
const [components, setComponents] = useLocalStorageState<{
[key: string]: IComponent
[key: string]: BaseComp
}>('components', {})

const [loadingTopo, setLoadingTopo] = useState(false)
116 changes: 11 additions & 105 deletions web-ui/src/pages/Deployment/CompsManager.tsx
Original file line number Diff line number Diff line change
@@ -1,36 +1,17 @@
import React, { useCallback, useState } from 'react'
import { useLocalStorageState } from 'ahooks'
import { Drawer, Button, Modal, Form, Input, Select } from 'antd'
import uniqid from 'uniqid'
import yaml from 'yaml'

import { IMachine } from '../Machines/MachineForm'
import DeploymentTable, {
IComponent,
COMPONENT_TYPES,
DEF_TIDB_PORT,
DEF_TIDB_STATUS_PORT,
DEF_TIKV_PORT,
DEF_TIKV_STATUS_PORT,
DEF_TIFLASH_TCP_PORT,
DEF_TIFLASH_HTTP_PORT,
DEF_TIFLASH_SERVICE_PORT,
DEF_TIFLASH_PROXY_PORT,
DEF_TIFLASH_PROXY_STATUS_PORT,
DEF_TIFLASH_METRICS_PORT,
DEF_PD_PEER_PORT,
DEF_PROM_PORT,
DEF_GRAFANA_PORT,
DEF_ALERT_CLUSTER_PORT,
DEF_PD_CLIENT_PORT,
DEF_ALERT_WEB_PORT,
} from './DeploymentTable'
import DeploymentTable from './DeploymentTable'
import EditCompForm from './EditCompForm'
import TopoPreview, { genTopo } from './TopoPreview'
import { Root } from '../../components/Root'
import { deployCluster, scaleOutCluster } from '../../utils/api'
import { IGlobalLoginOptions } from '../Machines/GlobalLoginOptionsForm'
import { useNavigate } from 'react-router-dom'
import { BaseComp, CompTypes } from '../../types/comps'

// TODO: fetch from API
const TIDB_VERSIONS = [
@@ -62,9 +43,9 @@ export default function CompsManager({
[key: string]: IMachine
}>('machines', {})
const [components, setComponents] = useLocalStorageState<{
[key: string]: IComponent
[key: string]: BaseComp
}>('components', {})
const [curComp, setCurComp] = useState<IComponent | undefined>(undefined)
const [curComp, setCurComp] = useState<BaseComp | undefined>(undefined)

const [previewYaml, setPreviewYaml] = useState(false)

@@ -88,65 +69,16 @@ export default function CompsManager({
const [form] = Form.useForm()

const handleAddComponent = useCallback(
(machine: IMachine, componentType: string, forScaleOut: boolean) => {
let comp: IComponent = {
id: uniqid(),
machineID: machine.id,
type: componentType,
for_scale_out: forScaleOut,
priority: COMPONENT_TYPES.indexOf(componentType),
}
(machine: IMachine, componentType: CompTypes, forScaleOut: boolean) => {
let comp = BaseComp.create(componentType, machine.id, forScaleOut)
const existedSameComps = Object.values(components).filter(
(comp) => comp.type === componentType && comp.machineID === machine.id
)
if (existedSameComps.length > 0) {
const lastComp = existedSameComps[existedSameComps.length - 1] as any
const lastComp = existedSameComps[existedSameComps.length - 1]
comp.deploy_dir_prefix = lastComp.deploy_dir_prefix
comp.data_dir_prefix = lastComp.data_dir_prefix
let newComp = comp as any
switch (componentType) {
case 'TiDB':
newComp.port = (lastComp.port || DEF_TIDB_PORT) + 1
newComp.status_port =
(lastComp.status_port || DEF_TIDB_STATUS_PORT) + 1
break
case 'TiKV':
newComp.port = (lastComp.port || DEF_TIKV_PORT) + 1
newComp.status_port =
(lastComp.status_port || DEF_TIKV_STATUS_PORT) + 1
break
case 'TiFlash':
newComp.tcp_port = (lastComp.tcp_port || DEF_TIFLASH_TCP_PORT) + 1
newComp.http_port =
(lastComp.http_port || DEF_TIFLASH_HTTP_PORT) + 1
newComp.flash_service_port =
(lastComp.flash_service_port || DEF_TIFLASH_SERVICE_PORT) + 1
newComp.flash_proxy_port =
(lastComp.flash_proxy_port || DEF_TIFLASH_PROXY_PORT) + 1
newComp.flash_proxy_status_port =
(lastComp.flash_proxy_status_port ||
DEF_TIFLASH_PROXY_STATUS_PORT) + 1
newComp.metrics_port =
(lastComp.metrics_port || DEF_TIFLASH_METRICS_PORT) + 1
break
case 'PD':
newComp.client_port = (lastComp.peer_port || DEF_PD_PEER_PORT) + 1
newComp.peer_port = (lastComp.peer_port || DEF_PD_PEER_PORT) + 2
break
case 'Prometheus':
newComp.port = (lastComp.port || DEF_PROM_PORT) + 1
break
case 'Grafana':
newComp.port = (lastComp.port || DEF_GRAFANA_PORT) + 2
break
case 'AlertManager':
newComp.web_port =
(lastComp.cluster_port || DEF_ALERT_CLUSTER_PORT) + 1
newComp.cluster_port =
(lastComp.cluster_port || DEF_ALERT_CLUSTER_PORT) + 2
break
}
comp = newComp
comp.increasePorts(lastComp)
}
setComponents({
...components,
@@ -157,7 +89,7 @@ export default function CompsManager({
)

const handleUpdateComponent = useCallback(
(comp: IComponent) => {
(comp: BaseComp) => {
setComponents({
...components,
[comp.id]: comp,
@@ -168,7 +100,7 @@ export default function CompsManager({
)

const handleDeleteComponent = useCallback(
(comp: IComponent) => {
(comp: BaseComp) => {
const newComps = { ...components }
delete newComps[comp.id]
setComponents(newComps)
@@ -220,33 +152,7 @@ export default function CompsManager({

const scaleOutNodes: any[] = []
for (const comp of scaleOutComps) {
let port: number = 0
let rec = comp as any

switch (rec.type) {
case 'TiDB':
port = rec.port || DEF_TIDB_PORT
break
case 'TiKV':
port = rec.port || DEF_TIKV_PORT
break
case 'TiFlash':
port = rec.tcp_port || DEF_TIFLASH_TCP_PORT
break
case 'PD':
port = rec.client_port || DEF_PD_CLIENT_PORT
break
case 'Prometheus':
port = rec.port || DEF_PROM_PORT
break
case 'Grafana':
port = rec.port || DEF_GRAFANA_PORT
break
case 'AlertManager':
port = rec.web_port || DEF_ALERT_WEB_PORT
break
}

let port: number = comp.symbolPort()
const machine = machines[comp.machineID]
scaleOutNodes.push({ id: comp.id, node: `${machine.host}:${port}` })
}
147 changes: 10 additions & 137 deletions web-ui/src/pages/Deployment/DeploymentTable.tsx
Original file line number Diff line number Diff line change
@@ -8,104 +8,19 @@ import {
IGlobalLoginOptions,
DEF_UESRNAME,
} from '../Machines/GlobalLoginOptionsForm'

export const COMPONENT_TYPES = [
'TiDB',
'TiKV',
'TiFlash',
'PD',
'Prometheus',
'Grafana',
'AlertManager',
]

const COMPONENT_COLORS = {
TiDB: 'magenta',
TiKV: 'orange',
TiFlash: 'red',
PD: 'purple',
Prometheus: 'green',
Grafana: 'cyan',
AlertManager: 'blue',
}

export interface IComponent {
id: string
machineID: string
type: string
for_scale_out: boolean
priority: number

deploy_dir_prefix?: string // "tidb-deploy"
data_dir_prefix?: string // "tidb-data", TiDB and Grafana have no data_dir
}
export const DEF_DEPLOY_DIR_PREFIX = 'tidb-deploy'
export const DEF_DATA_DIR_PREFIX = 'tidb-data'

export interface ITiDBComponent extends IComponent {
port?: number // 4000
status_port?: number // 10080
}
export const DEF_TIDB_PORT = 4000
export const DEF_TIDB_STATUS_PORT = 10080

export interface ITiKVComponent extends IComponent {
port?: number // 20160
status_port?: number // 20180
}
export const DEF_TIKV_PORT = 20160
export const DEF_TIKV_STATUS_PORT = 20180

export interface ITiFlashComponent extends IComponent {
tcp_port?: number // 9000
http_port?: number // 8123
flash_service_port?: number // 3930
flash_proxy_port?: number // 20170
flash_proxy_status_port?: number // 20292
metrics_port?: number // 8234
}
export const DEF_TIFLASH_TCP_PORT = 9000
export const DEF_TIFLASH_HTTP_PORT = 8123
export const DEF_TIFLASH_SERVICE_PORT = 3930
export const DEF_TIFLASH_PROXY_PORT = 20170
export const DEF_TIFLASH_PROXY_STATUS_PORT = 20292
export const DEF_TIFLASH_METRICS_PORT = 8234

export interface IPDComponent extends IComponent {
client_port?: number // 2379
peer_port?: number // 2380
}
export const DEF_PD_CLIENT_PORT = 2379
export const DEF_PD_PEER_PORT = 2380

export interface IPrometheusComponent extends IComponent {
port?: number // 9090
}
export const DEF_PROM_PORT = 9090

export interface IGrafanaComponent extends IComponent {
port?: number // 3000
}
export const DEF_GRAFANA_PORT = 3000

export interface IAlertManagerComponent extends IComponent {
web_port?: number // 9093
cluster_port?: number // 9094
}
export const DEF_ALERT_WEB_PORT = 9093
export const DEF_ALERT_CLUSTER_PORT = 9094
import { BaseComp, COMP_TYPES_ARR, CompTypes } from '../../types/comps'

interface IDeploymentTableProps {
forScaleOut: boolean // deploy or scale out
machines: { [key: string]: IMachine }
components: { [key: string]: IComponent }
components: { [key: string]: BaseComp }
onAddComponent?: (
machine: IMachine,
componentType: string,
componentType: CompTypes,
forScaleOut: boolean
) => void
onEditComponent?: (comp: IComponent) => void
onDeleteComponent?: (comp: IComponent) => void
onEditComponent?: (comp: BaseComp) => void
onDeleteComponent?: (comp: BaseComp) => void
onDeleteComponents?: (machine: IMachine, forScaleOut: boolean) => void
}

@@ -124,7 +39,7 @@ export default function DeploymentTable({
)

const dataSource = useMemo(() => {
let machinesAndComps: (IMachine | IComponent)[] = []
let machinesAndComps: (IMachine | BaseComp)[] = []
const sortedMachines = Object.values(machines).sort((a, b) =>
a.host > b.host ? 1 : -1
)
@@ -166,7 +81,7 @@ export default function DeploymentTable({
return (
<div>
--&nbsp;
<Tag key={rec.type} color={(COMPONENT_COLORS as any)[rec.type]}>
<Tag key={rec.type} color={rec.color}>
{rec.type}
{rec.for_scale_out ? ' (Scale)' : ''}
</Tag>
@@ -183,49 +98,7 @@ export default function DeploymentTable({
rec.username || globalLoginOptions.username || DEF_UESRNAME
}, DC=${rec.dc}, Rack=${rec.rack}`
}
switch (rec.type) {
case 'TiDB':
return `Port=${rec.port || DEF_TIDB_PORT}/${
rec.status_port || DEF_TIDB_STATUS_PORT
}, Path=${rec.deploy_dir_prefix || DEF_DEPLOY_DIR_PREFIX}`
case 'TiKV':
return `Port=${rec.port || DEF_TIKV_PORT}/${
rec.status_port || DEF_TIKV_STATUS_PORT
}, Path=${rec.deploy_dir_prefix || DEF_DEPLOY_DIR_PREFIX},${
rec.data_dir_prefix || DEF_DATA_DIR_PREFIX
}`
case 'TiFlash':
return `Port=${rec.tcp_port || DEF_TIFLASH_TCP_PORT}/${
rec.http_port || DEF_TIFLASH_HTTP_PORT
}/${rec.flash_service_port || DEF_TIFLASH_SERVICE_PORT}/${
rec.flash_proxy_port || DEF_TIFLASH_PROXY_PORT
}/${
rec.flash_proxy_status_port || DEF_TIFLASH_PROXY_STATUS_PORT
}/${rec.metrics_port || DEF_TIFLASH_METRICS_PORT}, Path=${
rec.deploy_dir_prefix || DEF_DEPLOY_DIR_PREFIX
},${rec.data_dir_prefix || DEF_DATA_DIR_PREFIX}`
case 'PD':
return `Port=${rec.client_port || DEF_PD_CLIENT_PORT}/${
rec.peer_port || DEF_PD_PEER_PORT
}, Path=${rec.deploy_dir_prefix || DEF_DEPLOY_DIR_PREFIX},${
rec.data_dir_prefix || DEF_DATA_DIR_PREFIX
}`
case 'Prometheus':
return `Port=${rec.port || DEF_PROM_PORT}, Path=${
rec.deploy_dir_prefix || DEF_DEPLOY_DIR_PREFIX
},${rec.data_dir_prefix || DEF_DATA_DIR_PREFIX}`
case 'Grafana':
return `Port=${rec.port || DEF_GRAFANA_PORT}, Path=${
rec.deploy_dir_prefix || DEF_DEPLOY_DIR_PREFIX
}`
case 'AlertManager':
return `Port=${rec.web_port || DEF_ALERT_WEB_PORT}/${
rec.cluster_port || DEF_ALERT_CLUSTER_PORT
}, Path=${rec.deploy_dir_prefix || DEF_DEPLOY_DIR_PREFIX},${
rec.data_dir_prefix || DEF_DATA_DIR_PREFIX
}`
}
return '...'
return `Port=${rec.ports()}, Path=${rec.paths()}`
},
},
{
@@ -240,10 +113,10 @@ export default function DeploymentTable({
<Menu
onClick={(e) =>
onAddComponent &&
onAddComponent(rec, e.key as string, forScaleOut)
onAddComponent(rec, e.key as CompTypes, forScaleOut)
}
>
{COMPONENT_TYPES.map((t) => (
{COMP_TYPES_ARR.map((t) => (
<Menu.Item key={t}>{t}</Menu.Item>
))}
</Menu>
Loading