js 开发游戏(炫酷丝滑的摸鱼神器!群晖威联通NAS复古游戏模拟器部署教程)

发布时间:2023-11-27 15:34:50 浏览量:213次

炫酷丝滑的摸鱼神器!群晖威联通NAS复古游戏模拟器部署教程

js 开发游戏(炫酷丝滑的摸鱼神器!群晖威联通NAS复古游戏模拟器部署教程)

一年多前写过类似的项目,同样是NAS上通过Docker部署一个网页版游戏模拟器,本次教程使用的容器对比上一篇可以说是全方位升级,页面相当炫酷。

实际游戏操作起来手感丝滑,工作累了打开网页玩两把魂斗罗或者合金弹头就很舒服,堪称摸鱼神器。

下面和大家分享一下群晖、威联通、极空间、华硕/爱速特、绿联及其他Linux系统的合集部署教程,包含支持部署的设备型号推荐,觉得有所帮助欢迎关注点赞收藏三连哈。

细节比较多,有些特殊设置需要注意,遇到问题善用浏览器的搜索功能(Ctrl+F)。

本次使用的是容器是基于RetroArch的emulatorjs,作者为Ryan Kuba,Linuxserver.io托管,项目地址:

https://registry.hub.docker.com/r/linuxserver/emulatorjs

这款模拟器除了开头展示的页面炫酷和丝滑操作以外,最大的特点就是非常棒的平台和ROM管理功能,支持以下主机平台:

3do、arcade、atari2600、atari7800、colecovision、doom、gb、gba、gbc、jaguar、lynx、msx、n64、nds、nes、ngp、odyssey2、pce、psx、sega32x、segaCD、segaGG、segaMD、segaMS、segaSaturn、segaSG、snes、vb、vectrex、ws

emulatorjs这个项目可以部署在几乎所有主流设备上,支持X86(64位)和ARM架构(32位和64位)平台设备,MIPS和RISC-V的路由器就暂时别想了哈。

先放一下个人修改的基础代码(docker cli规则),默认的游戏端口用的是80,国内大部分网络并没有开放80端口,这里我用8499作为替代,大家可以按需修改后用SSH部署:

docker run -d \

--name=emulatorjs \

-p 3000:3000 \

-p 8499:80 \

-v /目标挂载文件夹:/config \

-v /目标挂载文件夹:/data \

--restart unless-stopped \

lscr.io/linuxserver/emulatorjs:latest

由于不需要调用其他驱动,这里用的是群晖自带管理器部署,对新手来说更简单明了一些。

1️⃣ 适配设备

群晖的ARM设备说实话比较磕碜,虽然支持Docker功能,但一般都是512M的板载内存,确实玩不顺,不建议部署。

DS220+、DS420+和DS920+这些只要是4G以上内存都可以玩起来,X86架构的黑群晖当然也是没问题的。

2️⃣ 查看IP

进入控制面板的网络,点击网络,下图圈出来的3就是这台群晖的IP:

192.168.0.205

3️⃣ 实操流程

进入Docker管理器后,点击注册表搜索linuxserver/emulatorjs,只有一个结果,双击下载镜像,标签用默认的latest。

下载完成后双击镜像开始创建容器,这里由于需要将容器的80端口转发到宿主的8499端口,所以网络选择bridge。

PS:如果没有公网IPv4的朋友想外网使用,上Zerotier或者蒲公英组SD-WAN吧。

容器名称想改就改,勾选上使用高权限执行容器后,点击高级设置。

新增两个端口转发规则:

本地端口3000对应容器端口3000

本地端口8499对应容器端口80

下一步点击添加文件夹:

在docker这个共享文件夹下面创建一个名为emulatorjs的子文件夹

在emulatorjs这个子文件夹下面创建两个子文件夹,分别命名为config和data

文件夹新建完成后创建两个文件夹挂载关系:

刚才新建的/docker/emulatorjs/config装载路径填写/config

刚才新建的/docker/emulatorjs/data装载路径填写/data

全部确认无误后点击完成,开始创建容器。

创建完成后在容器页面可以看到运行状态,接下来请跳转到“使用丨上传管理”部分。

和群晖理由一样,新手用自带的ContainerStation部署比较简单。

1️⃣ 适配设备

威联通现在有使用RK3568平台的ARM架构型号,TS-216和TS-416无论是CPU还是内存都足够运行emulatorjs,四核硬参数在这儿,个人建议入手TS-416,毕竟4G内存。


使用Intel JasperLake的TS-264C、TS-464C和TS-564就更没问题了,X86架构使用起来更爽,毕竟内存是正常的卡槽,完全不用担心OOM。

2️⃣ 查看IP

进入网络与虚拟交换机,下图圈出来的就是这台威联通的IP:

10.168.1.102

3️⃣ 实操流程

第一步需要创建用于挂载配置文件+ROM的文件夹,进入FileStation后:

Container共享文件夹下创建一个名为emulatorjs的子文件夹

emulatorjs子文件夹下创建两个子文件夹,分别命名为config和data

第二步进入ContainerStation,点击创建搜索emulatorjs,第一个结果点击安装,镜像版本用默认的latest。

进入配置后点击网络,新增两个转发规则:

主机端口3000对应Container端口3000

主机端口8499对应Container端口80

点击共享文件夹,新增两组挂载关系:

刚才新建的
/Container/emulatorjs/config装载路径填写/config

刚才新建的
/Container/emulatorjs/data装载路径填写/data

确认无误后点击确认,开始下载镜像并自动部署容器。

创建完成后在总览页面可以看到运行状态,接下来请跳转到“使用丨上传管理”部分。

由于极空间并没有开放SSH,所以只能走自带管理器操作。

1️⃣ 适配设备

极空间的产品经理思路是求稳,ARM架构的老Z2和Q2并没有开放Docker功能,ARM架构只有Z2S(4G内存)可以部署。

X86架构的Z4、Z4S和Z4S旗舰版均可以部署,完全没有问题,不过极空间并没有送DDNS服务也没有开启TUN功能做不了SD-WAN,所以外网使用建议买个蒲公英X1(无需公网IP,文末放了连接)或者用DDNS-Go搭配域名(需有公网IP)使用。

2️⃣ 查看IP

进入系统设置的网络相关设置,下图圈出来的就是这台极空间的IP:

10.168.1.197

3️⃣ 实操流程

第一步需要创建用于挂载配置文件+ROM的文件夹,进入个人空间后:

创建一个名为emulatorjs的子文件夹

emulatorjs子文件夹下创建两个子文件夹,分别命名为config和data

右键这三个文件夹,设置为共享

第二步进入Docker管理器的镜像,仓库中搜索emulatorjs,第一个结果点击安装,镜像版本用默认的latest。

镜像下载完成后会自动跳转到本地镜像管理页面,选中emulatorjs镜像,点击添加到容器。

第三步开始创建容器,先取消性能限制的勾选。

点击文件夹路径,添加两组挂载关系:

刚才新建的/我的文件/Docker/emulatorjs/config装载路径填写/config

刚才新建的/我的文件/Docker/emulatorjs/data装载路径填写/data

进入配置后点击网络,新增两个转发规则:

本地端口3010对应容器端口3000(3000不知道被啥占用了,需要改成3010)

本地端口8499对应容器端口80

确认无误后点击应用,开始部署容器。

创建完成后在总览页面可以看到运行状态,接下来请跳转到“使用丨上传管理”部分。

ADM系统自带的容器管理器Portainer非常好用,这里就用它作为演示。

1️⃣ 适配设备

华硕(爱速特)不管是ARM还是X86架构,生态都基于Docker,所以部署当然是没问题啦,最近新款AS67系列也要上架了,感兴趣的话可以关注一下NAS圈为数不多带显示屏的系列。

2️⃣ 查看IP

js 开发游戏(炫酷丝滑的摸鱼神器!群晖威联通NAS复古游戏模拟器部署教程)

进入偏好设定的网络,下图圈出来的就是这台华硕的IP:

192.168.0.194

3️⃣ 实操流程

第一步需要创建用于挂载配置文件+ROM的文件夹,进入文件总管后:

Docker共享文件夹下创建一个名为emulatorjs的子文件夹

emulatorjs子文件夹下创建两个子文件夹,分别命名为config和data

右键config文件夹点击属性,这里可以看到config文件夹所在路径是:

/volume1/Docker/emulatorjs

所以config这个文件夹的完整路径应该是:

/volume1/Docker/emulatorjs/config

同理data文件夹的完整路径应该是:

/volume1/Docker/emulatorjs/data

第二步打开Portainer,跳转到管理页面登录,准备开始部署。

点击Container进入容器管理页面,单击Add container。

第三步填写镜像,注意看图和文字说明:

Name填写emulatorjs

image填写linuxserver/emulatorjs

第四步配置端口,新增两个转发规则:

host端口3000对应Container端口3000

host端口8499对应Container端口80

第四步配置文件夹,下拉到底部:

点击Volumes的map additional volume创建两个挂载关系

将默认的Volume改成Bind

新增两组挂载关系:

container填写/config,host填写刚创建的
/volume1/Docker/emulatorjs/config

container填写/data,host填写刚创建的
/volume1/Docker/emulatorjs/data

确认无误后点击Deploy the container,开始下载镜像并自动部署容器。

创建完成后会跳转到容器管理页面,这里可以看到运行状态,接下来请跳转到“使用丨上传管理”部分。

和极空间一样,绿联没有SSH功能,只能用自带管理器部署。

1️⃣ 适配设备

绿联目前有两款NAS(DH2100和DH2600),只有DH2600有Docker功能,所以想玩的话就入手DH2600。

2️⃣ 查看IP

点击绿联客户端左下角设备的设备管理,下图圈出来的就是这台绿联DH2600的IP:

10.163.1.179

3️⃣ 实操流程

第一步需要创建用于挂载配置文件+ROM的文件夹,进入FileStation后:

Container共享文件夹下创建一个名为emulatorjs的子文件夹

emulatorjs子文件夹下创建两个子文件夹,分别命名为config和data

第二步进入Docker管理器的镜像管理,搜索emulatorjs,第一个结果点击安装,镜像版本用默认的latest。

下载完成后点击本地镜像,双击emulatorjs的镜像开始创建,勾选下创建后启动容器。

点击存储空间,添加两组挂载关系:

刚才新建的config装载路径填写/config

刚才新建的data装载路径填写/data

进入配置后点击网络,新增两个转发规则:

本地端口3000对应容器端口3000

本地端口8499对应容器端口80

确认无误后点击确认,开始下载镜像并自动部署容器。

创建完成后在容器管理可以看到运行状态,接下来请跳转到“使用丨上传管理”部分。

除了NAS以外,理论上所有Linux系设备都可以部署,只要CPU架构是X86和ARM即可。

1️⃣ 适配设备

根据项目说明,latest标签的镜像是自适应的,ARM设备也不需要改标签,正常按照下面部署就行。

如果想要一个比较开放的NAS,可以考虑万由的HS系列,目前系统基本就是NAS专享版本的Debian,开放度非常高,下文也是用的万由401p作为案例演示。

瑞芯微RK系列和树莓派系列开发板理论上也是可以的,自己部署下docker本体即可。

2️⃣ 查看IP

用Linux的都能自己搞定吧?ifconfig命令看下就知道了。

3️⃣ 实操流程

先用su账号SSH登录,安装docker cli:

curl -sSL https://get.daocloud.io/docker | sh

输入下面代码回车即可(目标挂载文件夹记得换一下):

docker run -d \

--name=emulatorjs \

-p 3000:3000 \

-p 8499:80 \

-v /目标挂载文件夹:/config \

-v /目标挂载文件夹:/data \

--restart unless-stopped \

linuxserver/emulatorjs:latest

等上面命令执行完成后,用docker ps命令看下状态即可,接下来请跳转到“使用丨上传管理”部分。

emulatorjs一共有两个网页后台:

端口号3000对应的是文件管理(本文的极空间是3010)

端口号8499对应的是游戏页面

管理页面访问方式就是NAS的IP加上端口号,比如我这里的就是浏览器输入:

192.168.195.180:3000

进入后提示需要先创建默认文件系统,点击下图的Download。

这时候不要急,等待出现Downloaded All Files后,再点击右上角的黑点关闭下载详情,刷新下网页。

之后点击File Management,左侧是预设好的不同主机文件夹,点击想要上传的主机分类,将ROM上传到roms文件夹。

具体上传时间由电脑和NAS的网速决定,一般很快,毕竟这些主机游戏文件都不大。

上传完毕后点击Rom Management,左上方会提示Scan(扫描),点击执行。

扫描完成后同样点击黑块关闭日志。

之后进入对应平台,点击add all rom to config,将新增ROM添加到列表。

后续如果有更新或者修改,点击Default的DL/Update即可下载最新的配置文件。

先说下遇到的问题,上传新ROM后可能网页会不显示,清除下浏览器缓存即可破之,建议把ROM一起上传完后再操作。

游戏页面访问方式同样是NAS的IP加上端口号,比如我这里的就是浏览器输入:

192.168.195.180:8499

键盘的方向键就是方向,z和x是ab键,回车是start键,k是暂停,自己试一下就知道了。

值得一提的是部分游戏会崩溃,PS平台我拿战神测试会程序崩溃,NES和GBA没问题,等后续优化吧。

既然是摸鱼,外网访问肯定是刚需,这里说一下常见访问方式。

1️⃣ 群晖/威联通/华硕(爱速特)

这三家都送了DDNS(域名解析),如果有IPv4的公网IP,外网用域名加端口号的方式访问即可。

如果没有IPv4的公网IP就比较麻烦了,Linux5.10核心的大版本更新之后这三家的虚拟交换机都有问题,没办法走IPv6将Docker端口转发到宿主机上,emulatorjs目前还不支持自定义游戏页面端口,所以走Host也行不通。

替代方案就是做SD-WAN,免费蒲公英(限三台)和Zerotier(可能不稳定)的部署教程之前写过,感兴趣可以去看看。

如果家中设备比较多想一起组网,也可以选择直接购买蒲公英的X1或者X3A组网路由器,用着方便点。

2️⃣ 极空间/绿联

这两家的NAS的定位都是轻NAS,能客户端访问自然也不会送DDNS服务,如果有公网IP,可以路由器开启UPnP,之后通过IP加端口号的方式直接访问。

即使你没有IPv4的公网IP也没关系,亲测是可以直接通过IPv6的公网IP加端口号使用emulatorjs,IPv6的地址规则和v4不同,格式如下(符号一定是英文符号):

[NAS的ip]:8499

提醒:访问端电脑和NAS均需要有IPv6的公网IP,不然访问不了。

极空间查看IPv6的方法上文说过了不再赘述,绿联比较奇怪,没有入口显示IPv6的IP(实际上设备能拿到),只能通过路由器后台查看。

PS:你要觉得麻烦,直接上贝锐的蒲公英吧,花钱能解决的问题都不算问题。

js 开发游戏(炫酷丝滑的摸鱼神器!群晖威联通NAS复古游戏模拟器部署教程)

热门课程推荐

热门资讯

请绑定手机号

x
确定