mirror of
				https://github.com/TeaOSLab/EdgeAdmin.git
				synced 2025-11-04 05:00:25 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			258 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			258 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
{$layout}
 | 
						||
 | 
						||
	{$template "node_menu"}
 | 
						||
 | 
						||
	<table class="ui table definition selectable">
 | 
						||
		<tr>
 | 
						||
			<td class="title">节点名称</td>
 | 
						||
			<td>{{node.name}}</td>
 | 
						||
		</tr>
 | 
						||
		<tr>
 | 
						||
			<td>状态</td>
 | 
						||
			<td><label-on :v-is-on="node.isOn"></label-on></td>
 | 
						||
		</tr>
 | 
						||
        <tr>
 | 
						||
            <td>所属集群</td>
 | 
						||
            <td>
 | 
						||
                <node-clusters-labels :v-primary-cluster="node.cluster" :v-secondary-clusters="node.secondaryClusters"></node-clusters-labels>
 | 
						||
            </td>
 | 
						||
        </tr>
 | 
						||
		<tr>
 | 
						||
			<td>IP地址</td>
 | 
						||
			<td>
 | 
						||
				<div v-if="node.ipAddresses.length > 0">
 | 
						||
					<div>
 | 
						||
						<div v-for="(address, index) in node.ipAddresses" class="ui label tiny basic">
 | 
						||
                            <span v-if="address.ip.indexOf(':') > -1" class="grey">[IPv6]</span> {{address.ip}}
 | 
						||
                            <span class="small red" v-if="address.originIP != null && address.originIP.length > 0 && address.originIP != address.ip">(原:{{address.originIP}})</span>
 | 
						||
							<span class="small grey" v-if="address.name.length > 0">({{address.name}}<span v-if="!address.canAccess">,不可访问</span>)</span>
 | 
						||
							<span class="small grey" v-if="address.name.length == 0 && !address.canAccess">(不可访问)</span>
 | 
						||
                            <span class="small red" v-if="!address.isOn">[off]</span>
 | 
						||
                            <span class="small red" v-if="!address.isUp">[down]</span>
 | 
						||
                            <span class="small" v-if="address.thresholds != null && address.thresholds.length > 0">[阈值]</span>
 | 
						||
						</div>
 | 
						||
					</div>
 | 
						||
				</div>
 | 
						||
				<div v-else>
 | 
						||
					<span class="disabled">暂时还没有填写IP地址。</span>
 | 
						||
				</div>
 | 
						||
			</td>
 | 
						||
		</tr>
 | 
						||
		<tr v-if="node.routes.length > 0">
 | 
						||
			<td>DNS线路</td>
 | 
						||
			<td>
 | 
						||
                <span class="ui label tiny basic" v-for="route in node.routes">{{route.name}} <span class="grey small">({{route.domainName}})</span></span>
 | 
						||
			</td>
 | 
						||
		</tr>
 | 
						||
        <tr v-if="node.records.length > 0">
 | 
						||
            <td>DNS记录</td>
 | 
						||
            <td>
 | 
						||
                <div :style="{opacity: dnsIsExcludingLnNode ? 0.5 : 1.0}">
 | 
						||
                    <table class="ui table celled">
 | 
						||
                       <thead class="full-width">
 | 
						||
                           <tr>
 | 
						||
                               <th>记录名</th>
 | 
						||
                               <th>记录类型</th>
 | 
						||
                               <th>线路</th>
 | 
						||
                               <th>记录值</th>
 | 
						||
                           </tr>
 | 
						||
                       </thead>
 | 
						||
 | 
						||
                        <tr v-for="record in node.records">
 | 
						||
                            <td>{{record.name}}</td>
 | 
						||
                            <td>{{record.type}}</td>
 | 
						||
                            <td>
 | 
						||
                                <span v-if="record.route.length > 0">{{record.route}}</span>
 | 
						||
                                <span v-else class="disabled">默认</span>
 | 
						||
                            </td>
 | 
						||
                            <td>{{record.value}}</td>
 | 
						||
                        </tr>
 | 
						||
                    </table>
 | 
						||
                    <p class="comment" v-if="!dnsIsExcludingLnNode">通过设置A记录可以将集群上的服务请求转发到不同线路的节点上。</p>
 | 
						||
                </div>
 | 
						||
                <p class="comment" v-if="dnsIsExcludingLnNode"><span class="red">当前集群DNS已设置不解析Ln节点,所以当前节点不会加入DNS解析;如需加入,请修改"集群设置" -- "DNS设置" -- "更多选项" -- "包含Ln节点"。</span></p>
 | 
						||
            </td>
 | 
						||
        </tr>
 | 
						||
        <tr>
 | 
						||
            <td>所属区域</td>
 | 
						||
            <td>
 | 
						||
                <span v-if="node.region != null" class="ui label small basic">{{node.region.name}}</span>
 | 
						||
                <span v-else class="disabled">没有设置区域。</span>
 | 
						||
            </td>
 | 
						||
        </tr>
 | 
						||
		<tr>
 | 
						||
			<td>所属分组</td>
 | 
						||
			<td>
 | 
						||
				<span v-if="node.group != null" class="ui label small basic">{{node.group.name}}</span>
 | 
						||
				<span v-else class="disabled">没有设置分组。</span>
 | 
						||
			</td>
 | 
						||
		</tr>
 | 
						||
        <tr v-if="teaIsPlus">
 | 
						||
            <td>级别</td>
 | 
						||
            <td>
 | 
						||
                <span :class="{blue: node.levelInfo.code > 1}">{{node.levelInfo.name}}</span>
 | 
						||
                    <span v-if="node.level > 1 && node.lnAddrs != null && node.lnAddrs.length > 0">
 | 
						||
                    <span v-for="lnAddr in node.lnAddrs" class="ui label tiny basic">{{lnAddr}}</span>
 | 
						||
                </span>
 | 
						||
                <p class="comment" v-if="node.level > 1 && node.lnAddrs != null && node.lnAddrs.length > 0">指定了Ln节点访问地址。</p>
 | 
						||
            </td>
 | 
						||
        </tr>
 | 
						||
		<tr>
 | 
						||
			<td colspan="2"><more-options-indicator>更多选项</more-options-indicator></td>
 | 
						||
		</tr>
 | 
						||
		<tbody v-show="moreOptionsVisible">
 | 
						||
			<tr>
 | 
						||
				<td>SSH主机地址</td>
 | 
						||
				<td>
 | 
						||
					<div v-if="node.login != null && node.login.params != null && node.login.params.host != null">
 | 
						||
						<span v-if="node.login.params.host.length > 0">{{node.login.params.host}}</span>
 | 
						||
						<span v-else class="disabled">尚未设置</span>
 | 
						||
					</div>
 | 
						||
					<div v-else class="disabled">
 | 
						||
						尚未设置
 | 
						||
					</div>
 | 
						||
				</td>
 | 
						||
			</tr>
 | 
						||
			<tr>
 | 
						||
				<td>SSH主机端口</td>
 | 
						||
				<td>
 | 
						||
					<div v-if="node.login != null && node.login.params != null && node.login.params.host != null">
 | 
						||
						<span v-if="node.login.params.port > 0">{{node.login.params.port}}</span>
 | 
						||
						<span v-else class="disabled">尚未设置</span>
 | 
						||
					</div>
 | 
						||
					<span v-else class="disabled">
 | 
						||
						尚未设置
 | 
						||
					</span>
 | 
						||
				</td>
 | 
						||
			</tr>
 | 
						||
			<tr>
 | 
						||
				<td>SSH登录认证</td>
 | 
						||
				<td>
 | 
						||
					<div v-if="node.login != null && node.login.grant != null && node.login.grant.id > 0">
 | 
						||
						<a :href="'/clusters/grants/grant?grantId=' + node.login.grant.id">{{node.login.grant.name}}<span class="small grey">({{node.login.grant.methodName}})</span><span class="small grey" v-if="node.login.grant.username.length > 0">({{node.login.grant.username}})</span></a>
 | 
						||
					</div>
 | 
						||
					<span v-else class="disabled">
 | 
						||
						尚未设置
 | 
						||
					</span>
 | 
						||
				</td>
 | 
						||
			</tr>
 | 
						||
			<tr>
 | 
						||
				<td>CPU线程数</td>
 | 
						||
				<td>
 | 
						||
					<span v-if="node.maxCPU > 0">{{node.maxCPU}}线程</span>
 | 
						||
					<span v-else class="disabled">没有限制。</span>
 | 
						||
				</td>
 | 
						||
			</tr>
 | 
						||
            <tr>
 | 
						||
                <td>缓存磁盘容量</td>
 | 
						||
                <td>
 | 
						||
                    <span v-if="node.maxCacheDiskCapacity == null || node.maxCacheDiskCapacity.count <= 0" class="disabled">没有限制</span>
 | 
						||
                   <div v-else>
 | 
						||
                       <size-capacity-view :v-value="node.maxCacheDiskCapacity"></size-capacity-view>
 | 
						||
                   </div>
 | 
						||
                </td>
 | 
						||
            </tr>
 | 
						||
            <tr>
 | 
						||
                <td>缓存内存容量</td>
 | 
						||
                <td>
 | 
						||
                    <span v-if="node.maxCacheMemoryCapacity == null || node.maxCacheMemoryCapacity.count <= 0" class="disabled">没有限制</span>
 | 
						||
                    <div v-else>
 | 
						||
                        <size-capacity-view :v-value="node.maxCacheMemoryCapacity"></size-capacity-view>
 | 
						||
                    </div>
 | 
						||
                </td>
 | 
						||
            </tr>
 | 
						||
		</tbody>
 | 
						||
	</table>
 | 
						||
	<div class="ui divider"></div>
 | 
						||
 | 
						||
	<h3>运行状态</h3>
 | 
						||
	<table class="ui table definition selectable">
 | 
						||
		<tr>
 | 
						||
			<td class="title">是否在运行</td>
 | 
						||
			<td>
 | 
						||
				<div  v-if="node.status.isActive">
 | 
						||
					<span class="green">运行中</span>  
 | 
						||
					<a href="" @click.prevent="stopNode()" v-if="!isStopping"><span>[通过SSH停止]</span></a>
 | 
						||
					<span v-if="isStopping">[停止中...]</span>
 | 
						||
				</div>
 | 
						||
				<div v-else>
 | 
						||
					<span class="red">已断开</span>  
 | 
						||
					<a href="" @click.prevent="startNode()" v-if="node.isInstalled && !isStarting"><span>[通过SSH启动]</span></a>
 | 
						||
					<span v-if="node.isInstalled && isStarting">[启动中...]</span>
 | 
						||
					<a v-if="!node.isInstalled" :href="'/clusters/cluster/node/install?clusterId=' + clusterId + '&nodeId=' + node.id" ><span>去安装></span></a>
 | 
						||
				</div>
 | 
						||
			</td>
 | 
						||
		</tr>
 | 
						||
 | 
						||
		<tbody v-show="node.status.isActive">
 | 
						||
			<tr>
 | 
						||
				<td>CPU用量</td>
 | 
						||
				<td>{{node.status.cpuUsageText}}   <span v-if="node.status.cpuPhysicalCount > 0" class="small grey">({{node.status.cpuPhysicalCount}}核心/{{node.status.cpuLogicalCount}}线程)</span></td>
 | 
						||
			</tr>
 | 
						||
			<tr>
 | 
						||
				<td>内存用量</td>
 | 
						||
				<td>{{node.status.memUsageText}}</td>
 | 
						||
			</tr>
 | 
						||
			<tr>
 | 
						||
				<td>连接数</td>
 | 
						||
				<td>{{node.status.connectionCount}}</td>
 | 
						||
			</tr>
 | 
						||
            <tr>
 | 
						||
                <td>负载</td>
 | 
						||
                <td>{{node.status.load1m}}   {{node.status.load5m}}   {{node.status.load15m}}   <tip-icon content="三个数字分别代表1分钟、5分钟、15分钟平均负载"></tip-icon></td>
 | 
						||
            </tr>
 | 
						||
            <tr>
 | 
						||
                <td>缓存用量</td>
 | 
						||
                <td>
 | 
						||
                    磁盘:{{node.status.cacheTotalDiskSize}}    内存:{{node.status.cacheTotalMemorySize}}
 | 
						||
                </td>
 | 
						||
            </tr>
 | 
						||
        </tbody>
 | 
						||
        <tbody>
 | 
						||
            <tr v-if="node.status.buildVersion != null && node.status.buildVersion.length > 0">
 | 
						||
                <td>版本</td>
 | 
						||
                <td>v{{node.status.buildVersion}}
 | 
						||
                      <a :href="'/clusters/cluster/upgradeRemote?clusterId=' + clusterId" v-if="shouldUpgrade"><span class="red">发现新版本v{{newVersion}} »</span></a>
 | 
						||
                </td>
 | 
						||
            </tr>
 | 
						||
            <tr v-if="node.status.exePath != null && node.status.exePath.length > 0">
 | 
						||
                <td>主程序位置</td>
 | 
						||
                <td>{{node.status.exePath}}</td>
 | 
						||
            </tr>
 | 
						||
            <tr v-if="nodeDatetime.length > 0">
 | 
						||
                <td>上次更新时间</td>
 | 
						||
                <td>
 | 
						||
                    {{nodeDatetime}}
 | 
						||
                    <p class="comment" v-if="nodeTimeDiff > 3"><span class="red">当前节点时间与API节点时间相差 {{nodeTimeDiff}} 秒,请同步节点时间。</span></p>
 | 
						||
                </td>
 | 
						||
            </tr>
 | 
						||
		</tbody>
 | 
						||
	</table>
 | 
						||
	<p class="comment" v-if="node.status.isActive">每隔30秒钟更新一次运行状态。</p>
 | 
						||
 | 
						||
	<div class="ui divider"></div>
 | 
						||
	<h3>安装信息</h3>
 | 
						||
	<table class="ui table definition selectable">
 | 
						||
		<tr>
 | 
						||
			<td>节点ID<em>(id)</em></td>
 | 
						||
			<td>{{node.uniqueId}}</td>
 | 
						||
		</tr>
 | 
						||
		<tr>
 | 
						||
			<td>密钥<em>(secret)</em></td>
 | 
						||
			<td>{{node.secret}}</td>
 | 
						||
		</tr>
 | 
						||
		<tr>
 | 
						||
			<td class="title">安装目录</td>
 | 
						||
			<td>
 | 
						||
				<div v-if="node.installDir.length == 0">使用集群设置<span v-if="node.cluster != null && node.cluster.installDir.length > 0">({{node.cluster.installDir}})</span></div>
 | 
						||
				<span v-else>{{node.installDir}}</span>
 | 
						||
			</td>
 | 
						||
		</tr>
 | 
						||
		<tr>
 | 
						||
			<td>是否已安装</td>
 | 
						||
			<td>
 | 
						||
				<span v-if="node.isInstalled" class="green">已安装</span>
 | 
						||
				<a v-else :href="'/clusters/cluster/installNode?clusterId=' + clusterId + '&nodeId=' + nodeId" class="underline" title="点击进入安装界面"><span class="red">未安装</span></a>
 | 
						||
			</td>
 | 
						||
		</tr>
 | 
						||
	</table> |