百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

爷青回!在NAS上搭建1898 款中文 DOS 游戏合集

wptr33 2025-02-10 14:37 24 浏览

本内容来源于@什么值得买APP,观点仅代表作者本人 |作者:Stark-C



哈喽小伙伴们好,我是Stark-C~

对于和我一样的绝大多数的80后小伙伴来说,如果我没猜错的话,大家的启蒙PC游戏一定是DOS游戏了!

我到现在依稀记得,当初在网吧里整个通宵都乐此不疲的玩着《仙剑奇侠传》以及《金庸群侠传》等各种经典的RPG DOS 游戏,虽然那个时候使用的显示器还是那种大脑袋的老式显示器,貌似分辨率还不足720P,但是说实话,我现在在家里的4K大电视上玩着PS5游戏,也没能体会到当时那种的游戏乐趣。

哎,中年人的悲哀不过如此......致我们逝去的青春~

好在中年男人三件宝:充电头、路由器、NAS,都被我占齐了,特别是NAS,更是我几乎每天必须折腾的宝贝之一。所以,今天的内容就教大家怎么在NAS上使用Docker搭建拥有1898 款 DOS 游戏的游戏库,来重温我们儿时的回忆!

不过需要说明的是:因为1898 款 DOS 游戏的容量大小达到了36GB,这么大的容量先不说做成镜像不太现实,就算可以我们在部署的时候拉取就需要很久的时间,并且还有很大几率拉取失败,所以默认的Docker镜像作者只保留了40多个经典的DOS游戏。

当然,如果有哪位狂热爱好者想把这1898 款 DOS 游戏全部收入囊中,本文也会有相关教程。

话不多说,开干!

部署

今天为大家分享的这个项目的作者估计也是一位曾经 DOS 游戏的狂热爱好者,直接收集了1898 款 DOS 游戏,除了支持在线玩,还可以通过Docker一键部署到我们的NAS上,让我们随时都能体验到 DOS 游戏的乐趣。

部署之前小伙伴们可以先去本项目的在线地址体验一番:

体验网址:https://dos.lol/

部署起来非常的简单,直接使用SSH终端工具连接到NAS之后先改用管理员模式登录,然后输入以下部署的Docker run命令:

docker run -d --name dosgame -p 262:262 oldiy/dosgame-web-docker:latest

部署命令的时候只要端口没问题就可以一键部署,虽说默认的这个容器只有40个游戏,但是可以看到拉取的镜像仍然超过600多兆,好在拉取的速度还不错,几乎是满速,不到一分钟就能全部部署完成。

如果没有问题在NAS的Docker容器列表中就能看到dosgame容器已经正在运行了,说明部署成功。

体验

直接在浏览器中输入 【http:// NAS的局域网IP:端口号】 就能打开dosgame的后台页面了

可以看到小时候玩过的《仙剑奇侠传》《金庸群侠传》都有,还有《轩辕剑》《皇帝》等各种经典DOS游戏,总共40个。

随便启动一个游戏,比如说《仙剑奇侠传》,可以看到估计很多00后的小伙伴从未见过的DOS系统启动画面~

进入游戏的速度还是很快的,支持网页全屏与电脑全屏。就当时的画面水平,在目前最低1080P分辨率的显示下估计有点不容直视,所以建议还是网页全屏吧。

玩起来还是很简单的,玩起来的感觉还是有,当时总找不到那个时候的心情了~

如果说目前搭建容器内的40个游戏就够你玩耍了那么你就不用继续往下看了,如果说你想一网打尽,将1898 款 DOS 游戏全部收入囊中,那么你还得继续往下折腾。

进阶

Snipaste_2024-01-13_09-02-15

我们先通过NAS的文件管理夹新建一个共享文件夹用于存放这1898 款 DOS 游戏。因为这个文件夹除了存放游戏,还有一些配置文件,存档等相关都会在一起,并且稍后还会重新搭建映射到这个文件夹,所以方便起见,我直接把它新建在NAS的Docker文件夹中。我这里演示的是威联通NAS,所以可以看到我是在Container文件夹下面新建了一个dosgame的文件夹。

然后还是需要使用SSH终端工具连接到NAS之后管理员模式登录,然后输入以下Docker run命令:

docker ps -a | grep dosgame

这条命令的意思是列出我们搭建的“dosgame”容器的基本信息,而我们需要的是知道它的ID,也就是它最前面显示的一串字符。

接着继续输入以下命令,将dosgame容器内的内容拷贝到我们前面新建的dosgame文件夹内:

docker cp 0b8b2a96055d:/app/static/games /share/CACHEDEV1_DATA/Container/dosgame

请注意,命令中的以下两项需要根据你自己的实际情况更改:

  • 0b8b2a96055d:就是我们上步查询到的dosgame容器的ID;
  • /share/CACHEDEV1_DATA/Container/dosgame:是你前面新建dosgame文件夹的NAS本地实际路径。

Snipaste_2024-01-14_14-58-39

然后回到NAS中新建的dosgame文件夹,可以看到dosgame容器内的内容已经被成功拷贝过来了,bin文件夹是游戏存放文件夹,all-game-list的文本文档是所有游戏的游戏列表,我们现将all-game-list这个文本文档下载到本地。

打开之后就能看到所有1898 款 DOS 游戏的列表,同时也是每个游戏的下载地址,这个时候直接Ctrl+A全部全选。

然后它里面所有的游戏都会被迅雷识别,并且还可以非常完美的批量下载,下载下来的都是zip压缩包,不用解压。

下载好之后将所有的游戏(zip压缩包)直接拖到NAS文件夹中的bin文件夹,也就是前面说的游戏存放位置。

然后将文件夹内的“1898all-games.json”重命名为“games.json”,可能会和另外一个重命,直接替换即可。

PS:威联通的貌似不支持替换,将另外一个随便改下名就可以了。

接着打开NAS的容器管理套件。这里还是以威联通NAS为例,打开Container Station中的dosgame容器,然后直接点“重新创建”

在创建的时候选择“高级设置”,先做一下端口映射。

接着在存储里面做一个存储卷映射,主机选择我们新建dosgame里面的“game"文件夹路径,容器的路径统一为“/app/static/games”,其它就没什么可修改的,直接保存就完事了~

再次打开容器的Web网页端,拉到最底部,就会有一个“更多游戏”的选项。

点进去之后就能发现1898款游戏了,至此,游戏库搭建完成!

总结

如果你还想继续折腾,还可以将这个容器反代出去,然后在公司里上班还能打开玩玩。当然,我的意思是让你下班时间闲暇之余玩,而不是让你上班摸鱼玩哈!

DOS 游戏在目前这个时代已经是完全落伍了,但是作为我们绝大多数80后的青春还是值得回味一下的,不知道屏幕前面的你在玩这些经典的DOS 游戏会有什么感触,欢迎评论区里来一波回忆杀吧~


好了,以上就是今天给大家分享的内容,我是爱分享的Stark-C,如果今天的内容对你有帮助请记得收藏,顺便点点关注,我会经常给大家分享各类有意思的软件和免费干货,咱们下期再见!谢谢大家~


相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...