解决蜗牛星际B双安装黑群晖失败“文件已损毁(13)”

去年疫情期间,由于滞留家中实在无聊,我开始折腾软路由和 DIY NAS,而被折腾得最多的莫过于黑群晖系统。为此,我特意买来两台蜗牛星际(B双和C),其中B双用作软路由,C则用于黑群晖。时隔一年,忙于工作的我已不再有闲暇时间折腾黑群晖,而出于对数据安全和便捷性的考虑,我于今年年初购买了一台威联通的 NAS 主机。俗话说得好,黑群晖折腾到头,就会转去白群辉。但奈何威联通的性价比要比群晖高太多,因此我只好无耻地叛变了革命。 昨天心血来潮,想把放在角落吃灰许久的蜗牛星际B双刷成黑群晖,用作重要数据的冷备工具,平常都会处于关机状态,只有冷备的时候才会开机。由于我的B双之前一直都用作软路由,因此从来都没有刷过黑群晖。但鉴于蜗牛星际的配置都差不多,我简单地以为直接用之前C上现成的黑群晖引导U盘即可直接安装黑群晖系统。然而天真的我还是遇到了困难。 问题出在新系统安装的过程中,每当进度走到 56% 的时候,都会跳出编号为 13 的错误,提示“系统安装失败,文件可能已经损毁(13)”。为了解决这一问题,我尝试了很多方法,包括但不限于格式化所有硬盘(包括 SSD)以及更换各个版本的官方或非官方 DSM 安装包,但都不奏效,错误 13 依然存在。 最后,在电报群里高人的指点下,我终于解决了这一问题。其实,新系统安装的过程中之所以会出现错误 13, 是因为机器主板的 BIOS 没设置好。只要给主机插上键盘和显示器,在开机时进入 BIOS 界面(通常是在开机后显示主板厂商 logo 时按键盘上的 DEL 键进入),然后依次进入 Advanced—Miscellaneous Configuration—OS Selection,将 Win 7 改为 Win 8.x 即可。 忙活了半天,最后才知道原来只是这么简单的一个问题。为了不让后来的小白们像我一样浪费时间,特此记录一下。本文也谈不上什么教程了。

2021-04-23 · Mason

Openwrt Luci Openvpn 服务器多设备同时接入

我们日常使用的 Openwrt 软路由系统几乎都集成了 Luci 界面,它不仅可以为用户提供便利的可视化后台管理界面,还在各路大神的贡献下,适配了众多简单易用的图形化 App。Luci-app-openvpn-server 就是众多 Luci 应用中最常用的 VPN 服务器之一。 简单来说,luci-app-openvpn-server 就是 Openvpn 服务器端的 Luci 界面版本。有了它,你就可以告别难搞的命令行,通过图形化的网页直接配置你的 Openvpn 服务器端。结合各主流平台的 Openvpn 客户端软件,你可以随时随地接入自己家里的局域网,实现内网访问或文件传输等功能。 正常情况下,只要按照 Luci 界面的提示填写相应的配置信息,即可成功运行 Openvpn 的服务器端。此时只要点击“一键下载.Ovpn 文件”按钮,再将下载下来的配置文件直接导入 Openvpn 客户端软件即可开始使用。但 luci-app-openvpn-server 的默认配置支支持同时登陆一个客户端,当有第二个客户端尝试接入时,先前接入的第一个客户端就会被强制断线。然而在日常使用的过程中,多设备同时接入的情况是十分常见的,那么怎样才能使 luci-app-openvpn-server 可以同时接入多个设备呢? 其实,Openvpn 的服务端是支持多设备同时接入的。根据 Github 上这个 Issue 中的介绍,我们能够得知,只要在 Openvpn 的配置文件中加入一行代码,即可开启 Openvpn 的多设备同时接入功能: 具体如何操作呢?首先,用 ssh 工具登陆你的 Openwrt 软路由。具体的工具及方法可自行搜索,我日常使用的是微软官方发布的 Windows Terminal 终端工具。成功登陆 ssh 后,输入以下命令开始编辑 Openvpn 的配置文件: vim /etc/config/openvpn 如果没能成功打开配置文件的编辑界面,很可能是因为你的 Openwrt 系统没有安装 vim (一款命令行文本编辑器)。至于 vim 的安装方法,还请自行搜索,本文不再赘述。 进入配置文件的编辑界面后,按键盘上的 I 健进入文本编辑模式,将光标移到配置文件末尾,将以下代码复制粘贴到配置文件最后一行。 option duplicate_cn '1' 编辑完成后,按键盘上的 ESC 健,再依次输入以下命令保存并退出编辑器: ...

2021-04-13 · Mason

利用 Docker 搭建 Trilium Notes 服务器

由于平时需要处理大量结构复杂的内容,并且各内容板块间还存在相互交叉的引用关系,因此长久以来我一直在寻找一款既能满足需求,又简洁易用的内容管理工具。印象笔记或 OneNote 等笔记类服务似乎最为常见,但一来,将所有的私人内容存储在商业公司的服务器上总会让我缺乏安全感;二来这些软件要么不够轻便,要么对重要功能额外收费,因此一直都无法让我十分满意。 两年前,我接触到一款叫做 Notion 的跨平台软件,无论是功能还是界面都令我十分满意,但它的价格并不便宜,我毕竟不是靠内容吃饭的职业创作者,无论如何也不愿为一款笔记软件搞月付。另外,Notion 仍然无法实现在牢牢掌控内容数据的同时实现便捷的多端同步,这也是一个不大不小的遗憾。 直到今天,偶然在少数派这篇文章的介绍下了解到一个叫 Trilium 的 Github 开源项目,几乎完美地满足我的所有需求。首先,它是一个开源项目,支持自建笔记服务器,可以让我在牢牢掌控笔记控制权的同时实现多端同步;其次,它界面简洁,非常轻量,甚至可以丢掉客户端,完全实现网页端访问;最后,它完全免费,这点非常重要。 自从买了威联通 NAS 后,我越来越倾向于将自己的各种数据保存在 NAS 上,再通过各类开源软件实现多端同步。这样既能保证数据安全和个人隐私,又能方便地管理自己的文件和数据。用几千元的成本和少许的电费换得对个人数据的完全掌控,我认为是值得的。因此,在意识到 Trilium 提供开源的服务端软件后,我立刻开始本地服务器的搭建工作。 Trilium 的官方文档中提供了通过 Docker 安装 Trilium Server 的具体方式。但由于文档为全英文,且只提供了 SSH 命令安装的方式,一些新手阅读起来可能有些困难,因此本文将以图形化的方式简单陈述 Trilium Server 的安装方式。 首先,在你的 NAS 上安装 Docker 套件(在威联通的 QTS 中叫做 Container Station)并打开它。 进入“创建”,并在搜索框中搜索 Trilium,找到 zadam/trilium,点击右侧的“安装”。 在弹出的创建窗口中,点选“高级设置”,首先在“网络”选项卡中设置 Trilium 的端口转发,trilium 的默认 web 界面默认端口是 8080,因此 Container 的端口必须写 8080,而映射出的主机端口则可以根据自身需求填写。为了记忆方便,我倾向于内外端口一致的设置,即主机端口同样设置成 8080,但如果你的 NAS 的 8080 端口已被其他程序占用,请填写其他端口。 接着,在“共享文件夹”选项卡中,将一个共享文件夹挂在到 Trilium 的容器中。容器中的挂载路径必须写 /trilium-data,而本机共享文件夹则可根据自身需求进行选择,注意挂载共享文件夹的权限必须为读取和写入均有。 上述设置完成后,点击“创建”按钮,系统会自动下载镜像文件并根据你的配置安装容器。容器安装完成后,便可通过在浏览器中输入 NAS IP/端口的方式访问 Trilium 的 web 界面。初次使用 Trilium 时要进行一些简单的初始化设置,例如创建用户名和密码等。虽然界面只有英文,但非常简单,这里不做赘述。 ...

2021-03-20 · Mason

通过群晖与 Openwrt 软路由实现自动端口映射

要在家庭或公司的局域网以外(俗称外网)访问家中或公司内网的设备(例如 NAS),通常有两种方式。第一种方式是在局域网的路由器上架设一个 VPN 服务器,再将外网的终端设备作为 VPN 客户端接入内网。在这种情况下,VPN(虚拟专有网络)充当了网线的角色,即接入 VPN 的外网设备,就相当于拉了一根通往内网的网线。因此在 VPN 网络中,即使这根网线是虚拟的,也能实现如同身处局域网内一般的访问体验。 第二种方法则更为简单直接,即通过动态 DNS 服务将一个域名绑定到局域网服务器的外网 ip,再议端口映射的方式将内网设备暴露在公网中,以供外网设备连接。由于众所周知的原因,我国境内的 VPN 连接并不稳定,因此大多数人都会选择第二种方式进行内网穿透。 在路由器上进行端口映射的操作非常简单。这里以 Openwrt 系统为例,仅需在网络 - 防火墙 - 端口转发中新建转发规则,将相应内网设备的端口映射为外网端口即可。 然而,由于内网设备的内部 ip 地址会随着 DHCP 租约的更新而不断变化,尽管我们可以通过 IP/MAC 绑定的方式人为地固定内网设备的 ip 地址,但实践证明这种方式并不稳定。因此,我们经常需要手动修改端口映射规则,这就使得相关的维护工作变得非常繁琐。如果我们长期在外,无法接入内网环境,上述规则修改的工作就很难进行。这时,我们就需要用到 UPnP(通用即插即用)服务。顾名思义,它是一种自动配置端口映射的工具。只要服务器和内网其他设备同时开启 UPnP 服务并稍加简单的配置,即可一劳永逸地解决端口映射的问题。 以群晖和 Openwrt 系统为例,我们首先需要在 Openwrt 路由器上安装并开启 UPnP 服务。 然后,登陆群晖的管理后台,在控制面板 - 外部访问 - 路由器配置选项卡中,选择“设置路由器”。此时系统会自动检测网络环境以及路由器型号与配置,不出意外的话,整个过程能够由系统自动完成,无须人工配置。之后,点击“新增”按钮,并根据自己的需求选择要转发的应用和端口,再点击“保存”即可。 最后,我们可以回到路由器后台的 UPnP 页面,查看已经被系统自动添加好的端口映射规则。值得注意的是,国内的网络运营商一般会禁用个人和家庭宽带的 443 和 445 端口(前者是 https 的默认端口,后者是 smb 服务的默认端口),因此,即使我们在 UPnP 服务中添加了上述两个端口的自动映射,也无法实现 443 和 445 端口的外网访问。此时,就需要我们在防火墙的端口映射中手动进行端口映射,即将 443 和 445 两个内网端口映射到外网的非 443 或 445 端口(如 444 和 446,全凭个人喜好)。这样,我们才能绕过运营商的封锁,成功进行上述两个端口的外部访问。

2020-09-14 · Mason

利用 NAS、Docker 和 Calibre Web 搭建个人线上书库

经常阅读电子书并且用过 Kindle 的人应该都体会过整理电子书时的痛苦。尤其是像我这种经常下载电子书文件再导入到 Kindle 上进行阅读的人(或是为了省钱、或是因为 Kindle 商城中没有我们想要阅读的书),对于那些有着各自不同的标题、作者、封面,以及文件格式的纷繁复杂的电子书,缺乏一套行之有效的管理方案,进而充分管理自己的阅读进度与时间。 长期以来,PC 和 Mac 端的 Calibre 都是一个差强人意的电子书管理解决方案。它不仅支持多平台、功能强大(支持电子书整理、编辑、格式转换、一键推送到 Kindle 等),而且完全免费。那我为什么要将这么厉害的软件说成是“差强人意”呢?因为 Calibre 已经多年没有较大的功能更新,作为一款电子书管理软件,它已经无法适应当下人们已经习以为常的需求。具体而言,Calibre 具有以下缺点: 界面老旧(或曰古朴?),看起来像是十年前的软件; 启动和运行速度较慢,操作繁琐; 不支持多设备同步,不提供云存储服务(这是最重要的一点)。 对于像我这样学习或工作繁忙,几乎没有固定的整段时间使用同一台终端设备的人来说,多端同步和云存储几乎是不可或缺的功能。而且在网页程序和微信小程序等日益普及的今天,有时连下载一个专门的应用程序都显得繁琐(可能是被这几年的技术进步惯坏了把)。因此,最好有一款类似于 Plex 影视库的电子书管理服务器应用,能够让我随时随地打开一个网页就能管理和阅读自己的电子书。幸运的是,这样的软件确实存在,它便是 Calibre 的继任者—— Calibre Web。 下图就是我用 Calibre Web 在自己的 NAS 上搭建的个人电子书管理网站(或曰个人电子图书馆?)。通过这个网站,我可以轻松地在各种终端设备上上传、修改、整理、推送各种格式的电子书。由于是网页端,因此我不用担心海量电子书会占用手机或电脑的硬盘容量,也不用担心多端同步的问题。更加难能可贵的是,由于 Calibre Web 开发得比较晚近,因此它的界面也很符合当下的主流审美标准。 关于 Calibre Web 的搭建方法,网络上有很多前辈们撰写的教程,他们已经说得非常详细了。首先,你必须拥有一台能够稳定运行的服务器或 NAS(其实任意一台普通电脑都是可以的,只要你舍得让它 7*24 小时运行)。然后,你需要在你的设备上搭建一个 docker 环境,因为 Calibre Web 需要 docker 作为运行的载体。最后,经过简单的安装和配置,你就可以拥有一个属于自己的电子书管理网站了。 这里以群辉为例。首先在“控制面板”中创建一个新的共享文件夹,用于存放 Calibre Web 的数据库和电子书资源。我这里将它命名为"Books"。创建完成后切记要开放该文件夹对所有用户的读写权限,否则 Calibre Web 将无法正常运行。 共享文件夹配置完成后,在群辉的套件中心中选择安装 docker 并打开它。再在“注册表”页面中搜索“Calibre-web”,此处途中框选的三个镜像都可以下载,它们的区别并不大,这里主要推荐 linuxserver/Clibre-web,在双击后弹出的对话框中选择“latest”并点“确定”开始下载。 镜像下载成功后(系统右上角会弹出提示),进入 docker 的“镜像”页面选择刚刚下载好的 linuxserver/Clibre-web 镜像,点击启动。在弹出的对话框中,点击“高级设置”,再按下图所示进行设置即可。 ...

2020-05-12 · Mason