2026-02-13 22:10:03 +08:00
|
|
|
|
<template>
|
|
|
|
|
|
<div class="deployment-overview">
|
|
|
|
|
|
<div class="demo-header">
|
2026-02-14 01:00:26 +08:00
|
|
|
|
<span class="icon">🚀</span>
|
|
|
|
|
|
<span class="title">服务上线全流程</span>
|
|
|
|
|
|
<span class="subtitle">从代码到用户眼中的网页</span>
|
2026-02-13 22:10:03 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<div class="demo-content">
|
2026-02-14 01:00:26 +08:00
|
|
|
|
<div class="service-flow">
|
|
|
|
|
|
<div class="flow-step" :class="{ active: currentStep >= 1 }">
|
|
|
|
|
|
<div class="step-icon">📦</div>
|
|
|
|
|
|
<div class="step-title">Build</div>
|
|
|
|
|
|
<div class="tech-term">源码→可执行文件</div>
|
2026-02-13 22:10:03 +08:00
|
|
|
|
</div>
|
2026-02-14 01:00:26 +08:00
|
|
|
|
<span class="flow-arrow">→</span>
|
|
|
|
|
|
<div class="flow-step" :class="{ active: currentStep >= 2 }">
|
|
|
|
|
|
<div class="step-icon">🖥️</div>
|
|
|
|
|
|
<div class="step-title">Server</div>
|
|
|
|
|
|
<div class="tech-term">24h运行的电脑</div>
|
2026-02-13 22:10:03 +08:00
|
|
|
|
</div>
|
2026-02-14 01:00:26 +08:00
|
|
|
|
<span class="flow-arrow">→</span>
|
|
|
|
|
|
<div class="flow-step" :class="{ active: currentStep >= 3 }">
|
|
|
|
|
|
<div class="step-icon">�</div>
|
|
|
|
|
|
<div class="step-title">Deploy</div>
|
|
|
|
|
|
<div class="tech-term">代码放到服务器</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<span class="flow-arrow">→</span>
|
|
|
|
|
|
<div class="flow-step" :class="{ active: currentStep >= 4 }">
|
|
|
|
|
|
<div class="step-icon">🔀</div>
|
|
|
|
|
|
<div class="step-title">Nginx</div>
|
|
|
|
|
|
<div class="tech-term">接收请求分发响应</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<span class="flow-arrow">→</span>
|
|
|
|
|
|
<div class="flow-step" :class="{ active: currentStep >= 5 }">
|
|
|
|
|
|
<div class="step-icon">�</div>
|
|
|
|
|
|
<div class="step-title">DNS</div>
|
|
|
|
|
|
<div class="tech-term">域名→IP地址</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<span class="flow-arrow">→</span>
|
|
|
|
|
|
<div class="flow-step" :class="{ active: currentStep >= 6 }">
|
|
|
|
|
|
<div class="step-icon">�</div>
|
|
|
|
|
|
<div class="step-title">HTTPS</div>
|
|
|
|
|
|
<div class="tech-term">加密数据传输</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<span class="flow-arrow">→</span>
|
|
|
|
|
|
<div class="flow-step" :class="{ active: currentStep >= 7 }">
|
|
|
|
|
|
<div class="step-icon">⚡</div>
|
|
|
|
|
|
<div class="step-title">CDN</div>
|
|
|
|
|
|
<div class="tech-term">就近访问加速</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<span class="flow-arrow">→</span>
|
|
|
|
|
|
<div class="flow-step" :class="{ active: currentStep >= 8 }">
|
|
|
|
|
|
<div class="step-icon">🔄</div>
|
|
|
|
|
|
<div class="step-title">CI/CD</div>
|
|
|
|
|
|
<div class="tech-term">自动化部署流程</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<span class="flow-arrow">→</span>
|
|
|
|
|
|
<div class="flow-step" :class="{ active: currentStep >= 9 }">
|
|
|
|
|
|
<div class="step-icon">�</div>
|
|
|
|
|
|
<div class="step-title">Monitor</div>
|
|
|
|
|
|
<div class="tech-term">监控运行状态</div>
|
2026-02-13 22:10:03 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
2026-02-14 01:00:26 +08:00
|
|
|
|
<div class="info-box">
|
|
|
|
|
|
<span class="icon">💡</span>
|
|
|
|
|
|
<strong>核心原则</strong>:小步快跑 → 先上线MVP → 逐步完善
|
|
|
|
|
|
</div>
|
2026-02-13 22:10:03 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
2026-02-14 01:00:26 +08:00
|
|
|
|
<script setup>
|
|
|
|
|
|
import { ref } from 'vue'
|
|
|
|
|
|
|
|
|
|
|
|
const currentStep = ref(0)
|
|
|
|
|
|
</script>
|
|
|
|
|
|
|
2026-02-13 22:10:03 +08:00
|
|
|
|
<style scoped>
|
|
|
|
|
|
.deployment-overview {
|
|
|
|
|
|
border: 1px solid var(--vp-c-divider);
|
|
|
|
|
|
border-radius: 8px;
|
2026-02-14 01:00:26 +08:00
|
|
|
|
background: var(--vp-c-bg-soft);
|
|
|
|
|
|
padding: 0.75rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
margin: 1rem 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.demo-header {
|
2026-02-14 01:00:26 +08:00
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
gap: 0.5rem;
|
|
|
|
|
|
margin-bottom: 0.5rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 01:00:26 +08:00
|
|
|
|
.demo-header .icon {
|
|
|
|
|
|
font-size: 1.25rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 01:00:26 +08:00
|
|
|
|
.demo-header .title {
|
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
|
font-size: 1rem;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.demo-header .subtitle {
|
2026-02-13 22:10:03 +08:00
|
|
|
|
color: var(--vp-c-text-2);
|
2026-02-14 01:00:26 +08:00
|
|
|
|
font-size: 0.85rem;
|
|
|
|
|
|
margin-left: 0.5rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.intro-text {
|
2026-02-14 01:00:26 +08:00
|
|
|
|
font-size: 0.85rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
color: var(--vp-c-text-2);
|
2026-02-14 01:00:26 +08:00
|
|
|
|
line-height: 1.5;
|
|
|
|
|
|
margin-bottom: 0.75rem;
|
|
|
|
|
|
padding: 0.5rem;
|
|
|
|
|
|
background: var(--vp-c-bg);
|
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.intro-text strong {
|
|
|
|
|
|
color: var(--vp-c-brand-1);
|
|
|
|
|
|
font-weight: 500;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.demo-content {
|
2026-02-14 01:00:26 +08:00
|
|
|
|
margin-bottom: 0.5rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 01:00:26 +08:00
|
|
|
|
.service-flow {
|
2026-02-13 22:10:03 +08:00
|
|
|
|
display: flex;
|
2026-02-14 01:00:26 +08:00
|
|
|
|
flex-direction: row;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
align-items: center;
|
2026-02-14 01:00:26 +08:00
|
|
|
|
gap: 0.25rem;
|
|
|
|
|
|
overflow-x: auto;
|
|
|
|
|
|
padding-bottom: 0.5rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 01:00:26 +08:00
|
|
|
|
.flow-step {
|
2026-02-13 22:10:03 +08:00
|
|
|
|
display: flex;
|
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
|
align-items: center;
|
2026-02-14 01:00:26 +08:00
|
|
|
|
gap: 0.25rem;
|
|
|
|
|
|
padding: 0.5rem;
|
|
|
|
|
|
background: var(--vp-c-bg);
|
|
|
|
|
|
border: 2px solid var(--vp-c-divider);
|
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
|
transition: all 0.2s ease;
|
|
|
|
|
|
flex-shrink: 0;
|
|
|
|
|
|
min-width: 85px;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 01:00:26 +08:00
|
|
|
|
.flow-step:hover {
|
|
|
|
|
|
border-color: var(--vp-c-brand);
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 01:00:26 +08:00
|
|
|
|
.flow-step.active {
|
2026-02-13 22:10:03 +08:00
|
|
|
|
border-color: var(--vp-c-brand);
|
|
|
|
|
|
background: var(--vp-c-brand-soft);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.step-icon {
|
2026-02-14 01:00:26 +08:00
|
|
|
|
font-size: 1rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.step-title {
|
|
|
|
|
|
font-weight: 600;
|
2026-02-14 01:00:26 +08:00
|
|
|
|
font-size: 0.75rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
color: var(--vp-c-text-1);
|
2026-02-14 01:00:26 +08:00
|
|
|
|
text-align: center;
|
|
|
|
|
|
white-space: nowrap;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 01:00:26 +08:00
|
|
|
|
.tech-term {
|
|
|
|
|
|
font-size: 0.6rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
color: var(--vp-c-text-2);
|
2026-02-14 01:00:26 +08:00
|
|
|
|
text-align: center;
|
|
|
|
|
|
white-space: normal;
|
|
|
|
|
|
line-height: 1.2;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 01:00:26 +08:00
|
|
|
|
.flow-arrow {
|
|
|
|
|
|
font-size: 1rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
color: var(--vp-c-text-3);
|
2026-02-14 01:00:26 +08:00
|
|
|
|
flex-shrink: 0;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 01:00:26 +08:00
|
|
|
|
.info-box {
|
|
|
|
|
|
background: var(--vp-c-bg-alt);
|
|
|
|
|
|
padding: 0.5rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
border-radius: 6px;
|
|
|
|
|
|
font-size: 0.8rem;
|
|
|
|
|
|
color: var(--vp-c-text-2);
|
2026-02-14 01:00:26 +08:00
|
|
|
|
margin-top: 0.5rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-14 01:00:26 +08:00
|
|
|
|
.info-box .icon {
|
|
|
|
|
|
margin-right: 0.25rem;
|
2026-02-13 22:10:03 +08:00
|
|
|
|
}
|
|
|
|
|
|
</style>
|