<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
xmlns:content="http://purl.org/rss/1.0/modules/content/"
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
xmlns:atom="http://www.w3.org/2005/Atom"
xmlns:wfw="http://wellformedweb.org/CommentAPI/">
<channel>
<title>无名的小宇宙 - Linux</title>
<link>https://blog.662662.xyz/category/Linux/</link>
<atom:link href="https://blog.662662.xyz/feed/category/Linux/" rel="self" type="application/rss+xml" />
<language>zh-CN</language>
<description>Linux</description>
<lastBuildDate>Sat, 11 Apr 2026 13:31:00 +0000</lastBuildDate>
<pubDate>Sat, 11 Apr 2026 13:31:00 +0000</pubDate>
<item>
<title>Linux一键检测服务器三网回程路由｜粤沪京全覆盖，AS 号精准识别线路品质</title>
<link>https://blog.662662.xyz/archives/45/</link>
<guid>https://blog.662662.xyz/archives/45/</guid>
<pubDate>Sat, 11 Apr 2026 13:31:00 +0000</pubDate>
<dc:creator>无名</dc:creator>
<description><![CDATA[Linux一键检测服务器三网回程路由｜粤沪京全覆盖，AS号精准识别线路品质在选购海外VPS、服务器时，回国回程路由直接决定了国内访问速度、延迟和稳定性。电信CN2、联通9929、移动CMIN2等...]]></description>
<content:encoded xml:lang="zh-CN"><![CDATA[
<h1>Linux一键检测服务器三网回程路由｜粤沪京全覆盖，AS号精准识别线路品质</h1><p>在选购海外VPS、服务器时，<strong>回国回程路由</strong>直接决定了国内访问速度、延迟和稳定性。电信CN2、联通9929、移动CMIN2等精品线路，和普通163/CMI线路体验天差地别。</p><p>今天给大家分享一款<strong>全自动Shell脚本</strong>，无需手动配置环境，<strong>一行命令直接运行</strong>，一键检测服务器到广东、上海、北京三大核心城市的电信、联通、移动三网回程路由，通过AS号精准识别线路类型，彩色输出、结果一目了然！</p><hr><h2>脚本核心亮点</h2><p>✅ <strong>全系统兼容</strong>：支持 Debian / Ubuntu / CentOS / Rocky / AlmaLinux 所有主流Linux发行版<br>✅ <strong>自动安装依赖</strong>：一键检测并安装 mtr 路由追踪工具，无需手动操作<br>✅ <strong>粤沪京全覆盖</strong>：覆盖国内三大核心节点，三网9个目标地址全面测试<br>✅ <strong>AS号精准识别</strong>：自动识别精品线路/普通线路/中转隐藏路由<br>✅ <strong>彩色可视化</strong>：绿=优质、黄=普通、红=一般，直观判断线路质量<br>✅ <strong>结果自动汇总</strong>：检测完成自动生成汇总表，方便截图、对比、记录</p><hr><h2>关键AS号线路对照表</h2><table><thead><tr><th>AS号</th><th>线路类型</th><th>等级</th><th>颜色</th></tr></thead><tbody><tr><td>AS4809</td><td>电信CN2 精品回程</td><td>优质</td><td>绿色</td></tr><tr><td>AS9929</td><td>联通9929 精品回程</td><td>优质</td><td>绿色</td></tr><tr><td>AS58807</td><td>移动CMIN2 精品回程</td><td>优质</td><td>绿色</td></tr><tr><td>AS4134</td><td>电信163 普通回程</td><td>常规</td><td>黄色</td></tr><tr><td>AS4837</td><td>联通169 普通回程</td><td>常规</td><td>黄色</td></tr><tr><td>AS58453</td><td>移动CMI 普通回程</td><td>常规</td><td>黄色</td></tr></tbody></table><hr><h2>超简单使用教程</h2><p><strong>全程仅需复制一行命令</strong>，粘贴到服务器终端直接运行，全自动完成所有检测！</p><pre><code class="lang-bash">wget https://git.662662.xyz/linux/check_backhaul.sh &amp;&amp; chmod +x check_backhaul.sh &amp;&amp; ./check_backhaul.sh</code></pre><hr><h2>脚本执行流程</h2><ol><li><strong>自动下载脚本</strong>：无需手动创建文件，一行命令直接拉取最新版脚本</li><li><strong>依赖检查安装</strong>：自动识别系统，安装mtr路由追踪工具</li><li><strong>多节点路由测试</strong>：依次检测粤沪京三网9个核心节点</li><li><strong>AS号智能匹配</strong>：自动识别线路类型并彩色标注</li><li><strong>最终结果汇总</strong>：输出清晰汇总表，快速判断服务器线路质量</li></ol><hr><h2>结果颜色解读</h2><p>🟢 <strong>绿色</strong>：精品线路（CN2/9929/CMIN2）<br>延迟低、速度快、丢包率低，<strong>最推荐</strong></p><p>🟡 <strong>黄色</strong>：普通线路（163/169/CMI）<br>满足日常使用，速度中等，稳定性一般</p><p>🔴 <strong>红色</strong>：中转/路由隐藏<br>线路不稳定，可能绕路、高延迟、不推荐</p><hr><h2>注意事项</h2><ol><li>建议使用 <strong>root 权限</strong> 运行，避免依赖安装失败</li><li>检测结果为<strong>实时回程路由</strong>，受网络波动影响，可多次检测取平均值</li><li>脚本仅支持 IPv4 检测</li><li>脚本轻量化运行，无残留文件，不影响服务器正常使用</li></ol><hr><h2>总结</h2><p>这款回程路由检测脚本是<strong>挑选VPS、测试服务器、排查网络问题</strong>的必备工具，彻底告别复杂操作，<strong>一行命令就能测出服务器真实回国线路</strong>，轻松避开商家虚假宣传，站长、运维、VPS玩家必备！</p><h3>总结</h3><ol><li>全程<strong>仅需一行命令</strong>，无需代码、无需配置，小白也能轻松用</li><li>粤沪京三网全覆盖，AS号精准识别，彩色结果直观易懂</li><li>全Linux系统兼容，自动处理依赖，安全无残留</li></ol>
]]></content:encoded>
<slash:comments>0</slash:comments>
<comments>https://blog.662662.xyz/archives/45/#comments</comments>
<wfw:commentRss>https://blog.662662.xyz/feed/category/Linux/</wfw:commentRss>
</item>
<item>
<title>WebDAV备份脚本</title>
<link>https://blog.662662.xyz/archives/42/</link>
<guid>https://blog.662662.xyz/archives/42/</guid>
<pubDate>Thu, 18 Sep 2025 04:31:27 +0000</pubDate>
<dc:creator>无名</dc:creator>
<description><![CDATA[高效WebDAV备份解决方案：Shell与Python双版本脚本详解📌 方案概述这是一套专为WebDAV服务器设计的备份脚本工具，包含Shell和Python两个版本，支持本地备份创建、WebD...]]></description>
<content:encoded xml:lang="zh-CN"><![CDATA[
<h1>高效WebDAV备份解决方案：Shell与Python双版本脚本详解</h1><h2>📌 方案概述</h2><p>这是一套专为WebDAV服务器设计的备份脚本工具，包含Shell和Python两个版本，支持本地备份创建、WebDAV远程上传、备份文件数量管理、大文件处理及完整性校验等核心功能。无论是个人文件归档还是服务器数据备份，均可通过简单配置实现自动化流程，兼顾稳定性与灵活性。</p><h2>🌟 WebDAV服务推荐</h2><p>若您需要稳定的WebDAV存储服务，优先推荐以下方案：</p><ul><li><strong>InfiniCloud</strong>：注册即享20GB基础存储空间，输入推荐码 <strong><code>QXPSY</code></strong> 可额外获得5GB，总计25GB免费容量，满足中小型备份需求。  <br>🔗 <a href="https://infini-cloud.net/">立即注册</a></li></ul><h2>📋 环境要求与下载方式</h2><h3>一、🐚 Shell版本（适用于Linux/macOS/WSL）</h3><h4>环境依赖</h4><ul><li><strong>操作系统</strong>：支持Bash的环境（Linux全版本、macOS 10.14+、Windows Subsystem for Linux 2+）</li><li><p><strong>工具依赖</strong>：</p><ul><li><code>curl</code>（≥7.19.0，需支持<code>-C -</code>断点续传参数）</li><li><code>tar</code>（使用<code>tar.gz</code>格式时必备，建议<code>tar 1.30+</code>以支持压缩优化）</li><li><code>zip</code>（使用<code>zip</code>格式时必备，<code>zip 3.0+</code>兼容性更佳）</li></ul></li><li><strong>权限要求</strong>：对源目录有<code>读</code>权限、本地备份目录有<code>读写</code>权限、WebDAV服务器有<code>访问+上传+创建目录</code>权限。</li></ul><h4>下载方式</h4><h5>国内环境（Gitee镜像，速度更快，规避网络波动）</h5><pre><code class="lang-bash">wget https://gitee.com/wmwlwmwl/pagoda-happy-edition/raw/master/Linux/WebDAV_Backup/webdav_backup.sh</code></pre><h5>国外环境（GitHub原生地址，适合海外服务器）</h5><pre><code class="lang-bash">wget https://raw.githubusercontent.com/wmwlwmwl/WebDAV_Backup/refs/heads/main/webdav_backup.sh</code></pre><h3>二、🐍 Python版本（适用于跨平台场景）</h3><h4>环境依赖</h4><ul><li><strong>Python版本</strong>：3.6及以上（推荐3.8+，兼容新特性且稳定性更好）</li><li><strong>库依赖</strong>：<code>requests</code>（用于WebDAV通信，需<code>requests 2.25.0+</code>以支持断点续传）</li><li><strong>内置库</strong>：<code>smtplib</code>、<code>email</code>（Python标准库自带，无需额外安装）</li><li><strong>权限要求</strong>：与Shell版本一致，需对应目录读写权限及WebDAV访问权限。</li></ul><h4>下载方式</h4><h5>国内环境（Gitee镜像，速度更快）</h5><pre><code class="lang-bash">wget https://gitee.com/wmwlwmwl/pagoda-happy-edition/raw/master/Linux/WebDAV_Backup/webdav_backup.py</code></pre><h5>国外环境（GitHub原生地址）</h5><pre><code class="lang-bash">wget https://raw.githubusercontent.com/wmwlwmwl/WebDAV_Backup/refs/heads/main/webdav_backup.py</code></pre><h2>⚙️ 核心配置参数详解</h2><p>使用前需在脚本头部修改关键参数，以下为完整配置示例（以Shell版本为例，Python版本参数含义完全一致），<strong>建议按注释逐行核对</strong>：</p><pre><code class="lang-bash"># ==================== 基础备份配置 ====================
SOURCE_DIR=&quot;/path/to/source/directory&quot;          # 要备份的源目录（必填，例：/data/wwwroot）
WEBDAV_BASE_URL=&quot;https://your-webdav-server.com&quot; # WebDAV服务器基础地址（必填，例：https://dav.infini-cloud.net）
WEBDAV_UPLOAD_DIR=&quot;backups/docs&quot;                # WebDAV上的上传目录（相对于基础地址，例：backups/server1）
WEBDAV_USER=&quot;your_username&quot;                     # WebDAV用户名（必填，注册时的账号）
WEBDAV_PASS=&quot;your_password&quot;                     # WebDAV密码（必填，建议后续通过环境变量存储，避免明文）
LOCAL_BACKUP_DIR=&quot;/path/to/local/backups&quot;       # 本地备份保存目录（必填，需足够空间，例：/backup/local）
BACKUP_PREFIX=&quot;backup&quot;                          # 备份文件前缀（自定义，例：server1_backup）
MAX_REMOTE_BACKUPS=5                            # WebDAV保留的最大备份数量（建议3-10，避免占用过多远程空间）
MAX_LOCAL_BACKUPS=3                             # 本地保留的最大备份数量（建议2-5，平衡空间与冗余）
BACKUP_FORMAT=&quot;tar.gz&quot;                          # 备份文件格式（可选：tar.gz（压缩率高）、zip（跨平台））

# ==================== 文件上传参数 ====================
USE_SEPARATE_FILE_PARAMS=true                   # 是否区分大文件和非大文件（true=区分，false=统一用大文件参数）
LARGE_FILE_THRESHOLD=100                        # 大文件定义（MB，仅USE_SEPARATE_FILE_PARAMS=true时生效）
CONNECT_TIMEOUT=30                               # 所有文件的连接超时时间（秒，建议30-60，避免无限等待）

# 非大文件上传参数（文件≤LARGE_FILE_THRESHOLD时生效）
SMALL_FILE_MAX_TIME=1800                         # 最大上传时间（秒，默认30分钟，小文件无需过长）
SMALL_FILE_RATE_LIMIT=&quot;2M&quot;                        # 上传速度限制（格式：数字+单位，例：2M=2MB/s，空字符串&quot;&quot;=无限制）
                                                 # 【注意】Python版本暂不支持上传速度限制，此参数会被忽略

# 大文件上传参数（文件&gt;LARGE_FILE_THRESHOLD时生效）
LARGE_FILE_MAX_TIME=7200                         # 最大上传时间（秒，默认2小时，大文件需预留足够时间）
LARGE_FILE_RATE_LIMIT=&quot;1M&quot;                        # 上传速度限制（建议1-5M/s，避免占用全部带宽）
                                                 # 【注意】Python版本暂不支持上传速度限制，此参数会被忽略

# ==================== 完整性检测参数 ====================
ENABLE_INTEGRITY_CHECK=true                      # 是否启用上传后完整性检测（true=启用，建议开启）
INTEGRITY_CHECK_TIMEOUT=300                      # 完整性检测超时时间（秒，默认5分钟，避免检测耗时过长）
ENABLE_MD5_VERIFICATION=true                     # 是否启用MD5校验和验证（true=启用，进一步确保文件完整）
MD5_VERIFICATION_EXCLUDE_THRESHOLD=100           # 跳过MD5验证的文件大小（MB，例：100=100MB以上文件不校验，避免耗时）

# ==================== 邮箱通知参数（双版本均支持） ====================
ENABLE_EMAIL_NOTIFICATION=false                  # 是否启用邮箱通知（true=启用，建议开启以便及时知晓结果）
ENABLE_EMAIL_SUCCESS_NOTIFICATION=true           # 是否发送成功通知（true=发送，按需关闭）
ENABLE_EMAIL_FAILURE_NOTIFICATION=true           # 是否发送失败通知（true=发送，建议强制开启）
SMTP_SERVER=&quot;smtp.example.com&quot;                   # SMTP服务器地址（例：QQ邮箱=smtp.qq.com，网易=smtp.163.com）
SMTP_PORT=587                                    # SMTP端口（常用：25=无加密，587=TLS，465=SSL，需与SMTP_USE_TLS匹配）
SMTP_USERNAME=&quot;your_email@example.com&quot;           # SMTP用户名（通常是发件人邮箱地址）
SMTP_PASSWORD=&quot;your_email_password&quot;              # SMTP密码（注意：QQ/网易等需用「独立授权码」，而非登录密码）
SMTP_USE_TLS=true                                # 是否使用TLS加密（true=启用，配合587端口；false=不启用，配合25端口）
EMAIL_FROM=&quot;your_email@example.com&quot;              # 发件人邮箱（需与SMTP_USERNAME一致）
EMAIL_FROM_NAME=&quot;WebDAV备份系统&quot;                  # 发件人名称（邮件中显示，例：服务器A备份系统）
EMAIL_TO=&quot;recipient@example.com&quot;                 # 收件人邮箱（多个邮箱用逗号分隔，例：a@xxx.com,b@xxx.com）
EMAIL_SUBJECT_PREFIX=&quot;服务器&quot;                     # 邮件主题前缀（最终主题：[服务器]WebDAV备份结果）</code></pre><h3>参数补充说明（易混淆点）</h3><table><thead><tr><th>易混淆参数</th><th>常见错误示例</th><th>正确配置建议</th></tr></thead><tbody><tr><td><code>WEBDAV_BASE_URL</code></td><td><code>https://dav.example.com/</code></td><td>末尾可带/或不带，脚本会自动兼容，但建议统一格式（如不带/）</td></tr><tr><td><code>SMTP_PASSWORD</code></td><td>用QQ邮箱登录密码</td><td>需用QQ邮箱「独立授权码」（在邮箱设置-账户中开启）</td></tr><tr><td><code>MD5_VERIFICATION_EXCLUDE_THRESHOLD</code></td><td>设为0</td><td>0=所有文件校验，大文件会耗时，建议设为100-200</td></tr></tbody></table><h2>🚀 快速使用指南</h2><h3>一、🐚 Shell版本操作流程</h3><ol><li><p><strong>修改配置</strong>：用<code>vim</code>或<code>nano</code>打开脚本，按上述示例调整头部参数（重点核对<code>SOURCE_DIR</code>、<code>WEBDAV</code>账号、<code>LOCAL_BACKUP_DIR</code>）：</p><pre><code class="lang-bash">vim webdav_backup.sh  # 编辑脚本
# 按「i」进入编辑模式，修改后按「Esc」+输入「:wq」保存退出</code></pre></li><li><p><strong>赋予执行权限</strong>：首次使用需给脚本添加可执行权限，避免「权限不足」错误：</p><pre><code class="lang-bash">chmod +x webdav_backup.sh</code></pre></li><li><p><strong>手动执行测试</strong>：先手动运行一次，验证配置是否正确（若报错，可根据日志排查问题）：</p><pre><code class="lang-bash">./webdav_backup.sh
# 执行后观察输出</code></pre></li><li><p><strong>设置定时任务（自动化备份）</strong>：  <br>若需每天凌晨2点自动备份，可通过以下两种方式添加到<code>crontab</code>（Linux/macOS自带定时任务工具）：</p><ul><li><p>方式1：手动编辑crontab（适合需要调整其他任务的场景）</p><pre><code class="lang-bash"># 1. 打开crontab编辑器
crontab -e
# 2. 在末尾添加以下内容（替换实际路径，日志路径需提前创建）
# 格式说明：分 时 日 月 周 脚本路径 &gt;&gt; 日志路径 2&gt;&amp;1（2&gt;&amp;1=错误日志也写入文件）
0 2 * * * /path/to/webdav_backup.sh &gt;&gt; /var/log/webdav_backup.log 2&gt;&amp;1
# 3. 保存退出：vi编辑器按「Esc」+「:wq」，nano按「Ctrl+O」+「Enter」+「Ctrl+X」</code></pre></li><li><p>方式2：直接命令添加（无需手动编辑，更便捷，适合批量部署）</p><pre><code class="lang-bash"># 替换「/path/to/webdav_backup.sh」和「/path/to/backup.log」为实际路径
(crontab -l 2&gt;/dev/null; echo &quot;0 2 * * * /path/to/webdav_backup.sh &gt;&gt; /path/to/backup.log 2&gt;&amp;1&quot;) | crontab -</code></pre></li></ul></li></ol><h3>二、🐍 Python版本操作流程</h3><ol><li><p><strong>安装依赖库</strong>：首次使用需安装<code>requests</code>库（用于WebDAV通信），若系统有多个Python版本，建议指定<code>pip3</code>：</p><pre><code class="lang-bash"># 通用安装命令
pip install requests
# 若有Python3和Python2共存，用：
pip3 install requests</code></pre></li><li><p><strong>修改配置</strong>：与Shell版本一致，用文本编辑器打开<code>webdav_backup.py</code>，调整头部参数（参数含义完全相同，无需额外适配）：</p><pre><code class="lang-bash">vim webdav_backup.py</code></pre></li><li><p><strong>手动执行测试</strong>：运行脚本并验证配置（若报错，优先检查<code>requests</code>是否安装成功、Python版本是否≥3.6）：</p><pre><code class="lang-bash"># 通用执行命令
python webdav_backup.py
# 若指定Python3，用：
python3 webdav_backup.py</code></pre></li><li><p><strong>设置定时任务</strong>：与Shell版本逻辑一致，仅需修改「执行命令」和「脚本路径」：</p><ul><li><p>方式1：手动编辑crontab</p><pre><code class="lang-bash">crontab -e
# 添加以下内容（替换实际路径）
0 2 * * * python3 /path/to/webdav_backup.py &gt;&gt; /var/log/webdav_backup.log 2&gt;&amp;1</code></pre></li><li><p>方式2：直接命令添加</p><pre><code class="lang-bash"># 替换「/path/to/webdav_backup.py」和「/path/to/backup.log」为实际路径
(crontab -l 2&gt;/dev/null; echo &quot;0 2 * * * python3 /path/to/webdav_backup.py &gt;&gt; /path/to/backup.log 2&gt;&amp;1&quot;) | crontab -</code></pre></li></ul></li></ol><h2>🔧 核心功能解析</h2><h3>1. 智能备份与清理机制</h3><ul><li><strong>时间戳命名</strong>：备份文件自动按「前缀_年月日_时分秒.格式」命名（例：<code>server1_backup_20250917_020000.tar.gz</code>），便于追溯备份时间，避免文件名冲突。</li><li><p><strong>双端自动清理</strong>：</p><ul><li>远程清理：当WebDAV上的备份数量超过<code>MAX_REMOTE_BACKUPS</code>时，自动删除<strong>最早</strong>的备份文件，避免远程空间耗尽。</li><li>本地清理：同理，本地备份数量超过<code>MAX_LOCAL_BACKUPS</code>时，自动删除旧备份，释放本地磁盘空间。</li></ul></li><li><strong>格式灵活选择</strong>：<code>tar.gz</code>压缩率高（节省存储），适合Linux服务器；<code>zip</code>格式跨平台（Windows可直接解压），适合需多系统访问的场景。</li></ul><h3>2. 大文件优化处理（解决上传痛点）</h3><p>针对大文件（如数据库备份、视频文件）上传易超时、易中断的问题，脚本做了三重优化：</p><ol><li><strong>动态参数切换</strong>：根据文件大小自动选择上传参数（大文件用更长超时、更低速率限制，小文件用更短超时、更高速率，兼顾效率与稳定性）。</li><li><strong>断点续传</strong>：基于<code>curl</code>（Shell）和<code>requests</code>（Python）的断点续传能力，若上传中断（如网络波动），再次执行脚本会从<strong>已上传部分</strong>继续，无需重新上传整个文件，大幅节省时间。</li><li><strong>速率可控</strong>：Shell版本支持限制上传速度（如<code>1M/s</code>），避免备份占用全部带宽，影响服务器其他业务（Python版本暂不支持此功能，需后续优化）。</li></ol><h3>3. 完整性保障体系（避免文件损坏）</h3><p>为确保上传后的文件与本地一致，脚本提供「大小校验+MD5校验」双重保障：</p><ol><li><strong>文件大小校验</strong>：上传完成后，自动对比本地文件与远程文件的大小，若不一致（如上传中断导致文件不完整），则标记为「上传失败」，并删除远程损坏文件，避免无效备份。</li><li><strong>MD5校验（可选）</strong>：启用后，脚本会计算本地文件的MD5值，上传后再计算远程文件的MD5值，两者一致则确认文件完整；同时支持跳过超大文件的MD5校验（通过<code>MD5_VERIFICATION_EXCLUDE_THRESHOLD</code>设置），避免耗时过长。</li></ol><h3>4. 精准邮件通知（及时知晓结果）</h3><p>支持按备份结果发送通知，避免无效信息干扰，核心特性：</p><ul><li><strong>开关独立控制</strong>：可分别开启/关闭「成功通知」和「失败通知」（例：仅接收失败通知，减少冗余信息）。</li><li><strong>内容详细完整</strong>：邮件包含「备份时间、源目录、备份文件大小、上传状态、耗时、错误信息（若失败）」，便于快速定位问题（如失败时可通过错误信息排查是WebDAV账号错误还是网络问题）。</li><li><strong>多邮箱支持</strong>：收件人可填写多个邮箱（用逗号分隔），适合团队协作场景（如运维组全员接收备份结果）。</li></ul><h2>🛠️ 常见问题与解决方案（附排查步骤）</h2><h3>问题1：大文件上传超时或中断</h3><h4>原因排查（按优先级排序）</h4><ol><li>上传时间不足（默认2小时，超大文件可能不够）；</li><li>网络波动频繁（公网WebDAV易出现）；</li><li>WebDAV服务器限制单文件大小或上传时间；</li><li>本地磁盘空间不足（备份过程中磁盘满导致文件损坏）。</li></ol><h4>解决方案</h4><ol><li>延长大文件超时时间：将<code>LARGE_FILE_MAX_TIME</code>从7200（2小时）调整为14400（4小时）或21600（6小时）；</li><li>关闭大小文件区分：将<code>USE_SEPARATE_FILE_PARAMS</code>设为<code>false</code>，所有文件统一用大文件参数（更稳定）；</li><li>检查网络稳定性：在备份时段用<code>ping your-webdav-server.com</code>测试网络延迟，若波动大，建议更换备份时段（如凌晨）；</li><li>验证服务器限制：联系WebDAV服务商，确认是否有单文件大小限制（如InfiniCloud免费版通常支持10GB以内文件）；</li><li>检查本地磁盘：执行<code>df</code></li></ol>
]]></content:encoded>
<slash:comments>0</slash:comments>
<comments>https://blog.662662.xyz/archives/42/#comments</comments>
<wfw:commentRss>https://blog.662662.xyz/feed/category/Linux/</wfw:commentRss>
</item>
<item>
<title>Ubuntu 系统一键升级脚本：轻松实现 Ubuntu 18.04 到 24.04 LTS 的无缝过渡</title>
<link>https://blog.662662.xyz/archives/41/</link>
<guid>https://blog.662662.xyz/archives/41/</guid>
<pubDate>Sat, 13 Sep 2025 07:40:34 +0000</pubDate>
<dc:creator>无名</dc:creator>
<description><![CDATA[Ubuntu 系统一键升级脚本：轻松实现 Ubuntu 18.04 到 24.04 LTS 的无缝过渡对于仍在使用 Ubuntu 18.04 LTS 的用户而言，系统升级是保障安全与获取新特性的...]]></description>
<content:encoded xml:lang="zh-CN"><![CDATA[
<h1>Ubuntu 系统一键升级脚本：轻松实现 Ubuntu 18.04 到 24.04 LTS 的无缝过渡</h1><p>对于仍在使用 Ubuntu 18.04 LTS 的用户而言，系统升级是保障安全与获取新特性的关键操作。然而，跨多个版本的手动手动升级流程繁琐且易出错。本文将详细介绍一款专为 Ubuntu 系统设计的一键升级脚本，助你轻松完成从 18.04 到 24.04 LTS 的逐步升级。</p><h2>脚本核心优势</h2><p>这款一键升级脚本凭借以下特性脱颖而出：</p><ul><li><strong>全自动升级路径</strong>：无需手动干预各版本升级步骤，脚本会按序完成 18.04 → 20.04 → 22.04 → 24.04 的完整升级流程</li><li><strong>灵活源选择</strong>：提供官方源、中科大源、CERNET 校园网联合源三种选择，国内用户可根据网络环境挑选最优源</li><li><strong>协议自由切换</strong>：支持 HTTP/HTTPS 协议选择，适应不同网络环境需求</li><li><strong>智能冲突处理</strong>：自动配置 dpkg 以保留现有配置文件，避免升级中的配置冲突</li><li><strong>完善日志记录</strong>：所有操作均记录在 <code>/var/log/ubuntu_upgrade.log</code>，便于问题排查</li><li><strong>版本自适应</strong>：自动检测当前系统版本，仅执行对应阶段的升级操作</li></ul><h2>脚本工作原理</h2><p>脚本采用模块化设计，主要包含以下核心功能模块：</p><ol><li><strong>权限验证</strong>：确保脚本以 root 权限运行，保障升级操作顺利执行</li><li><strong>源配置管理</strong>：自动备份当前源配置，根据用户选择生成适配的 sources.list</li><li><strong>系统预处理</strong>：更新现有软件包、清理系统冗余文件、安装必要升级工具</li><li><strong>版本检测与升级</strong>：识别当前系统版本，调用对应升级流程，完成后自动重启</li><li><strong>异常处理</strong>：当自动升级失败时，提示用户进行手动干预</li></ol><h2>一键升级操作步骤</h2><h3>1. 获取并运行脚本</h3><p>通过以下单条命令即可下载、授权并启动升级脚本：</p><ol><li><p>主域名（江苏和四川部分地区可能被拦截）</p><pre><code class="lang-bash">wget https://git.662662.xyz/linux/ubuntu/ubuntu_upgrade.sh &amp;&amp; chmod +x ubuntu_upgrade.sh &amp;&amp; ./ubuntu_upgrade.sh</code></pre></li><li><p>备用域名</p><pre><code class="lang-bash">wget https://gitee.com/wmwlwmwl/pagoda-happy-edition/raw/master/Linux/Ubuntu/ubuntu_upgrade.sh &amp;&amp; chmod +x ubuntu_upgrade.sh &amp;&amp; ./ubuntu_upgrade.sh</code></pre></li></ol><h3>2. 交互式配置</h3><p>脚本启动后，会引导你完成两项关键配置：</p><ul><li><strong>软件源选择</strong>：根据网络环境选择最合适的源（1.官方源 / 2.中科大源 / 3.CERNET源）</li><li><strong>协议选择</strong>：根据网络安全需求选择 HTTP 或 HTTPS 协议（默认 HTTP）</li></ul><h3>3. 自动升级流程</h3><p>完成配置后，脚本将自动执行以下操作：</p><ol><li><p><strong>系统准备阶段</strong>：</p><ul><li>备份当前软件源配置到 <code>/etc/apt/sources.list.bak.时间戳</code></li><li>执行 <code>apt update</code> 更新软件包列表</li><li>运行 <code>apt upgrade</code> 和 <code>apt dist-upgrade</code> 升级现有软件</li><li>清理无用软件包（<code>autoremove</code>）和缓存（<code>autoclean</code>）</li></ul></li><li><p><strong>分阶段升级</strong>：</p><ul><li>从 18.04 升级到 20.04 LTS（focal），完成后系统自动重启</li><li>重启后，再次执行 <code>./ubuntu_upgrade.sh</code> 继续升级到 22.04 LTS（jammy），完成后再次自动重启</li><li>再次重启后，第三次执行 <code>./ubuntu_upgrade.sh</code> 完成到 24.04 LTS（noble）的升级</li></ul></li></ol><h2>关键技术细节</h2><p>脚本通过以下技术手段确保升级过程的稳定性：</p><ul><li>设置 <code>DEBIAN_FRONTEND=noninteractive</code> 实现非交互式升级</li><li>配置 <code>Dpkg::Options { &quot;--force-confold&quot;; }</code> 自动保留现有配置文件</li><li>采用 <code>do-release-upgrade</code> 命令的非交互模式（<code>-f DistUpgradeViewNonInteractive</code>）</li><li>对升级命令进行双重尝试（标准命令 → 开发版选项），提高成功率</li><li>自动禁用 Proposed Updates 源，避免不稳定软件包影响升级</li></ul><h2>注意事项</h2><ol><li><strong>全程需三次运行</strong>：每次版本升级后系统会自动重启，重启后需重新执行 <code>./ubuntu_upgrade.sh</code> 继续下一阶段</li><li><strong>升级时机选择</strong>：建议在非业务高峰期执行，整个过程可能持续数小时</li><li><strong>日志查询</strong>：若升级中断，可通过 <code>cat /var/log/ubuntu_upgrade.log</code> 查看详细过程</li><li><strong>手动干预方案</strong>：当自动升级失败时，可按提示运行 <code>do-release-upgrade</code> 进行交互式升级</li></ol><h2>升级验证</h2><p>完成所有升级步骤后，使用以下命令验证结果：</p><pre><code class="lang-bash">lsb_release -a</code></pre><p>成功升级到 24.04 LTS 后，将显示：</p><pre><code>No LSB modules are available.
Distributor ID: Ubuntu
Description:    Ubuntu 24.04 LTS
Release:        24.04
Codename:       noble</code></pre><h2>总结</h2><p>这款一键升级脚本将原本复杂的跨版本升级过程简化为几次命令执行，极大降低了操作难度。通过自动化处理软件源配置、冲突解决和分阶段升级等关键环节，既保证了升级的安全性，又提高了操作效率。</p><p>对于需要批量升级多台服务器的管理员而言，该脚本更是省时省力的利器。升级完成后，你的系统将获得持续至 2030 年的长期支持，同时享受最新的安全补丁和功能改进。</p>
]]></content:encoded>
<slash:comments>0</slash:comments>
<comments>https://blog.662662.xyz/archives/41/#comments</comments>
<wfw:commentRss>https://blog.662662.xyz/feed/category/Linux/</wfw:commentRss>
</item>
<item>
<title>Debian 系统一键升级脚本：轻松实现 10 到 13 版本的无缝过渡</title>
<link>https://blog.662662.xyz/archives/40/</link>
<guid>https://blog.662662.xyz/archives/40/</guid>
<pubDate>Sat, 13 Sep 2025 07:40:11 +0000</pubDate>
<dc:creator>无名</dc:creator>
<description><![CDATA[Debian 系统一键升级脚本：轻松实现 10 到 13 版本的无缝过渡在服务器管理中，系统版本升级是保持安全性和功能完整性的关键操作，但手动升级往往涉及繁琐的步骤和潜在风险。本文将介绍一个便捷...]]></description>
<content:encoded xml:lang="zh-CN"><![CDATA[
<h1>Debian 系统一键升级脚本：轻松实现 10 到 13 版本的无缝过渡</h1><p>在服务器管理中，系统版本升级是保持安全性和功能完整性的关键操作，但手动升级往往涉及繁琐的步骤和潜在风险。本文将介绍一个便捷的 Debian 自动化升级脚本，让你轻松实现从 Debian 10 到 11、12 直至 13 版本的平滑升级。</p><h2>一键部署与使用</h2><p>获取并运行脚本非常简单，只需在终端中执行以下命令：</p><ol><li><p>主域名（江苏和四川部分地区可能被拦截）</p><pre><code class="lang-bash">wget https://git.662662.xyz/linux/debian/debian_upgrade.sh &amp;&amp; chmod +x debian_upgrade.sh &amp;&amp; ./debian_upgrade.sh</code></pre></li><li><p>备用域名</p><pre><code class="lang-bash">wget https://gitee.com/wmwlwmwl/pagoda-happy-edition/raw/master/Linux/Debian/debian_upgrade.sh &amp;&amp; chmod +x debian_upgrade.sh &amp;&amp; ./debian_upgrade.sh</code></pre></li></ol><p>这条命令会自动完成：</p><ul><li>下载脚本文件</li><li>赋予执行权限</li><li>启动升级流程</li></ul><h2>脚本核心功能解析</h2><h3>智能版本管理</h3><p>脚本最突出的特点是能自动检测当前系统版本，并根据 Debian 官方推荐路径选择合适的升级目标：</p><ul><li>Debian 10 (buster) → 11 (bullseye)</li><li>Debian 11 (bullseye) → 12 (bookworm)</li><li>Debian 12 (bookworm) → 13 (trixie)</li></ul><p>也支持手动指定目标版本，具体命令如下：</p><h3>从 Debian 10 升级到 11</h3><pre><code class="lang-bash">./debian_upgrade.sh bullseye</code></pre><h3>从 Debian 11 升级到 12</h3><pre><code class="lang-bash">./debian_upgrade.sh bookworm</code></pre><h3>从 Debian 12 升级到 13</h3><pre><code class="lang-bash">./debian_upgrade.sh trixie</code></pre><h3>灵活的镜像源选择</h3><p>考虑到不同网络环境的访问速度，脚本提供多镜像源选项：</p><ul><li>官方源 (deb.debian.org)</li><li>中国科学技术大学源 (mirrors.ustc.edu.cn)</li><li>CERNET校园网联合源 (mirrors.cernet.edu.cn)</li></ul><p>同时支持 HTTP/HTTPS 协议切换，兼顾速度与安全性。</p><h3>安全升级机制</h3><ol><li><p><strong>自动备份</strong>：升级前会备份关键配置文件到 <code>/root/debian_upgrade_backup_时间戳</code> 目录，包括：</p><ul><li>软件源列表 (sources.list)</li><li>源列表目录 (sources.list.d)</li><li>网络配置 (interfaces)</li></ul></li><li><p><strong>配置冲突处理</strong>：智能处理升级过程中的配置文件冲突，默认保留现有配置：</p><pre><code class="lang-bash"># 非交互模式处理配置文件
DEBIAN_FRONTEND=noninteractive apt upgrade -y -o Dpkg::Options::=&quot;--force-confold&quot;</code></pre></li><li><strong>完整日志记录</strong>：所有操作细节记录在 <code>/var/log/debian_upgrade.log</code>，便于问题排查。</li></ol><h2>升级流程详解</h2><ol><li><strong>环境检测</strong>：验证系统版本和root权限</li><li><strong>镜像源选择</strong>：根据网络环境选择合适的软件源</li><li><strong>操作确认</strong>：提醒用户做好数据备份和准备工作</li><li><strong>系统准备</strong>：更新当前系统到最新状态并清理冗余包</li><li><strong>源配置更新</strong>：根据目标版本自动生成新的软件源配置</li><li><strong>分步升级</strong>：先执行最小升级，再进行完整系统升级</li><li><strong>重启确认</strong>：升级完成后提示用户重启系统</li></ol><h2>注意事项</h2><p>使用前请确保：</p><ul><li>系统已备份重要数据</li><li>网络连接稳定（建议有线连接）</li><li>至少保留 10GB 空闲磁盘空间</li><li>升级过程中避免断电（服务器建议使用UPS）</li></ul><h2>总结</h2><p>这个自动化升级脚本通过标准化升级流程，大大降低了 Debian 版本升级的技术门槛。无论是个人用户还是企业运维人员，都可以通过简单的命令实现系统的安全升级。</p><p>脚本采用模块化设计，后续可轻松扩展支持更高版本的 Debian 系统。建议首次使用时先在测试环境验证，再应用到生产系统，确保升级过程万无一失。</p>
]]></content:encoded>
<slash:comments>0</slash:comments>
<comments>https://blog.662662.xyz/archives/40/#comments</comments>
<wfw:commentRss>https://blog.662662.xyz/feed/category/Linux/</wfw:commentRss>
</item>
<item>
<title>Linux 多发行版一键换源脚本：支持 Debian/Ubuntu/Rocky/Alma（含 DEB822 新格式）</title>
<link>https://blog.662662.xyz/archives/39/</link>
<guid>https://blog.662662.xyz/archives/39/</guid>
<pubDate>Tue, 09 Sep 2025 18:44:00 +0000</pubDate>
<dc:creator>无名</dc:creator>
<description><![CDATA[Linux 系统软件源一键切换工具：轻松配置国内镜像源在 Linux 系统使用过程中，软件源的选择直接影响包管理工具的下载速度和稳定性。对于国内用户而言，切换到国内镜像源往往能显著提升软件安装和...]]></description>
<content:encoded xml:lang="zh-CN"><![CDATA[
<h1>Linux 系统软件源一键切换工具：轻松配置国内镜像源</h1><p>在 Linux 系统使用过程中，软件源的选择直接影响包管理工具的下载速度和稳定性。对于国内用户而言，切换到国内镜像源往往能显著提升软件安装和更新效率。本文将介绍一款实用的 Shell 脚本工具，帮助你一键切换 Debian、Ubuntu、Rocky Linux 和 Alma Linux 系统的软件源，同时支持自定义镜像源配置。</p><h2>工具特点与优势</h2><p>这款软件源切换工具具备以下核心特性：</p><ul><li><strong>多系统支持</strong>：兼容 Debian、Ubuntu、Rocky Linux 和 Alma Linux 主流发行版</li><li><strong>智能版本适配</strong>：自动识别系统版本，对 Ubuntu 24.04+ 和 Debian 12+ 采用新的 DEB822 格式源配置</li><li><strong>丰富镜像选择</strong>：内置官方源及多个国内优质镜像（中科大、南京大学、阿里云、华为云、CERNET 校园网联合源等）</li><li><strong>自定义源支持</strong>：允许用户添加和管理私有或第三方镜像源，满足个性化需求</li><li><strong>安全备份机制</strong>：自动备份当前源配置，支持历史备份管理与一键还原，防止配置丢失</li><li><strong>协议灵活选择</strong>：支持 HTTP/HTTPS 协议切换，适应不同网络环境</li><li><strong>操作简单直观</strong>：交互式菜单设计，无需手动编辑配置文件</li></ul><h2>支持的镜像源说明</h2><table><thead><tr><th>镜像源</th><th>特点</th><th>推荐场景</th></tr></thead><tbody><tr><td>官方源</td><td>最权威稳定</td><td>国外服务器或需要严格兼容性的场景</td></tr><tr><td>中国科技大学源</td><td>学术机构镜像，更新及时</td><td>教育网用户优先选择</td></tr><tr><td>南京大学源</td><td>镜像完整，速度稳定</td><td>华东地区用户体验佳</td></tr><tr><td>阿里云源</td><td>国内访问速度快，覆盖广</td><td>阿里云服务器或南方用户</td></tr><tr><td>华为云源</td><td>稳定性好，镜像同步及时</td><td>华为云服务器用户</td></tr><tr><td>CERNET 校园网联合源</td><td>智能选择最佳镜像</td><td>高校校园网用户</td></tr><tr><td>江西理工大学源</td><td>高校运维团队维护</td><td>华南地区用户体验佳</td></tr><tr><td>自定义源（兰州大学示例）</td><td>按需配置，灵活扩展</td><td>私有镜像或特殊需求场景</td></tr></tbody></table><blockquote>说明：由于中国科技大学源暂不提供 Alma Linux 镜像支持，脚本为 Alma Linux 系统特别集成了江西理工大学源作为替代选择</blockquote><h2>工具使用指南</h2><h3>前提条件</h3><ul><li>系统需为 Debian、Ubuntu、Rocky Linux 或 Alma Linux</li><li>确保已安装 wget（可通过 <code>apt install -y wget</code> 或 <code>dnf install -y wget</code> 安装）</li><li>需拥有 root 权限（可通过 sudo 执行）</li><li>确保网络连接正常</li></ul><h3>使用方法</h3><ol><li><p><strong>获取脚本</strong></p><ol><li><p>主域名（江苏和四川部分地区可能被拦截）</p><pre><code class="lang-bash">wget https://git.662662.xyz/linux/change_source.sh &amp;&amp; bash change_source.sh</code></pre></li><li><p>备用域名</p><pre><code class="lang-bash">wget https://gitee.com/wmwlwmwl/pagoda-happy-edition/raw/master/Linux/change_source.sh &amp;&amp; bash change_source.sh</code></pre></li></ol></li><li><p><strong>操作流程</strong></p><ul><li>运行脚本后，系统将自动检测当前发行版及版本</li><li>从交互菜单中选择所需的镜像源（包括"自定义源"选项）</li><li>选择适合网络环境的 HTTP/HTTPS 协议</li><li>如需添加自定义源，选择对应选项后按提示输入镜像源地址和相关参数</li><li>如需管理历史配置，可通过"备份管理"选项进行操作</li><li>脚本自动完成备份、配置替换与缓存更新</li></ul></li></ol><h2>自定义镜像源配置说明</h2><p>工具支持添加和管理自定义镜像源，满足特殊场景需求：</p><ul><li><p><strong>添加流程</strong>：</p><ol><li>在主菜单选择"自定义源"选项</li><li>按提示输入镜像源名称（用于标识）</li><li>输入镜像源基础 URL（如 <code>https://mirrors.lzu.edu.cn/debian/</code>）</li><li>选择适用的系统组件或仓库类型</li><li>确认配置后，脚本将自动生成对应格式的源配置文件</li></ol></li></ul><h2>备份管理功能说明</h2><p>工具内置完善的备份管理机制，为系统源配置提供安全保障：</p><ul><li><strong>自动备份</strong>：每次更换源配置前，自动将当前配置备份至带时间戳的专用目录</li><li><p><strong>备份路径</strong>：</p><ul><li>Debian/Ubuntu 系统：<code>/etc/apt/backup_时间戳</code></li><li>Rocky/Alma Linux 系统：<code>/etc/yum.repos.d/backup_时间戳</code></li></ul></li><li><p><strong>交互管理</strong>：通过"备份管理"菜单可实现：</p><ul><li>查看所有历史备份记录（按时间排序）</li><li>选择指定版本一键还原</li><li>清理过期备份文件释放空间</li></ul></li><li><strong>版本追溯</strong>：每个备份包含精确时间戳，便于追溯配置变更历史</li></ul><h2>注意事项</h2><ol><li>切换源后若出现 GPG 密钥错误，可尝试导入对应仓库的公钥（通常镜像站文档会提供导入命令）</li><li>部分镜像源可能存在软件包不全的情况，若遇缺失可尝试切换其他源</li><li>系统版本升级（如 Ubuntu 22.04 → 24.04）后，建议重新运行脚本更新源配置</li><li>校园网用户优先选择 CERNET 源，可自动匹配最优镜像节点</li><li>企业内网环境建议选择 HTTP 协议，避免证书验证问题</li><li>添加自定义源时，请确保源地址的正确性和安全性，避免使用不可信的第三方源</li></ol><p>通过这款工具，即使是 Linux 新手也能轻松完成软件源配置，同时支持高级用户通过自定义源功能满足特殊需求，告别缓慢的下载速度，提升系统使用体验。工具源码开源可查，便于二次开发和功能扩展。</p>
]]></content:encoded>
<slash:comments>0</slash:comments>
<comments>https://blog.662662.xyz/archives/39/#comments</comments>
<wfw:commentRss>https://blog.662662.xyz/feed/category/Linux/</wfw:commentRss>
</item>
<item>
<title>Linux修改SSH端口</title>
<link>https://blog.662662.xyz/archives/38/</link>
<guid>https://blog.662662.xyz/archives/38/</guid>
<pubDate>Thu, 04 Jul 2024 10:55:00 +0000</pubDate>
<dc:creator>无名</dc:creator>
<description><![CDATA[如何修改SSH默认端口修改SSH默认端口（22）可以提高服务器安全性，以下是两种常用方法：方法一：使用sed命令自动修改（推荐）通过命令行直接替换配置文件中的端口，无需手动编辑。执行以下命令，将...]]></description>
<content:encoded xml:lang="zh-CN"><![CDATA[
<h1>如何修改SSH默认端口</h1><p>修改SSH默认端口（22）可以提高服务器安全性，以下是两种常用方法：</p><h2>方法一：使用sed命令自动修改（推荐）</h2><p>通过命令行直接替换配置文件中的端口，无需手动编辑。</p><ol><li><p>执行以下命令，将<code>[新端口]</code>替换为你需要设置的端口（如2222）：</p><pre><code class="lang-bash"># 替换注释掉的端口配置（#Port 22）
sed -i &#039;s@#Port 22@Port [新端口]@g&#039; /etc/ssh/sshd_config
# 替换已启用的端口配置（Port 22）
sed -i &#039;s@Port 22@Port [新端口]@g&#039; /etc/ssh/sshd_config</code></pre></li><li><p>重启SSH服务使配置生效：</p><pre><code class="lang-bash">systemctl restart sshd
# 或
systemctl restart ssh</code></pre></li></ol><h2>方法二：手动编辑配置文件</h2><p>适合习惯可视化编辑的用户，步骤如下：</p><ol><li><p>打开SSH配置文件：</p><pre><code class="lang-bash">vi /etc/ssh/sshd_config</code></pre></li><li><p>找到端口配置行：</p><ul><li>若显示 <code>#Port 22</code>（带注释），删除 <code>#</code> 并将 <code>22</code> 改为新端口；</li><li>若显示 <code>Port 22</code>（已启用），直接将 <code>22</code> 改为新端口。<br>（提示：按 <code>i</code> 进入编辑模式，修改后按 <code>Esc</code> 退出编辑）</li></ul></li><li>保存并退出：<br>输入 <code>:wq!</code> 后按回车（强制保存并退出）。</li><li><p>重启SSH服务使配置生效：</p><pre><code class="lang-bash">systemctl restart sshd
# 或
systemctl restart ssh</code></pre></li></ol><h2>注意事项</h2><ul><li>新端口建议选择1024-65535之间的未占用端口，避免与其他服务冲突；</li><li>修改后需通过新端口连接SSH（如 <code>ssh 用户名@IP地址 -p 新端口</code>）；</li><li>若服务器启用防火墙，需开放新端口的访问权限。</li></ul>
]]></content:encoded>
<slash:comments>0</slash:comments>
<comments>https://blog.662662.xyz/archives/38/#comments</comments>
<wfw:commentRss>https://blog.662662.xyz/feed/category/Linux/</wfw:commentRss>
</item>
<item>
<title>Ubuntu18.04LTS升级到20.04LTS升级到22.04LTS升级到24.04LTS</title>
<link>https://blog.662662.xyz/archives/37/</link>
<guid>https://blog.662662.xyz/archives/37/</guid>
<pubDate>Sat, 15 Jun 2024 12:40:00 +0000</pubDate>
<dc:creator>无名</dc:creator>
<description><![CDATA[Ubuntu 系统版本升级完整教程（含操作截图指引）准备工作：系统更新与清理在进行版本升级前，需先确保当前系统软件包为最新状态，避免因依赖问题导致升级失败：更新软件包列表并升级已安装软件：sud...]]></description>
<content:encoded xml:lang="zh-CN"><![CDATA[
<h1>Ubuntu 系统版本升级完整教程（含操作截图指引）</h1><h2>准备工作：系统更新与清理</h2><p>在进行版本升级前，需先确保当前系统软件包为最新状态，避免因依赖问题导致升级失败：</p><ol><li><p>更新软件包列表并升级已安装软件：</p><pre><code class="lang-bash">sudo apt update -y
sudo apt upgrade -y</code></pre></li><li><p>移除不再需要的依赖包和冗余文件，释放磁盘空间：</p><pre><code class="lang-bash">sudo apt autoremove -y</code></pre></li></ol><h2>升级步骤（含交互提示与截图对应）</h2><h3>1. 安装升级管理工具</h3><p>Ubuntu 版本升级依赖 <code>update-manager-core</code> 工具，执行以下命令安装：</p><pre><code class="lang-bash">sudo apt install update-manager-core -y</code></pre><h3>2. 启动版本升级过程</h3><p>输入核心升级命令，触发系统版本迭代流程：</p><pre><code class="lang-bash">sudo do-release-upgrade</code></pre><h3>3. 升级过程中的交互提示处理（截图对应操作）</h3><h4>提示1：SSH 备用端口确认</h4><p>若通过 SSH 远程连接服务器升级，会提示“在 1022 端口启动额外 SSH 守护进程（防止主连接中断）”，对应截图如下：  <br><img src="https://blog.662662.xyz/usr/uploads/2024/06/3202695117.png" alt="Screenshot_20240615-144056.png" title="Screenshot_20240615-144056.png"><br><strong>操作</strong>：输入 <code>y</code> 继续。</p><h4>提示2：信息确认回车</h4><p>出现“To continue please press [ENTER]”提示，对应截图如下：  <br><img src="https://blog.662662.xyz/usr/uploads/2024/06/2484458162.png" alt="Screenshot_20240615-144102.png" title="Screenshot_20240615-144102.png"><br><strong>操作</strong>：按下回车键继续。</p><h4>提示3：继续升级确认</h4><p>显示“Continue [yN]  Details [d]”选项，对应截图如下：  <br><img src="https://blog.662662.xyz/usr/uploads/2024/06/818727797.png" alt="Screenshot_20240615-144225.png" title="Screenshot_20240615-144225.png"><br><strong>操作</strong>：输入 <code>y</code> 确认继续升级。</p><h4>提示4：服务重启配置</h4><p>进入“Configuring libc6”界面，提示“Restart services during package upgrades without asking?”，对应截图如下：  <br><img src="https://blog.662662.xyz/usr/uploads/2024/06/2575002836.png" alt="Screenshot_20240615-144505.png" title="Screenshot_20240615-144505.png"><br><strong>操作</strong>：按 <code>TAB</code> 键切换到 <code>&lt;Yes&gt;</code> 选项，按下回车键确认。</p><h4>提示5：crontab 配置文件选择</h4><p>出现“<em>*</em> crontab (Y/I/N/O/D/Z) [default=N] ?”提示（选择是否使用新版本 crontab 配置），对应截图如下：  <br><img src="https://blog.662662.xyz/usr/uploads/2024/06/892600673.png" alt="Screenshot_20240615-144840.png" title="Screenshot_20240615-144840.png"><br><strong>操作</strong>：</p><ul><li>全新系统/无自定义配置：输入 <code>y</code> 使用新版本</li><li>有自定义 crontab 规则：输入 <code>n</code> 保留原版本</li></ul><h4>提示6：sshd_config 配置文件处理</h4><p>提示“modified configuration file sshd_config”（本地修改过 SSH 配置文件，需选择处理方式），对应截图如下：  <br><img src="https://blog.662662.xyz/usr/uploads/2024/06/423346180.png" alt="Screenshot_20240615-144929.png" title="Screenshot_20240615-144929.png"><br><strong>操作</strong>：按 <code>↓</code> 键选择第 2 项（通常为“保留本地修改版本”），按下回车键。</p><h4>提示7：升级继续确认</h4><p>再次出现“Continue [yN]  Details [d]”提示，对应截图如下：  <br><img src="https://blog.662662.xyz/usr/uploads/2024/06/2803601323.png" alt="Screenshot_20240615-145124.png" title="Screenshot_20240615-145124.png"><br><strong>操作</strong>：输入 <code>y</code> 继续。</p><h4>提示8：系统重启确认</h4><p>升级完成后提示“System upgrade is complete. Restart required”，对应截图如下：  <br><img src="https://blog.662662.xyz/usr/uploads/2024/06/3013023152.png" alt="Screenshot_20240615-145145.png" title="Screenshot_20240615-145145.png"><br><strong>操作</strong>：输入 <code>y</code> 自动重启系统。</p><h4>提示9：升级成功验证</h4><p>系统重启后重新连接，若显示“Welcome to Ubuntu 20.04.6 LTS”，对应截图如下：  <br><img src="https://blog.662662.xyz/usr/uploads/2024/06/3995767427.png" alt="Screenshot_20240615-145209.png" title="Screenshot_20240615-145209.png"><br><strong>说明</strong>：此时已成功升级到 Ubuntu 20.04 LTS 版本。</p><h2>升级到更高版本（如 20.04 → 22.04 → 24.04）</h2><p>Ubuntu 版本升级需<strong>逐级迭代</strong>（无法跨版本直接升级），若需继续升级到更高版本：</p><ol><li>重复上述“准备工作”（更新软件包、清理冗余文件）</li><li><p>再次执行核心升级命令：</p><pre><code class="lang-bash">sudo do-release-upgrade</code></pre></li><li>按照相同的交互提示流程操作，直至升级到目标版本。</li></ol><h2>关键注意事项</h2><ol><li><strong>数据备份</strong>：升级前务必备份重要文件（如配置文件、业务数据），避免意外中断导致数据丢失。</li><li><strong>磁盘空间</strong>：确保系统空闲磁盘空间≥10GB，不足时可通过 <code>df -h</code> 查看并清理冗余文件。</li><li><strong>网络稳定性</strong>：升级过程需持续下载软件包，建议使用有线网络或稳定的无线网络，避免中断。</li><li><strong>时间预估</strong>：升级耗时取决于网络速度和系统配置，通常为 30 分钟~2 小时，请勿中途强制关机。</li></ol>
]]></content:encoded>
<slash:comments>0</slash:comments>
<comments>https://blog.662662.xyz/archives/37/#comments</comments>
<wfw:commentRss>https://blog.662662.xyz/feed/category/Linux/</wfw:commentRss>
</item>
<item>
<title>Linux设置登录提示</title>
<link>https://blog.662662.xyz/archives/27/</link>
<guid>https://blog.662662.xyz/archives/27/</guid>
<pubDate>Tue, 11 Jun 2024 16:53:00 +0000</pubDate>
<dc:creator>无名</dc:creator>
<description><![CDATA[如何在 Linux 登录时显示自定义提示或图案在 Linux 系统中，你可以通过编辑 /etc/motd 文件（Message of the Day，即日提示信息），设置用户登录后看到的欢迎信息...]]></description>
<content:encoded xml:lang="zh-CN"><![CDATA[
<h1>如何在 Linux 登录时显示自定义提示或图案</h1><p>在 Linux 系统中，你可以通过编辑 <code>/etc/motd</code> 文件（Message of the Day，即日提示信息），设置用户登录后看到的欢迎信息、提示内容或趣味图案。</p><h2>配置方法</h2><ol><li><p>编辑或创建 <code>motd</code> 文件：</p><pre><code class="lang-bash">vi /etc/motd</code></pre><p>（如果文件不存在，此命令会自动创建）</p></li><li>在文件中添加你想要显示的内容（文字或图案），按 <code>i</code> 进入编辑模式，完成后按 <code>Esc</code>，输入 <code>:wq</code> 保存退出。</li><li>无需重启服务，下次登录时即可看到效果。</li></ol><h2>关于 <code>/etc/motd</code> 的说明</h2><ul><li><code>motd</code> 是 "Message of the Day" 的缩写，内容会在用户成功登录后显示</li><li>该文件通常是普通文本文件，但部分系统中可能是软链接（如链接到 <code>/var/run/motd</code>）</li><li>支持纯文本格式，可包含 ASCII 字符组成的图案、系统提示、欢迎语等</li></ul><h2>实用示例：有趣的登录图案</h2><p>以下是几个常用的 ASCII 艺术图案示例，可直接复制到 <code>/etc/motd</code> 中使用：</p><h3>示例 1：佛祖保佑图案</h3><pre><code>                   _ooOoo_
                  o8888888o
                  88&quot; . &quot;88
                  (| -_- |)
                  O\  =  /O
               ____/`---&#039;\____
             .&#039;  \\|     |//  `.
            /  \\|||  :  |||//  \
           /  _||||| -:- |||||-  \
           |   | \\\  -  /// |   |
           | \_|  &#039;&#039;\---/&#039;&#039;  |   |
           \  .-\__  `-`  ___/-. /
         ___`. .&#039;  /--.--\  `. . __
      .&quot;&quot; &#039;&lt;  `.___\_&lt;|&gt;_/___.&#039;  &gt;&#039;&quot;&quot;.
     | | :  `- \`.;`\ _ /`;.`/ - ` : | |
     \  \ `-.   \_ __\ /__ _/   .-` /  /
======`-.____`-.___\_____/___.-`____.-&#039;======
                   `=---=&#039;
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
           佛祖保佑       永不宕机</code></pre><h3>示例 2：奋斗激励图案</h3><pre><code>          __   _,--=&quot;=--,_   __
         /  \.&quot;    .-.    &quot;./  \
        /  ,/  _   : :   _  \/` \
        \  `| /o\  :_:  /o\ |\__/
         `-&#039;| :=&quot;~` _ `~&quot;=: |
            \`     (_)     `/
     .-&quot;-.   \      |      /   .-&quot;-.
.---{     }--|  /,.-&#039;-.,\  |--{     }---.
 )  (_)_)_)  \_/`~-===-~`\_/  (_(_(_)  (
(              GO GO GO GO              )
 )                                     (
&#039;---------------------------------------&#039;</code></pre><h2>扩展技巧</h2><ul><li>可以在图案中添加系统信息，例如使用脚本动态生成当前时间、负载等（需结合 <code>update-motd</code> 机制）</li><li>避免使用过多特殊字符，部分终端可能无法正常显示</li><li>如需临时关闭提示，可清空文件内容：<code>echo &quot;&quot; &gt; /etc/motd</code></li></ul><p>通过自定义 <code>motd</code>，既能增加登录时的趣味性，也能添加实用的系统提示信息，适合个人服务器或团队使用的 Linux 环境。</p>
]]></content:encoded>
<slash:comments>0</slash:comments>
<comments>https://blog.662662.xyz/archives/27/#comments</comments>
<wfw:commentRss>https://blog.662662.xyz/feed/category/Linux/</wfw:commentRss>
</item>
<item>
<title>Linux修改系统主机名</title>
<link>https://blog.662662.xyz/archives/26/</link>
<guid>https://blog.662662.xyz/archives/26/</guid>
<pubDate>Tue, 11 Jun 2024 16:46:00 +0000</pubDate>
<dc:creator>无名</dc:creator>
<description><![CDATA[如何修改 Linux 系统的主机名修改 Linux 系统的主机名有两种常用方法，操作简单且效果持久，以下是详细步骤：方法一：使用 hostnamectl 命令（推荐）hostnamectl 是 ...]]></description>
<content:encoded xml:lang="zh-CN"><![CDATA[
<h1>如何修改 Linux 系统的主机名</h1><p>修改 Linux 系统的主机名有两种常用方法，操作简单且效果持久，以下是详细步骤：</p><h2>方法一：使用 hostnamectl 命令（推荐）</h2><p><code>hostnamectl</code> 是 systemd 系统中专门用于管理主机名的工具，修改后无需重启即可生效。</p><ol><li><p>执行以下命令，将 <code>[新主机名]</code> 替换为你想要设置的名称（如 <code>wuming</code>）：</p><pre><code class="lang-bash">hostnamectl set-hostname [新主机名]</code></pre></li><li><p>示例（将主机名改为 <code>wuming</code>）：</p><pre><code class="lang-bash">hostnamectl set-hostname wuming</code></pre></li><li><p>修改后立即生效，可通过 <code>hostname</code> 命令验证：</p><pre><code class="lang-bash">hostname  # 输出新设置的主机名</code></pre></li></ol><h2>方法二：手动编辑配置文件</h2><p>通过直接修改 <code>/etc/hostname</code> 文件来设置主机名，适合习惯手动编辑配置的场景。</p><ol><li><p>打开主机名配置文件：</p><pre><code class="lang-bash">vi /etc/hostname</code></pre></li><li><p>编辑文件内容：</p><ul><li>按 <code>i</code> 进入编辑模式</li><li>删除原有内容，输入新的主机名（如 <code>wuming</code>）</li><li>按 <code>Esc</code> 退出编辑模式</li></ul></li><li>保存并退出：<br>输入 <code>:wq!</code> 后按回车（强制保存并退出）。</li><li><p>重启系统使修改生效：</p><pre><code class="lang-bash">reboot</code></pre></li></ol><h2>注意事项</h2><ul><li>主机名建议使用字母、数字、连字符（-）或下划线（_），避免特殊字符</li><li>修改后，可通过 <code>hostname</code> 或 <code>hostnamectl</code> 命令确认是否生效</li><li>部分系统可能还需要同步修改 <code>/etc/hosts</code> 文件（将旧主机名替换为新主机名），以避免本地解析问题</li></ul><p>两种方法均可永久修改主机名，推荐优先使用 <code>hostnamectl</code> 命令，操作更简便且无需重启。</p>
]]></content:encoded>
<slash:comments>0</slash:comments>
<comments>https://blog.662662.xyz/archives/26/#comments</comments>
<wfw:commentRss>https://blog.662662.xyz/feed/category/Linux/</wfw:commentRss>
</item>
<item>
<title>docker执行容器内的脚本</title>
<link>https://blog.662662.xyz/archives/25/</link>
<guid>https://blog.662662.xyz/archives/25/</guid>
<pubDate>Tue, 21 May 2024 08:02:00 +0000</pubDate>
<dc:creator>无名</dc:creator>
<description><![CDATA[Docker容器操作指南：执行命令与设置开机自启一、连接并操作正在运行的Docker容器1. 查看容器信息直接获取需操作的容器ID或名称（无需额外权限）：docker ps命令会列出所有运行中容...]]></description>
<content:encoded xml:lang="zh-CN"><![CDATA[
<h1>Docker容器操作指南：执行命令与设置开机自启</h1><h2>一、连接并操作正在运行的Docker容器</h2><h3>1. 查看容器信息</h3><p>直接获取需操作的容器ID或名称（无需额外权限）：</p><pre><code class="lang-bash">docker ps</code></pre><p>命令会列出所有运行中容器，重点关注两列信息：</p><table><thead><tr><th>列名</th><th>示例值</th></tr></thead><tbody><tr><td>CONTAINER ID</td><td>212cfc09b7ed</td></tr><tr><td>NAMES</td><td>1Panel-php7-3T4d</td></tr></tbody></table><h3>2. 连接到容器</h3><p>通过<code>docker exec</code>以交互式方式进入容器，方便后续操作：</p><pre><code class="lang-bash">docker exec -it &lt;容器ID或名称&gt; /bin/sh</code></pre><ul><li>说明：<code>-it</code>确保交互式连接（可输入命令）；<code>&lt;容器ID或名称&gt;</code>替换为实际标识（如<code>212cfc09b7ed</code>或<code>1Panel-php7-3T4d</code>）；<code>/bin/sh</code>为容器默认shell（部分容器需用<code>/bin/bash</code>）。</li></ul><h2>二、在容器中执行PHP任务（以彩虹聚合DNS为例）</h2><h3>1. 方法一：通过脚本执行（适合需延迟/复杂逻辑）</h3><ol><li><p>在宿主机目标目录创建脚本文件（如<code>dns.sh</code>）：</p><pre><code class="lang-bash">vi /www/sites/dns/index/dns.sh</code></pre></li><li><p>写入脚本内容（延迟20秒确保数据库启动，无需可删除）：</p><pre><code class="lang-bash">sleep 20  # 适配彩虹聚合DNS依赖的数据库启动时间
cd /www/sites/dns/index/ &amp;&amp; php think dmtask</code></pre></li><li><p>给脚本添加执行权限：</p><pre><code class="lang-bash">chmod +x /www/sites/dns/index/dns.sh</code></pre></li><li><p>让容器执行脚本：</p><pre><code class="lang-bash">docker exec -it &lt;容器ID或名称&gt; /bin/sh /www/sites/dns/index/dns.sh</code></pre></li></ol><h3>2. 方法二：直接执行PHP命令（简化操作）</h3><p>无需创建脚本，直接在容器内运行PHP任务，支持后台执行：</p><pre><code class="lang-bash">docker exec &lt;容器ID或名称&gt; sh -c &quot;php /www/sites/dns/index/think dmtask&quot;</code></pre><ul><li>优势：省略脚本步骤，<code>docker</code>会自动后台运行，退出终端不影响任务执行。</li></ul><h2>三、设置开机自启动（用cron @reboot 实现）</h2><p>通过<code>cron</code>的<code>@reboot</code>选项，让系统重启后自动执行容器内的PHP任务，比<code>rc.local</code>更灵活稳定。</p><h3>1. 编辑当前用户的crontab配置</h3><p>执行以下命令打开crontab编辑界面：</p><pre><code class="lang-bash">crontab -e</code></pre><ul><li>首次编辑会提示选择编辑器（如<code>nano</code>或<code>vi</code>），按提示选择常用编辑器即可（如输入<code>2</code>选择<code>vi</code>）。</li></ul><h3>2. 添加开机自启任务</h3><p>在crontab文件末尾添加以下内容（根据实际场景选择命令）：</p><h4>场景1：直接执行PHP命令（推荐）</h4><pre><code class="lang-bash">@reboot sleep 20; docker exec &lt;容器ID或名称&gt; sh -c &quot;php /www/sites/dns/index/think dmtask&quot;</code></pre><ul><li><p>示例（用容器名称<code>1Panel-php7-3T4d</code>，更稳定）：</p><pre><code class="lang-bash">@reboot sleep 20; docker exec 1Panel-php7-3T4d sh -c &quot;php /www/sites/dns/index/think dmtask&quot;</code></pre></li></ul><h4>场景2：执行脚本文件</h4><p>若用之前创建的<code>dns.sh</code>脚本，可添加：</p><pre><code class="lang-bash">@reboot docker exec &lt;容器ID或名称&gt; /bin/sh /www/sites/dns/index/dns.sh</code></pre><ul><li>说明：若脚本内已包含<code>sleep 20</code>，此处无需重复添加延迟。</li></ul><h3>3. 保存并退出crontab</h3><ul><li>若用<code>vi</code>编辑器：按<code>Esc</code>，输入<code>:wq</code>回车保存退出；</li><li>若用<code>nano</code>编辑器：按<code>Ctrl+O</code>回车保存，再按<code>Ctrl+X</code>退出。</li></ul><h3>4. 验证crontab配置</h3><p>执行以下命令查看当前用户的crontab任务，确认配置已生效：</p><pre><code class="lang-bash">crontab -l</code></pre><p>若输出中包含刚才添加的<code>@reboot</code>任务，说明配置成功。</p><h2>四、注意事项</h2><ol><li><strong>容器标识选择</strong>：优先用容器名称（如<code>1Panel-php7-3T4d</code>），而非容器ID——容器重建后ID会变化，名称通常不变，避免频繁修改配置。</li><li><strong>延迟时间调整</strong>：<code>sleep 20</code>（20秒）需根据实际环境调整，确保系统重启后，<code>docker</code>服务、容器及依赖的数据库完全启动后，再执行PHP任务（可根据实际启动速度改为<code>30</code>或<code>40</code>秒）。</li><li><strong>权限问题</strong>：若执行<code>docker</code>命令提示权限不足，需确认当前用户已加入<code>docker</code>用户组（可联系管理员执行<code>usermod -aG docker 用户名</code>添加，添加后需重新登录生效）。</li><li><strong>日志排查</strong>：若开机后任务未执行，可查看<code>cron</code>日志排查问题（Debian/Ubuntu系统日志路径：<code>/var/log/syslog</code>，搜索关键词<code>CRON</code>；CentOS系统日志路径：<code>/var/log/cron</code>）。</li></ol>
]]></content:encoded>
<slash:comments>0</slash:comments>
<comments>https://blog.662662.xyz/archives/25/#comments</comments>
<wfw:commentRss>https://blog.662662.xyz/feed/category/Linux/</wfw:commentRss>
</item>
</channel>
</rss>