Skip to content

Commit

Permalink
chore: add worker command paramters
Browse files Browse the repository at this point in the history
  • Loading branch information
hibig committed Dec 23, 2024
1 parent 6ce6a93 commit 762ab30
Show file tree
Hide file tree
Showing 8 changed files with 94 additions and 28 deletions.
8 changes: 6 additions & 2 deletions src/locales/en-US/resources.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,10 +47,14 @@ export default {
'Note: <span style="color: #000;font-weight: 600">mytoken</span> is the token obtained in the first step.',
'resources.worker.add.step3':
'After success, refresh the workers list to see the new worker.',
'resources.worker.container.supported': 'Do not support windows.',
'resources.worker.container.supported': 'Do not support MacOS or Windows.',
'resources.worker.current.version': 'Current version is {version}.',
'resources.worker.driver.install':
'Ensure all necessary drivers and libraries are installed on the system prior to installing GPUStack.',
'resources.worker.select.command':
'Select a label to generate the command and copy it using the copy button.',
'resources.worker.script.install': 'Script Installation',
'resources.worker.container.install': 'Container Installation'
'resources.worker.container.install': 'Container Installation',
'resources.worker.cann.tips':
'Set <span style="color: #000;font-weight: 600">ASCEND_VISIBLE_DEVICES</span> to 0 for a single GPU or to the index range (e.g., 0-7 for 8 GPUs) for multiple GPUs.'
};
8 changes: 6 additions & 2 deletions src/locales/zh-CN/resources.ts
Original file line number Diff line number Diff line change
Expand Up @@ -46,9 +46,13 @@ export default {
'resources.worker.add.step2.tips':
'注意:<span style="color: #000;font-weight: 600">mytoken</span> 为第一步获取到的 Token',
'resources.worker.add.step3': '成功后,刷新 worker 列表即可看到新的 worker',
'resources.worker.container.supported': '不支持 Windows',
'resources.worker.container.supported': '不支持 MacOS 和 Windows',
'resources.worker.current.version': '当前版本为 {version}',
'resources.worker.select.command': '选择一个标签生成命令并使用复制按钮复制',
'resources.worker.driver.install':
'在安装 GPUStack 之前,确保系统上安装了所有必需的驱动程序和库',
'resources.worker.script.install': '脚本安装',
'resources.worker.container.install': '容器安装'
'resources.worker.container.install': '容器安装',
'resources.worker.cann.tips':
'若 GPU 数量为 1,则设 ASCEND_VISIBLE_DEVICES=0;若大于 1,则设为索引范围(如 8 张为 0-7)'
};
10 changes: 4 additions & 6 deletions src/pages/llmodels/components/search-model.tsx
Original file line number Diff line number Diff line change
@@ -1,8 +1,4 @@
import {
BulbOutlined,
QuestionCircleOutlined,
WarningOutlined
} from '@ant-design/icons';
import { BulbOutlined, QuestionCircleOutlined } from '@ant-design/icons';
import { useIntl } from '@umijs/max';
import { Checkbox, Select, Tooltip } from 'antd';
import _ from 'lodash';
Expand Down Expand Up @@ -238,7 +234,9 @@ const SearchModel: React.FC<SearchInputProps> = (props) => {
modelSource={modelSource}
></SearchInput>
<div className="gguf-tips">
<WarningOutlined className="font-size-14 m-r-5 warning" />
<span className="m-r-5">
{intl.formatMessage({ id: 'common.tips.title' })}
</span>
<span>
{intl.formatMessage({ id: 'models.form.search.gguftips' })}
</span>
Expand Down
2 changes: 1 addition & 1 deletion src/pages/resources/components/add-worker.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ const AddWorker: React.FC<ViewModalProps> = (props) => {
width={600}
styles={{
body: {
height: 310
height: 410
}
}}
footer={null}
Expand Down
52 changes: 38 additions & 14 deletions src/pages/resources/components/container-install.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { getAtomStorage } from '@/atoms/utils';
import HighlightCode from '@/components/highlight-code';
import { BulbOutlined, WarningOutlined } from '@ant-design/icons';
import { useIntl } from '@umijs/max';
import { Radio } from 'antd';
import { Button, Radio } from 'antd';
import React from 'react';
import { addWorkerGuide, containerInstallOptions } from '../config';
import './styles/installation.less';
Expand All @@ -24,14 +24,17 @@ const AddWorker: React.FC<ViewModalProps> = (props) => {
if (!version || !versionInfo.isProduction) {
version = 'main';
}

const commandCode = addWorkerGuide[activeKey];

if (activeKey === 'cuda') {
return addWorkerGuide.docker.registerWorker({
return commandCode?.registerWorker({
server: origin,
tag: version,
token: props.token
});
}
return addWorkerGuide.docker.registerWorker({
return commandCode?.registerWorker({
server: origin,
tag: `${version}-${activeKey}`,
token: props.token
Expand All @@ -40,28 +43,41 @@ const AddWorker: React.FC<ViewModalProps> = (props) => {

return (
<div className="container-install">
<div className="notes">
<span>
1.{' '}
<ul className="notes">
<li>
<span>
{intl.formatMessage({ id: 'resources.worker.container.supported' })}
</span>
<WarningOutlined
style={{ color: 'var(--ant-color-warning)' }}
className="font-size-14 m-l-5"
/>
</span>
<span>
2.{' '}
</li>
<li>
{intl.formatMessage(
{ id: 'resources.worker.current.version' },
{ version: versionInfo.version }
)}
</span>
<span>
3. {intl.formatMessage({ id: 'resources.worker.select.command' })}
</span>
</div>
</li>
<li>{intl.formatMessage({ id: 'resources.worker.select.command' })}</li>
<li>
<span>
{intl.formatMessage({ id: 'resources.worker.driver.install' })}
</span>
<WarningOutlined
style={{ color: 'var(--ant-color-warning)' }}
className="font-size-14 m-l-5"
/>
<Button
type="link"
size="small"
href="https://docs.gpustack.ai/latest/installation/installation-requirements/"
target="_blank"
>
{intl.formatMessage({ id: 'playground.audio.enablemic.doc' })}
</Button>
</li>
</ul>
<div className="m-b-20">
<Radio.Group
block
Expand All @@ -74,6 +90,14 @@ const AddWorker: React.FC<ViewModalProps> = (props) => {
size="small"
/>
</div>
{activeKey === 'npu' && (
<div
className="m-b-8 text-tertiary"
dangerouslySetInnerHTML={{
__html: intl.formatMessage({ id: 'resources.worker.cann.tips' })
}}
></div>
)}
<HighlightCode theme="dark" code={code}></HighlightCode>
<h3>
<BulbOutlined className="m-r-5"></BulbOutlined>
Expand Down
2 changes: 1 addition & 1 deletion src/pages/resources/components/script-install.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ const AddWorker: React.FC<ViewModalProps> = (props) => {
const origin = window.location.origin;

return (
<div>
<div className="script-install">
<h4>{intl.formatMessage({ id: 'resources.worker.linuxormaxos' })}</h4>
<HighlightCode
code={addWorkerGuide.mac.registerWorker({
Expand Down
15 changes: 15 additions & 0 deletions src/pages/resources/components/styles/installation.less
Original file line number Diff line number Diff line change
Expand Up @@ -9,5 +9,20 @@
padding-left: 16px;
background: var(--color-fill-sider);
border-radius: 2px;
list-style-type: decimal;

li {
margin-left: 12px;
}
}

.code-pre {
white-space: pre-wrap;
}
}

.script-install {
.code-pre {
white-space: pre-wrap;
}
}
25 changes: 23 additions & 2 deletions src/pages/resources/config/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ export const status: any = {
[WorkerStatusMap.not_ready]: StatusMaps.error
};

export const addWorkerGuide = {
export const addWorkerGuide: Record<string, any> = {
mac: {
getToken: 'cat /var/lib/gpustack/token',
registerWorker(params: { server: string; token: string }) {
Expand All @@ -29,12 +29,33 @@ export const addWorkerGuide = {
return `Invoke-Expression "& { $((Invoke-WebRequest -Uri "https://get.gpustack.ai" -UseBasicParsing).Content) } --server-url ${params.server} --token ${params.token}"`;
}
},
docker: {
cuda: {
getToken:
'Get-Content -Path (Join-Path -Path $env:APPDATA -ChildPath "gpustack\\token") -Raw',
registerWorker(params: { server: string; tag: string; token: string }) {
return `docker run -d --gpus all --ipc=host --network=host gpustack/gpustack:${params.tag} --server-url ${params.server} --token ${params.token}`;
}
},
npu: {
getToken:
'Get-Content -Path (Join-Path -Path $env:APPDATA -ChildPath "gpustack\\token") -Raw',
registerWorker(params: { server: string; tag: string; token: string }) {
return `docker run -d --ipc=host -e ASCEND_VISIBLE_DEVICES=0 --network=host gpustack/gpustack:${params.tag} --server-url ${params.server} --token ${params.token}`;
}
},
musa: {
getToken:
'Get-Content -Path (Join-Path -Path $env:APPDATA -ChildPath "gpustack\\token") -Raw',
registerWorker(params: { server: string; tag: string; token: string }) {
return `docker run -d --ipc=host --network=host gpustack/gpustack:${params.tag} --server-url ${params.server} --token ${params.token}`;
}
},
cpu: {
getToken:
'Get-Content -Path (Join-Path -Path $env:APPDATA -ChildPath "gpustack\\token") -Raw',
registerWorker(params: { server: string; tag: string; token: string }) {
return `docker run -d --ipc=host --network=host gpustack/gpustack:${params.tag} --server-url ${params.server} --token ${params.token}`;
}
}
};

Expand Down

0 comments on commit 762ab30

Please sign in to comment.