(。•ˇˇ•。)我没能给墨灵过上 4 岁生日。
关闭之际,我想回顾这近 1300 天的历程。
墨灵是 mkplayer 开源项目的改进版,也是我作为计算机初学者的第一个练手的项目。诞生之际,我没想过会有这么多人会去用它。
随着墨灵的长大,它的经历越来越丰富,故事越来越多。
技术回顾
非技术回顾(作者感想)
如果你对墨灵音乐所使用的技术不感兴趣,建议直接点击链接浏览《墨灵音乐给全体用户的一封信》:https://qugeek.com/blog/archives/Work-summary-of-Moling.html#menu_index_20
前端
JS
因为我是菜鸟,所以当时只学会了最基本的 JS,还没接触 Vue 等。没有使用 ES6,因为浏览器兼容(vivo 手机浏览器...)问题。
没用上 worker 、pwa 那些高端玩意。低端玩家,比如我,使用各种小玩意来优化前端性能。不得不叹息一句:WebSQL 普及的真差。
总有人问我,前端 JS 为什么加密?前端加密一定是可解的。接口不希望轻易暴露,加密也只防君子不防小人。事实证明:It worked.
CSS
大量使用动画,使用完善的 Weui 库来支持夜间模式。
我是从 Weui 库的源码中学会如何只使用 CSS 来完成夜间和白天的主题切换。
异常上报
使用 Sentry、frontjs 平台监控。
主要用来防止更新版本后 bug 爆发。
数据统计(埋点)
依次使用了百度统计、Google Analysis、自建程序,最后回到了百度统计。
因为埋点过多,程序无法处理大量的数据导致跑着自建统计程序的服务器屡次阵亡,最后放弃。百度统计比谷歌统计更加清晰;谷歌统计非常细化,只适用于商业化站点。
后端
PHP:因为我是菜鸟,所以当时我只会 PHP
至今还在疑惑 PHP 为何会 503。现在能说得通是肉鸡扫服务器时提交了垃圾数据,程序没有做异常处理,然后。
无数据库:没有使用任何数据库,不是因为我菜,是因为不需要。程序的缓存和大量小文件数据都存放在高效的文件系统中。
唯一遇到的问题就是数据迁移与备份。硬盘中存储了超过 900 万的缓存。初期未预知到文件这么多,导致硬盘 inode 爆满。
![]()
服务
服务器
为了省钱(穷),各种优惠服务器真是能嫖就嫖。
主站、API、鉴权分别部署在三台主机上。服务器指标:高性能高 IO,稳定可靠。
下载服务器部署在若干主机上。服务器指标:低性能、高上传。
前后大大小小的服务器部署了至少也有 50 台左右了。牢记:快照、先备份再操作。
域名
域名前后换了几个。还是 COM 最香。
DNS
用的 DNSPOD 企业基础版。主要用到的是负载均衡功能。
下载是用的一个域名,根据主机权重在 DNS 层面实现负载均衡。这样最简单,但显然这样的负载均衡不是严格按照权重分配的。
CDN
用的腾讯云全球 CDN。特殊时期: CLoudflare Pro 版本。
阿里 CDN 功能过于细分,不适合。腾讯云 CDN 无攻击减免,下图为被攻击惨况。
运行状态
主机监控:阿里云云监控。用于监控全部主机的 CPU 等核心信息。
外部监控:UptimeRobot PRO(一个国外的平台)。用于监控域名、主机、CDN 的外部可通性和可用性。
攻击
这三年,我目睹了:DNS FLOOD 攻击、云服务器 DDOS 攻击、CDN DDOS 攻击、API 接口伪造攻击。
有趣的是,攻击我的人似乎是同一个。没有很好的对付策略,放平心态。
用 PHP 写了一套自己的 IP 评分机制,用来阻止 API 接口攻击。
其他
域名被腾讯封锁:被别人恶意举报,被网友们提交申诉救回来了。是个奇迹,我自己没想到能起死回生。
SSL:因为方便,所以用上了付费证书。因为国内环境,开启了 OCSP。
版本控制
没用上 git 来实现版本控制。
无法追溯 bug 是最头疼的了。
一些数据
跑了:1300 天左右
播放:70 万首歌曲/天(按次、不去重、平均值)
搜索:13 万次/天(按次、不去重、平均值)
Q 群:12 个(后面建不动群了,干脆就把整个群清空再加人)
代码量:除去库,标准格式化后估摸 1 万行吧。感觉没啥意义。
总结
值得被吐槽的地方很多,当然,当时菜鸟的我只能做到这水平了。
如果有机会,肯定会用上最新的技术来写。
每个部分实现起来并不复杂,甚至对于很多大佬来说,too easy 甚至 too low 了。然鹅,完整的跑起来并让它持续地跑是一件相当有挑战的事情。一个人顾及方方面面,确实不易。
维护起来因为平时就很忙所以断断续续的。维护的不连续性也产生了很多麻烦。
现在回看,我觉得最糟糕的是:很多东西没有深入理解或者学习,就用上了。比如 :SSL 原理不懂,就给部署上了。JS、CSS 没系统学,边写边抄是大忌。
下一次的目标
或许有一天我会“卷土重来”。
始终维护旧项目,会让自己的技术落后,一直困在舒适圈里面。
至始至终,代码是一个人在写。所以,都是自己想怎么来就怎么来。
如果有那么一天,我会进行重构。
模块化、组件化、规范化,是下一次的目标。(有感于文章 https://75.team/post/yunpan_refactoring)
非技术总结
墨灵音乐后续(2021 年新春)
墨灵音乐会被我重写一遍代码,然后以全新的形态发布。
功能只增不减,目前计划不公开开放。
在本文章下面认真评论的小伙伴,
届时会收到邀请邮件。(评论时建议填写 QQ 邮箱)
如果你曾经喜欢过墨灵,欢迎留下你的足迹。
新年快乐!
(。・ˇˇ・。) 我没能给墨灵过上 4 岁生日。
关闭之际,我想回顾这近 1300 天的历程。
墨灵是 mkplayer 开源项目的改进版,也是我作为计算机初学者的第一个练手的项目。诞生之际,我没想过会有这么多人会去用它。
随着墨灵的长大,它的经历越来越丰富,故事越来越多。
一、 墨灵刚部署之时起初,我只是当作一个练手程序去做。所以,我的绝大多数时间都是用在“写新功能”(自娱自乐)上。那个时候,更新墨灵是一件非常简单的事情:写代码 → 推送到服务器 → 完成。
二、 小有名气之时当墨灵的用户越来越多的时候,问题随之暴露。
1.第一个阶段添加的新功能,未做浏览器兼容测试,未做细节优化,功能只是处于能用的阶段。一个好的程序的功能应该是“易用的”,而不是“能用的”。随着用户提交的反馈越来越多,墨灵开始细化功能,打磨用户的每一次点击。
2.我发现我也不能再像之前一样更新墨灵,因为我的一次隐藏着 bug 的更新会波及到非常多的用户。所以,更新墨灵变成了一件富有挑战的事情:收集用户反馈、确定要更新的内容 → 编写代码 → 本地多次测试 → 凌晨推送更新 → 线上测试 → 决定是否回滚代码 → 完成。 挺累,但挺好。
三、 初具规模
(╯‵□′)╯︵┴─┴ 当墨灵的用户再翻倍的时候,问题又来了。
① 服务器“爆炸”了。服务器其实没有那么神秘,它和你家的电脑、手机没有本质区别。
服务器爆炸 意味着 服务器太忙 ,当然也意味着 加钱。
② 费用“爆炸”了。买服务器要钱,钱包受伤,这个我就不多言了。
③ 我“爆炸“了。其实,服务器满载,我挺开心的,自己的东西能被人用,谁不开心呢?然而,我发现了不善的访客,他们在恶意消耗服务器资源。墨灵一直没有做登录功能,不是我不能,是我不想。对于用户而言,登录是一种麻烦。对于我而言,登录功能意味着把用户进行分类,或者说我可以选择差异对待用户。这不是墨灵的初衷。因此,每一个用户对于我们来说都是匿名访问。然而,这种”匿名“给我们带来了麻烦,不足 0.1% 的恶意用户消耗着我们 80% 的资源。我花了大量的时间,在尽量避免影响正常用户,不加入登录功能的情况下,去解决这个问题。值得开心的是,这个问题被解决了。遗憾的是,1→ 我投入了大量的精力以至于拖延了整体更新进度。 2→ 这会影响极少数网络环境异常但确实是正常用户的访问。我写了这么长的一段来说这个问题,是有原因的:不仅仅是我,任何网站的开发者,在用户量上升的阶段一定会遇到这个问题。开发者们都非常头痛,用户的不理解往往加剧了这个问题。
墨灵教会我的,也是最重要的:一个程序的功能完整是基础,最最最重要的是功能易用。功能上线前的一次次测试,是为了提高功能的易用性。一个程序的某个功能不能正常运作,不应该是告诉用户“开发者预期的操作过程“,而是程序本身应该足够完善,无论用户做了什么动作,用户都能得到它预期的结果。这就好像,一个好的产品,不需要说明书,无论是傻瓜还是精通的人,无论是老人还是年轻人,都能轻易上手。条条大路通罗马,应该是一个程序设计的准则。当然,这也是墨灵每一次测试的准则。
至于,墨灵为什么关闭,有很多原因,可能你很关心,但是我不太想与你分享。
墨灵音乐后续(2021 年新春)
墨灵音乐会被我重写一遍代码,然后以全新的形态发布。
功能只增不减,目前计划不公开开放。
在本文章下面认真评论的小伙伴,
届时会收到邀请邮件。(评论时建议填写 QQ 邮箱)
如果你曾经喜欢过墨灵,欢迎留下你的足迹。
新年快乐!
· 史蒂芬·平克:“写作之难,在于把网状的思考,用树状的结构,体现在线性展开的语句中”。 · 除明显标注转载的文章外,均为原创。未经同意,禁止任何方式转载、复制、修改后发布。本博客内的所有内容,包括但不限于文字、图片、图表等内容受中华人民共和国《著作权》法和《民法典》的保护,凡未经权利人明确书面授权,转载上述内容均属侵权行为。 · 本博客图片均含有盲水印,文字含有特殊零宽字符,已委托版权卫士保护版权!
加油呀,我以前经常用,现在都没有找到怎么方便的音乐网站了。还是习惯性大概网站看看复活了没呀
支持
期待着下一次的重生,加油@(真棒)
2019年,我无意间在众多网站上找到了这个并不起眼的网站,墨灵。我被它深深吸引,它功能完善,完全免费,是我在所有音乐网站当中我觉得最好最方便的,不用登录,省去了隐私暴露问题,至此,我在这个网站上听歌,下歌 。别的平台上有的,这都有。两年过去了,别的音乐平台陆续倒下了些,终于,墨灵也...现在,又只能回到两年前那样,为了一首歌,翻阅无数网站,也不一定找到。所以,我希望墨灵的制作者能够更加努力,做出比墨灵更加完美的网站。最后,辛苦了,感谢你两年多的陪伴,墨灵,以及你的制作者,谢谢!!!
加油
感谢墨灵音乐的陪伴!感谢作者大大!加油!有你,我才能找到我想要的,音乐路上才不孤单
加油
很感谢你的努力,确实给大家带来很大的方便,虽然我是个白嫖怪(没办法,学生党,家里抓的严一点零花钱都没有),但是衷心的祝福你呀
等待作者重新归来,加油,等你
很喜欢墨灵的便捷,加油,希望作者大大能够浴火重生,冲冲冲
感谢墨灵音乐的陪伴!感谢作者大大!加油!
支持!
支持作者
很喜欢这个网站,对于作者说的这些可谓是是一窍不通,但是,能够看出作者的辛苦付出,还有作者的一步步的成长,三年将近四年的时间,独自一人进行维护和打理,可见辛苦与艰辛。作为浏览者,不论作者是坚持还是放弃,我都无从进行评价。只希望作者能够继续在追梦的道路上勇敢前行。不被世俗所困,勿忘初心!元宵节安康!
期待墨灵以新的形势涅槃重生~~
墨灵是一个很好的音乐网站,我希望在2021年看见一个新的墨灵,届时我也会投资赞助的(虽然金额不是很大)但也是为了共同的墨灵出一份力吧
加油,期待墨灵的归来,很多绝版音乐在这都能找到,属实给力,称之为音乐全库都不为过
还在就好,加油!@(笑眼)
在年前想下载歌曲死活找不到莫灵,翻了三个月的记录,结果还是打不开。以为莫灵凉了,心里还伤心了很长时间,毕竟这是一个真正意义上给予了我快乐的网站。今天用旧手机看书签的时候发现有以前存下了的书签,打开一看,心头一暖,只要没凉就好。@(笑尿)
加油
加油啊!!特别喜欢墨灵音乐!我是一名画师 画画的时候都会开着墨灵,期待你的“卷土重来”!
加油!期待回归!
加油期待墨灵回归!!
@(真棒)
支持
2021,一个全新的开始,我期待墨灵的全新回归
加油哦加油!!!
加油加油,等你回来
去年想要给老妈下载各种广场舞的歌曲,奈何各个音乐软件里都下载不了,通过各种搜索找到了神器——墨灵音乐,所有需要下载的音乐都能下载,真的很感谢墨灵音乐的开发者,希望以后还能有机会用~
加油冲冲冲
加油,我支持你@(大拇指)
很期待
期待一波
支持,等待全新归来!
期待,刚刚才被朋友推荐
小小的网站,大大的惊喜!来一场音乐的盛宴!期待再与墨灵音乐相遇!我们坚信:暂时的离开是为了更好的到来!感谢作者的付出!
期待ing,作者加油呀。支持。
辛苦了
非常期待能再次用到,感觉这次学习的历程也给作者很多成长,停下脚步是为了更好的前行。
加油,非常喜欢墨灵,我会一直支持创作者的
加油,回归。期待新版的上线(玫瑰)
发现墨灵音乐这个平台,真的蛮高兴的,因为它真的好用,也不用登录这么麻烦,真的很为使用者考虑了,我还推荐给了朋友使用。每当我懒得打开音乐软件@(小乖)我就会打开收藏的墨灵音乐的网页,听收藏里的歌,或者搜索一些热歌,抑或是下载几首歌,有时没版权无法播放,是有点遗憾,但想想这网站的运营者也不容易啊,也就没什么情绪了。
当某一天我再次点开这个有段时间没点进去却仍然很熟悉的网站时,却看到了陌生的画面,得知墨灵音乐由于各种原因无法再运营下去了,我觉得特别惋惜,它毕竟曾陪伴过我,虽然也才大概一年多吧,更何况它的功能和使用感都不错。
虽然遗憾墨灵和我们暂时说了再见,但同时我也真切希望在未来的某一天,当我搜索墨灵时,能再一次搜索到你,等到你真正的“卷土重来”。
期待你的回归,还有更强大的功能。加油噢!
期待回归,情怀依旧
加油
太 棒了,加油
非常感谢,你在改变世界,让世界变得更美好!
加油@(玫瑰)
可惜了,期待重逢。很长一段时间内都是用墨灵在线听音乐,界面很简洁美观,还可以导入歌单,登陆个人网易云账号,可以说对于嫌麻烦而选择在网页端听歌的人来讲功能十分契合了。
加油
加油!期待新版本!