mirror of https://github.com/jkjoy/sunpeiwen.git
764 lines
27 KiB
HTML
764 lines
27 KiB
HTML
|
|
|
|
<!DOCTYPE html>
|
|
<html lang="zh-CN" data-default-color-scheme=auto>
|
|
|
|
|
|
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<link rel="apple-touch-icon" sizes="76x76" href="/img/logo.png">
|
|
<link rel="icon" href="/img/logo.png">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=5.0, shrink-to-fit=no">
|
|
<meta http-equiv="x-ua-compatible" content="ie=edge">
|
|
|
|
<meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests">
|
|
|
|
<meta name="theme-color" content="#2f4154">
|
|
<meta name="author" content="浪子">
|
|
<meta name="keywords" content="DIY,黑苹果,分享,自由">
|
|
|
|
<meta name="description" content="如何使用Docker快速部署mastodon实例直接使用docker compose部署是不可行的,需要按照步骤进行 创建目录1mkdir -p /home/mastodon/mastodon 进入目录1cd /home/mastodon/mastodon 拉取镜像1docker pull ghcr.io/mastodon/mastodon 修改docker compose配置文件1wget ht">
|
|
<meta property="og:type" content="article">
|
|
<meta property="og:title" content="使用Docker快速部署mastodon实例">
|
|
<meta property="og:url" content="https://blog.jkjoy.cn/posts/ebf565b6.html">
|
|
<meta property="og:site_name" content="提剑追梦">
|
|
<meta property="og:description" content="如何使用Docker快速部署mastodon实例直接使用docker compose部署是不可行的,需要按照步骤进行 创建目录1mkdir -p /home/mastodon/mastodon 进入目录1cd /home/mastodon/mastodon 拉取镜像1docker pull ghcr.io/mastodon/mastodon 修改docker compose配置文件1wget ht">
|
|
<meta property="og:locale" content="zh_CN">
|
|
<meta property="article:published_time" content="2023-10-30T11:12:43.000Z">
|
|
<meta property="article:modified_time" content="2024-05-08T12:00:38.225Z">
|
|
<meta property="article:author" content="浪子">
|
|
<meta property="article:tag" content="mastodon">
|
|
<meta name="twitter:card" content="summary_large_image">
|
|
|
|
|
|
<meta name="referrer" content="no-referrer-when-downgrade">
|
|
|
|
|
|
<title>使用Docker快速部署mastodon实例 - 提剑追梦</title>
|
|
|
|
<link rel="stylesheet" href="https://lib.baomitu.com/twitter-bootstrap/4.6.1/css/bootstrap.min.css" />
|
|
|
|
|
|
|
|
<link rel="stylesheet" href="https://lib.baomitu.com/github-markdown-css/4.0.0/github-markdown.min.css" />
|
|
|
|
<link rel="stylesheet" href="https://lib.baomitu.com/hint.css/2.7.0/hint.min.css" />
|
|
|
|
<link rel="stylesheet" href="https://lib.baomitu.com/fancybox/3.5.7/jquery.fancybox.min.css" />
|
|
|
|
|
|
|
|
<!-- 主题依赖的图标库,不要自行修改 -->
|
|
<!-- Do not modify the link that theme dependent icons -->
|
|
|
|
<link rel="stylesheet" href="//at.alicdn.com/t/font_1749284_hj8rtnfg7um.css">
|
|
|
|
|
|
|
|
<link rel="stylesheet" href="//at.alicdn.com/t/c/font_4267870_i7km8ozxnbr.css">
|
|
|
|
|
|
<link rel="stylesheet" href="/css/main.css" />
|
|
|
|
|
|
<link id="highlight-css" rel="stylesheet" href="/css/highlight.css" />
|
|
|
|
<link id="highlight-css-dark" rel="stylesheet" href="/css/highlight-dark.css" />
|
|
|
|
|
|
|
|
|
|
|
|
<link rel="stylesheet" href="/css/mac.css">
|
|
|
|
|
|
|
|
<script id="fluid-configs">
|
|
var Fluid = window.Fluid || {};
|
|
Fluid.ctx = Object.assign({}, Fluid.ctx)
|
|
var CONFIG = {"hostname":"blog.jkjoy.cn","root":"/","version":"1.9.7","typing":{"enable":true,"typeSpeed":70,"cursorChar":"💡","loop":false,"scope":[]},"anchorjs":{"enable":true,"element":"h1,h2,h3,h4,h5,h6","placement":"left","visible":"hover","icon":" # "},"progressbar":{"enable":true,"height_px":3,"color":"#29d","options":{"showSpinner":false,"trickleSpeed":100}},"code_language":{"enable":true,"default":"TEXT"},"copy_btn":true,"image_caption":{"enable":true},"image_zoom":{"enable":true,"img_url_replace":["",""]},"toc":{"enable":true,"placement":"right","headingSelector":"h1,h2,h3,h4,h5,h6","collapseDepth":0},"lazyload":{"enable":true,"loading_img":"/img/loading.gif","onlypost":false,"offset_factor":2},"web_analytics":{"enable":false,"follow_dnt":false,"baidu":"9a59c9b2baa8e43c367f559cd7d9b86c","google":{"measurement_id":"G-EL6EBC27ES"},"tencent":{"sid":null,"cid":null},"woyaola":null,"cnzz":null,"leancloud":{"app_id":"qkYaRmrTvy9Og9bRIt4YTIiC-MdYXbMMI","app_key":"BnyRqKMFP7xp6xF0OTU7rC40","server_url":null,"path":"window.location.pathname","ignore_local":false}},"search_path":"/local-search.xml","include_content_in_search":true};
|
|
|
|
if (CONFIG.web_analytics.follow_dnt) {
|
|
var dntVal = navigator.doNotTrack || window.doNotTrack || navigator.msDoNotTrack;
|
|
Fluid.ctx.dnt = dntVal && (dntVal.startsWith('1') || dntVal.startsWith('yes') || dntVal.startsWith('on'));
|
|
}
|
|
</script>
|
|
<script src="/js/utils.js" ></script>
|
|
<script src="/js/color-schema.js" ></script>
|
|
|
|
|
|
|
|
|
|
<meta name="generator" content="Hexo 6.3.0"><link rel="alternate" href="/atom.xml" title="提剑追梦" type="application/atom+xml">
|
|
</head>
|
|
|
|
|
|
<body>
|
|
|
|
|
|
<header>
|
|
|
|
|
|
<div class="header-inner" style="height: 70vh;">
|
|
<nav id="navbar" class="navbar fixed-top navbar-expand-lg navbar-dark scrolling-navbar">
|
|
<div class="container">
|
|
<a class="navbar-brand" href="/">
|
|
<strong>提剑追梦</strong>
|
|
</a>
|
|
|
|
<button id="navbar-toggler-btn" class="navbar-toggler" type="button" data-toggle="collapse"
|
|
data-target="#navbarSupportedContent"
|
|
aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
|
|
<div class="animated-icon"><span></span><span></span><span></span></div>
|
|
</button>
|
|
|
|
<!-- Collapsible content -->
|
|
<div class="collapse navbar-collapse" id="navbarSupportedContent">
|
|
<ul class="navbar-nav ml-auto text-center">
|
|
|
|
|
|
|
|
|
|
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="/" target="_self">
|
|
<i class="iconfont icon-home"></i>
|
|
<span>首页</span>
|
|
</a>
|
|
</li>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="/archives/" target="_self">
|
|
<i class="iconfont icon-archive"></i>
|
|
<span>归档</span>
|
|
</a>
|
|
</li>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="/categories/" target="_self">
|
|
<i class="iconfont icon-categories"></i>
|
|
<span>分类</span>
|
|
</a>
|
|
</li>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="/tags/" target="_self">
|
|
<i class="iconfont icon-tags"></i>
|
|
<span>标签</span>
|
|
</a>
|
|
</li>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="/links/" target="_self">
|
|
<i class="iconfont icon-link1"></i>
|
|
<span>友链</span>
|
|
</a>
|
|
</li>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="/fcircle/" target="_self">
|
|
<i class="iconfont icon-friend"></i>
|
|
<span>圈子</span>
|
|
</a>
|
|
</li>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="/memos/" target="_self">
|
|
<i class="iconfont icon-Chat"></i>
|
|
<span>说说</span>
|
|
</a>
|
|
</li>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="/about/" target="_self">
|
|
<i class="iconfont icon-aboutme"></i>
|
|
<span>关于</span>
|
|
</a>
|
|
</li>
|
|
|
|
|
|
|
|
<li class="nav-item" id="search-btn">
|
|
<a class="nav-link" target="_self" href="javascript:;" data-toggle="modal" data-target="#modalSearch" aria-label="Search">
|
|
<i class="iconfont icon-search"></i>
|
|
</a>
|
|
</li>
|
|
|
|
|
|
|
|
<li class="nav-item" id="color-toggle-btn">
|
|
<a class="nav-link" target="_self" href="javascript:;" aria-label="Color Toggle">
|
|
<i class="iconfont icon-dark" id="color-toggle-icon"></i>
|
|
</a>
|
|
</li>
|
|
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</nav>
|
|
|
|
|
|
|
|
<div id="banner" class="banner" parallax=true
|
|
style="background: url('/img/default.png') no-repeat center center; background-size: cover;">
|
|
<div class="full-bg-img">
|
|
<div class="mask flex-center" style="background-color: rgba(0, 0, 0, 0.3)">
|
|
<div class="banner-text text-center fade-in-up">
|
|
<div class="h2">
|
|
|
|
<span id="subtitle" data-typed-text="使用Docker快速部署mastodon实例"></span>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mt-3">
|
|
|
|
|
|
<span class="post-meta">
|
|
<i class="iconfont icon-date-fill" aria-hidden="true"></i>
|
|
<time datetime="2023-10-30 11:12" pubdate>
|
|
2023年10月30日 上午
|
|
</time>
|
|
</span>
|
|
|
|
</div>
|
|
|
|
<div class="mt-1">
|
|
|
|
<span class="post-meta mr-2">
|
|
<i class="iconfont icon-chart"></i>
|
|
|
|
244 字
|
|
|
|
</span>
|
|
|
|
|
|
|
|
<span class="post-meta mr-2">
|
|
<i class="iconfont icon-clock-fill"></i>
|
|
|
|
|
|
|
|
3 分钟
|
|
|
|
</span>
|
|
|
|
|
|
|
|
|
|
|
|
<span id="busuanzi_container_page_pv" style="display: none">
|
|
<i class="iconfont icon-eye" aria-hidden="true"></i>
|
|
<span id="busuanzi_value_page_pv"></span> 次
|
|
</span>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="scroll-down-bar">
|
|
<i class="iconfont icon-arrowdown"></i>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</header>
|
|
|
|
<main>
|
|
|
|
|
|
|
|
<div class="container-fluid nopadding-x">
|
|
<div class="row nomargin-x">
|
|
<div class="side-col d-none d-lg-block col-lg-2">
|
|
|
|
|
|
</div>
|
|
|
|
<div class="col-lg-8 nopadding-x-md">
|
|
<div class="container nopadding-x-md" id="board-ctn">
|
|
<div id="board">
|
|
<article class="post-content mx-auto">
|
|
<h1 id="seo-header">使用Docker快速部署mastodon实例</h1>
|
|
|
|
<p id="updated-time" class="note note-info" style="">
|
|
|
|
|
|
本文最后更新于 2024年5月8日 中午
|
|
|
|
|
|
</p>
|
|
|
|
|
|
<div class="markdown-body">
|
|
|
|
<h2 id="如何使用Docker快速部署mastodon实例"><a href="#如何使用Docker快速部署mastodon实例" class="headerlink" title="如何使用Docker快速部署mastodon实例"></a>如何使用Docker快速部署mastodon实例</h2><p>直接使用docker compose部署是不可行的,需要按照步骤进行</p>
|
|
<h3 id="创建目录"><a href="#创建目录" class="headerlink" title="创建目录"></a>创建目录</h3><figure class="highlight arduino"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><code class="hljs arduino">mkdir -p /home/mastodon/mastodon<br></code></pre></td></tr></table></figure>
|
|
<h3 id="进入目录"><a href="#进入目录" class="headerlink" title="进入目录"></a>进入目录</h3><figure class="highlight awk"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><code class="hljs awk">cd <span class="hljs-regexp">/home/m</span>astodon/mastodon<br></code></pre></td></tr></table></figure>
|
|
<h3 id="拉取镜像"><a href="#拉取镜像" class="headerlink" title="拉取镜像"></a>拉取镜像</h3><figure class="highlight awk"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><code class="hljs awk">docker pull ghcr.io<span class="hljs-regexp">/mastodon/m</span>astodon<br></code></pre></td></tr></table></figure>
|
|
<h3 id="修改docker-compose配置文件"><a href="#修改docker-compose配置文件" class="headerlink" title="修改docker compose配置文件"></a>修改docker compose配置文件</h3><figure class="highlight awk"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><code class="hljs awk">wget https:<span class="hljs-regexp">//</span>raw.githubusercontent.com<span class="hljs-regexp">/mastodon/m</span>astodon<span class="hljs-regexp">/main/</span>docker-compose.yml<br></code></pre></td></tr></table></figure>
|
|
<p>修改<code>docker compose</code>文件中的版本号</p>
|
|
<h3 id="初始化PostgreSQL"><a href="#初始化PostgreSQL" class="headerlink" title="初始化PostgreSQL"></a>初始化PostgreSQL</h3><ul>
|
|
<li>重要!!!!!<figure class="highlight awk"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><code class="hljs awk">docker run --name postgres14 -v <span class="hljs-regexp">/home/m</span>astodon<span class="hljs-regexp">/mastodon/</span>postgres14:<span class="hljs-regexp">/var/</span>lib<span class="hljs-regexp">/postgresql/</span>data -e POSTGRES_PASSWORD=设置数据库管理员密码 --rm -d postgres:<span class="hljs-number">14</span>-alpine<br></code></pre></td></tr></table></figure>
|
|
进入数据库<figure class="highlight applescript"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><code class="hljs applescript">docker exec -<span class="hljs-keyword">it</span> postgres14 psql -U postgres<br></code></pre></td></tr></table></figure>
|
|
创建用户名mastodon的密码<figure class="highlight pgsql"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><code class="hljs pgsql"><span class="hljs-keyword">CREATE</span> <span class="hljs-keyword">USER</span> mastodon <span class="hljs-keyword">WITH</span> <span class="hljs-keyword">PASSWORD</span> <span class="hljs-string">'数据库密码(最好和数据库管理员密码不一样)'</span> <span class="hljs-keyword">CREATEDB</span>;<br></code></pre></td></tr></table></figure>
|
|
停止docker<figure class="highlight arduino"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><code class="hljs arduino">docker stop postgres14<br></code></pre></td></tr></table></figure></li>
|
|
</ul>
|
|
<h3 id="配置Mastodon"><a href="#配置Mastodon" class="headerlink" title="配置Mastodon"></a>配置Mastodon</h3><p>在<code>/home/mastodon/mastodon</code>根文件夹中创建空白<code>.env.production</code>文件</p>
|
|
<figure class="highlight bash"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br></pre></td><td class="code"><pre><code class="hljs bash"><span class="hljs-built_in">cd</span> /home/mastodon/mastodon<br><span class="hljs-built_in">touch</span> .env.production<br></code></pre></td></tr></table></figure>
|
|
<p>运行引导</p>
|
|
<figure class="highlight applescript"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><code class="hljs applescript">docker-compose <span class="hljs-built_in">run</span> <span class="hljs-comment">--rm web bundle exec rake mastodon:setup</span><br></code></pre></td></tr></table></figure>
|
|
<p>按照提示进行操作<br><code>Below is your configuration, save it to an .env.production file outside Docker:</code>之后会出现配置文件的数据,复制下来<br>写入<code>.env.production</code>中</p>
|
|
<p>启动Mastodon</p>
|
|
<figure class="highlight x86asm"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br></pre></td><td class="code"><pre><code class="hljs x86asm">docker-compose <span class="hljs-meta">down</span><br>docker-compose <span class="hljs-meta">up</span> -d<br></code></pre></td></tr></table></figure>
|
|
<p>文件夹赋权</p>
|
|
<figure class="highlight apache"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br></pre></td><td class="code"><pre><code class="hljs apache"><span class="hljs-attribute">chown</span> <span class="hljs-number">991</span>:<span class="hljs-number">991</span> -R ./public<br><span class="hljs-attribute">chown</span> -R <span class="hljs-number">70</span>:<span class="hljs-number">70</span> ./postgres14<br><span class="hljs-attribute">docker</span>-compose down<br><span class="hljs-attribute">docker</span>-compose up -d<br></code></pre></td></tr></table></figure>
|
|
|
|
<p>创建管理员</p>
|
|
<figure class="highlight brainfuck"><table><tr><td class="gutter"><pre><span class="line">1</span><br></pre></td><td class="code"><pre><code class="hljs brainfuck"><span class="hljs-comment">docker exec mastodon</span><span class="hljs-literal">-</span><span class="hljs-comment">web</span><span class="hljs-literal">-</span><span class="hljs-comment">1 tootctl accounts create USERNAME</span> <span class="hljs-literal">--</span><span class="hljs-comment">email EMAIL</span> <span class="hljs-literal">--</span><span class="hljs-comment">confirmed</span> <span class="hljs-literal">--</span><span class="hljs-comment">role Owner</span><br></code></pre></td></tr></table></figure>
|
|
<p>至此完成</p>
|
|
|
|
|
|
</div>
|
|
|
|
<hr/>
|
|
<div>
|
|
<div class="post-metas my-3">
|
|
|
|
<div class="post-meta mr-3 d-flex align-items-center">
|
|
<i class="iconfont icon-category"></i>
|
|
|
|
|
|
<span class="category-chains">
|
|
|
|
|
|
|
|
<span class="category-chain">
|
|
|
|
<a href="/categories/%E5%88%86%E4%BA%AB/" class="category-chain-item">分享</a>
|
|
|
|
|
|
|
|
</span>
|
|
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
|
|
<div class="post-meta">
|
|
<i class="iconfont icon-tags"></i>
|
|
|
|
<a href="/tags/mastodon/" class="print-no-link">#mastodon</a>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<div class="post-prevnext my-3">
|
|
<article class="post-prev col-6">
|
|
|
|
|
|
<a href="/posts/b50cb9c4.html" title="关于网络发展的随笔">
|
|
<i class="iconfont icon-arrowleft"></i>
|
|
<span class="hidden-mobile">关于网络发展的随笔</span>
|
|
<span class="visible-mobile">上一篇</span>
|
|
</a>
|
|
|
|
</article>
|
|
<article class="post-next col-6">
|
|
|
|
|
|
<a href="/posts/d29d6713.html" title="快速部署misskey实例">
|
|
<span class="hidden-mobile">快速部署misskey实例</span>
|
|
<span class="visible-mobile">下一篇</span>
|
|
<i class="iconfont icon-arrowright"></i>
|
|
</a>
|
|
|
|
</article>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<article id="comments" lazyload>
|
|
|
|
<div id="twikoo"></div>
|
|
<script type="text/javascript">
|
|
Fluid.utils.loadComments('#comments', function() {
|
|
Fluid.utils.createScript('https://unpkg.com/twikoo/dist/twikoo.all.min.js', function() {
|
|
var options = Object.assign(
|
|
{"envId":"https://t.jkjoy.cn","region":null,"path":"window.location.pathname"},
|
|
{
|
|
el: '#twikoo',
|
|
path: 'window.location.pathname',
|
|
onCommentLoaded: function() {
|
|
Fluid.utils.listenDOMLoaded(function() {
|
|
var imgSelector = '#twikoo .tk-content img:not(.tk-owo-emotion)';
|
|
Fluid.plugins.imageCaption(imgSelector);
|
|
Fluid.plugins.fancyBox(imgSelector);
|
|
});
|
|
}
|
|
}
|
|
)
|
|
twikoo.init(options)
|
|
});
|
|
});
|
|
</script>
|
|
<noscript>Please enable JavaScript to view the comments</noscript>
|
|
|
|
|
|
</article>
|
|
|
|
|
|
|
|
</article>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="side-col d-none d-lg-block col-lg-2">
|
|
|
|
<aside class="sidebar" style="margin-left: -1rem">
|
|
<div id="toc">
|
|
<p class="toc-header">
|
|
<i class="iconfont icon-list"></i>
|
|
<span>目录</span>
|
|
</p>
|
|
<div class="toc-body" id="toc-body"></div>
|
|
</div>
|
|
|
|
|
|
|
|
</aside>
|
|
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<a id="scroll-top-button" aria-label="TOP" href="#" role="button">
|
|
<i class="iconfont icon-arrowup" aria-hidden="true"></i>
|
|
</a>
|
|
|
|
|
|
|
|
<div class="modal fade" id="modalSearch" tabindex="-1" role="dialog" aria-labelledby="ModalLabel"
|
|
aria-hidden="true">
|
|
<div class="modal-dialog modal-dialog-scrollable modal-lg" role="document">
|
|
<div class="modal-content">
|
|
<div class="modal-header text-center">
|
|
<h4 class="modal-title w-100 font-weight-bold">搜索</h4>
|
|
<button type="button" id="local-search-close" class="close" data-dismiss="modal" aria-label="Close">
|
|
<span aria-hidden="true">×</span>
|
|
</button>
|
|
</div>
|
|
<div class="modal-body mx-3">
|
|
<div class="md-form mb-5">
|
|
<input type="text" id="local-search-input" class="form-control validate">
|
|
<label data-error="x" data-success="v" for="local-search-input">关键词</label>
|
|
</div>
|
|
<div class="list-group" id="local-search-result"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
|
|
|
|
|
|
</main>
|
|
|
|
<footer>
|
|
<div class="footer-inner">
|
|
|
|
<div class="footer-content">
|
|
<link rel="stylesheet" href="https://cdnjs.sgcd.net/lxgw-wenkai-screen-webfont/lxgwwenkaigbscreen.css" /> <style> body { font-family: "LXGW WenKai Screen", sans-serif; } </style> <a href="https://hexo.io" target="_blank" rel="nofollow noopener"><span>Hexo</span></a> <i class="iconfont icon-love"></i> <a href="https://github.com/fluid-dev/hexo-theme-fluid" target="_blank" rel="nofollow noopener"><span>Fluid</span></a> <br> PowerBy 浪子 ©2024
|
|
|
|
</div>
|
|
|
|
|
|
<div class="statistics">
|
|
|
|
|
|
|
|
|
|
|
|
<span id="busuanzi_container_site_pv" style="display: none">
|
|
总访问量
|
|
<span id="busuanzi_value_site_pv"></span>
|
|
次
|
|
</span>
|
|
|
|
|
|
<span id="busuanzi_container_site_uv" style="display: none">
|
|
总访客数
|
|
<span id="busuanzi_value_site_uv"></span>
|
|
人
|
|
</span>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<!-- 备案信息 ICP for China -->
|
|
<div class="beian">
|
|
<span>
|
|
<a href="http://beian.miit.gov.cn/" target="_blank" rel="nofollow noopener">
|
|
鄂ICP备16022970号-16
|
|
</a>
|
|
</span>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</footer>
|
|
|
|
<!-- Scripts -->
|
|
|
|
<script src="https://lib.baomitu.com/nprogress/0.2.0/nprogress.min.js" ></script>
|
|
<link rel="stylesheet" href="https://lib.baomitu.com/nprogress/0.2.0/nprogress.min.css" />
|
|
|
|
<script>
|
|
NProgress.configure({"showSpinner":false,"trickleSpeed":100})
|
|
NProgress.start()
|
|
window.addEventListener('load', function() {
|
|
NProgress.done();
|
|
})
|
|
</script>
|
|
|
|
|
|
<script src="https://lib.baomitu.com/jquery/3.6.4/jquery.min.js" ></script>
|
|
<script src="https://lib.baomitu.com/twitter-bootstrap/4.6.1/js/bootstrap.min.js" ></script>
|
|
<script src="/js/events.js" ></script>
|
|
<script src="/js/plugins.js" ></script>
|
|
|
|
|
|
<script src="https://lib.baomitu.com/typed.js/2.0.12/typed.min.js" ></script>
|
|
<script>
|
|
(function (window, document) {
|
|
var typing = Fluid.plugins.typing;
|
|
var subtitle = document.getElementById('subtitle');
|
|
if (!subtitle || !typing) {
|
|
return;
|
|
}
|
|
var text = subtitle.getAttribute('data-typed-text');
|
|
|
|
typing(text);
|
|
|
|
})(window, document);
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<script src="/js/img-lazyload.js" ></script>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
|
Fluid.utils.createScript('https://lib.baomitu.com/tocbot/4.20.1/tocbot.min.js', function() {
|
|
var toc = jQuery('#toc');
|
|
if (toc.length === 0 || !window.tocbot) { return; }
|
|
var boardCtn = jQuery('#board-ctn');
|
|
var boardTop = boardCtn.offset().top;
|
|
|
|
window.tocbot.init(Object.assign({
|
|
tocSelector : '#toc-body',
|
|
contentSelector : '.markdown-body',
|
|
linkClass : 'tocbot-link',
|
|
activeLinkClass : 'tocbot-active-link',
|
|
listClass : 'tocbot-list',
|
|
isCollapsedClass: 'tocbot-is-collapsed',
|
|
collapsibleClass: 'tocbot-is-collapsible',
|
|
scrollSmooth : true,
|
|
includeTitleTags: true,
|
|
headingsOffset : -boardTop,
|
|
}, CONFIG.toc));
|
|
if (toc.find('.toc-list-item').length > 0) {
|
|
toc.css('visibility', 'visible');
|
|
}
|
|
|
|
Fluid.events.registerRefreshCallback(function() {
|
|
if ('tocbot' in window) {
|
|
tocbot.refresh();
|
|
var toc = jQuery('#toc');
|
|
if (toc.length === 0 || !tocbot) {
|
|
return;
|
|
}
|
|
if (toc.find('.toc-list-item').length > 0) {
|
|
toc.css('visibility', 'visible');
|
|
}
|
|
}
|
|
});
|
|
});
|
|
</script>
|
|
|
|
|
|
<script src=https://lib.baomitu.com/clipboard.js/2.0.11/clipboard.min.js></script>
|
|
|
|
<script>Fluid.plugins.codeWidget();</script>
|
|
|
|
|
|
|
|
<script>
|
|
Fluid.utils.createScript('https://lib.baomitu.com/anchor-js/4.3.1/anchor.min.js', function() {
|
|
window.anchors.options = {
|
|
placement: CONFIG.anchorjs.placement,
|
|
visible : CONFIG.anchorjs.visible
|
|
};
|
|
if (CONFIG.anchorjs.icon) {
|
|
window.anchors.options.icon = CONFIG.anchorjs.icon;
|
|
}
|
|
var el = (CONFIG.anchorjs.element || 'h1,h2,h3,h4,h5,h6').split(',');
|
|
var res = [];
|
|
for (var item of el) {
|
|
res.push('.markdown-body > ' + item.trim());
|
|
}
|
|
if (CONFIG.anchorjs.placement === 'left') {
|
|
window.anchors.options.class = 'anchorjs-link-left';
|
|
}
|
|
window.anchors.add(res.join(', '));
|
|
|
|
Fluid.events.registerRefreshCallback(function() {
|
|
if ('anchors' in window) {
|
|
anchors.removeAll();
|
|
var el = (CONFIG.anchorjs.element || 'h1,h2,h3,h4,h5,h6').split(',');
|
|
var res = [];
|
|
for (var item of el) {
|
|
res.push('.markdown-body > ' + item.trim());
|
|
}
|
|
if (CONFIG.anchorjs.placement === 'left') {
|
|
anchors.options.class = 'anchorjs-link-left';
|
|
}
|
|
anchors.add(res.join(', '));
|
|
}
|
|
});
|
|
});
|
|
</script>
|
|
|
|
|
|
|
|
<script>
|
|
Fluid.utils.createScript('https://lib.baomitu.com/fancybox/3.5.7/jquery.fancybox.min.js', function() {
|
|
Fluid.plugins.fancyBox();
|
|
});
|
|
</script>
|
|
|
|
|
|
<script>Fluid.plugins.imageCaption();</script>
|
|
|
|
<script src="/js/local-search.js" ></script>
|
|
|
|
<script defer src="https://busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js" ></script>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 主题的启动项,将它保持在最底部 -->
|
|
<!-- the boot of the theme, keep it at the bottom -->
|
|
<script src="/js/boot.js" ></script>
|
|
|
|
|
|
|
|
|
|
<noscript>
|
|
<div class="noscript-warning">博客在允许 JavaScript 运行的环境下浏览效果更佳</div>
|
|
</noscript>
|
|
</body>
|
|
</html>
|