Compare commits

..

No commits in common. "master" and "AR-Backup-2025.09.03" have entirely different histories.

42 changed files with 576 additions and 2048 deletions

View File

@ -1,16 +0,0 @@
# Required
version: 2
build:
os: ubuntu-24.04
tools:
ruby: "3.3"
commands:
- gem install bundler
- bundle install
- mkdir Mabbs
- curl -L -o Mabbs/README.md https://github.com/Mabbs/Mabbs/raw/main/README.md
- bundle exec jekyll build --destination $READTHEDOCS_OUTPUT/html
- tar czvf MayxBlog.tgz -C $READTHEDOCS_OUTPUT html
- mv MayxBlog.tgz $READTHEDOCS_OUTPUT/html

View File

@ -14,7 +14,4 @@ group :jekyll_plugins do
gem "jekyll-paginate", "~> 1.1.0"
gem "kramdown-parser-gfm", "~> 1.1.0"
gem "kramdown", "~> 2.3.2"
gem "csv"
gem "base64"
gem "bigdecimal"
end

View File

@ -22,8 +22,6 @@ if (!norunFlag) {
var sleepTimer_ = null;
var AITalkFlag = false;
var talkNum = 0;
// 暴露到全局,供 pjax.js 在页面切换后重新调用
window._live2d = { initTips: null, showMessage: null, showHitokoto: null };
(function () {
function renderTip(template, context) {
var tokenReg = /(\\)?\{([^\{\}\\]+)(\\)?\}/g;
@ -35,11 +33,11 @@ if (!norunFlag) {
var currentObject = context;
var i, length, variable;
for (i = 0, length = variables.length; i < length; ++i) {
variable = currentObject[variables[i]];
if (variable === undefined || variable === null) return '';
currentObject = variable;
variable = variables[i];
currentObject = currentObject[variable];
if (currentObject === undefined || currentObject === null) return '';
}
return String(currentObject);
return currentObject;
});
}
@ -58,20 +56,14 @@ if (!norunFlag) {
showMessage('你都复制了些什么呀,转载要记得加上出处哦~~', 5000);
});
// 缓存 message.json 数据,供 PJAX 重绑定使用
var tipsData = null;
function initTips() {
$.ajax({
cache: true,
url: message_Path + 'message.json',
dataType: "json",
success: function (result) {
tipsData = result;
// 解绑旧事件(用命名空间避免影响其他绑定)
$.each(result.mouseover, function (index, tips) {
$(tips.selector).off('mouseover._live2d_tips mouseout._live2d_tips');
$(tips.selector).on('mouseover._live2d_tips', function () {
$(tips.selector).mouseover(function () {
var text = tips.text;
if (Array.isArray(tips.text)) text = tips.text[Math.floor(Math.random() * tips.text.length + 1) - 1];
text = text.renderTip({ text: $(this).text() });
@ -80,7 +72,7 @@ if (!norunFlag) {
clearInterval(liveTlakTimer);
liveTlakTimer = null;
});
$(tips.selector).on('mouseout._live2d_tips', function () {
$(tips.selector).mouseout(function () {
showHitokoto();
if (liveTlakTimer == null) {
liveTlakTimer = window.setInterval(function () {
@ -90,8 +82,7 @@ if (!norunFlag) {
});
});
$.each(result.click, function (index, tips) {
$(tips.selector).off('click._live2d_tips');
$(tips.selector).on('click._live2d_tips', function () {
$(tips.selector).click(function () {
if (hitFlag) {
return false
}
@ -115,22 +106,46 @@ if (!norunFlag) {
}
});
}
window._live2d.initTips = initTips;
initTips();
var text;
if (document.referrer !== '' && document.referrer.split('/')[2] !== window.location.host) {
var referrer = document.createElement('a');
referrer.href = document.referrer;
var domain = referrer.hostname.split('.')[1];
if (domain == 'baidu' || domain == 'so' || domain == 'google') {
var source = domain == 'baidu' ? '百度搜索' : domain == 'so' ? '360搜索' : '谷歌搜索';
text = '嗨! 来自 ' + source + ' 的朋友!<br>欢迎访问<span style="color:#0099cc;">「 ' + document.title.split(' | ')[0] + ' 」</span>';
} else {
text = '嗨!来自 <span style="color:#0099cc;">' + referrer.hostname + '</span> 的朋友!';
var domain = referrer.hostname.split('.')[1];
if (domain == 'baidu') {
text = '嗨! 来自 百度搜索 的朋友!<br>欢迎访问<span style="color:#0099cc;">「 ' + document.title.split(' | ')[0] + ' 」</span>';
} else if (domain == 'so') {
text = '嗨! 来自 360搜索 的朋友!<br>欢迎访问<span style="color:#0099cc;">「 ' + document.title.split(' | ')[0] + ' 」</span>';
} else if (domain == 'google') {
text = '嗨! 来自 谷歌搜索 的朋友!<br>欢迎访问<span style="color:#0099cc;">「 ' + document.title.split(' | ')[0] + ' 」</span>';
}
} else {
text = getWelcomeText();
if (window.location.pathname == "/") { //主页URL判断需要斜杠结尾
var now = (new Date()).getHours();
if (now > 23 || now <= 5) {
text = '你是夜猫子呀?这么晚还不睡觉,明天起的来嘛?';
} else if (now > 5 && now <= 7) {
text = '早上好!一日之计在于晨,美好的一天就要开始了!';
} else if (now > 7 && now <= 11) {
text = '上午好!工作顺利嘛,不要久坐,多起来走动走动哦!';
} else if (now > 11 && now <= 14) {
text = '中午了,工作了一个上午,现在是午餐时间!';
} else if (now > 14 && now <= 17) {
text = '午后很容易犯困呢,今天的运动目标完成了吗?';
} else if (now > 17 && now <= 19) {
text = '傍晚了!窗外夕阳的景色很美丽呢,最美不过夕阳红~~';
} else if (now > 19 && now <= 21) {
text = '晚上好,今天过得怎么样?';
} else if (now > 21 && now <= 23) {
text = '已经这么晚了呀,早点休息吧,晚安~~';
} else {
text = '嗨~ 快来逗我玩吧!';
}
} else {
text = '欢迎阅读<span style="color:#0099cc;">「 ' + document.title.split(' | ')[0] + ' 」</span>';
}
}
showMessage(text, 12000);
})();
@ -157,7 +172,6 @@ if (!norunFlag) {
console.log(sleepTimer_);
}
}
window._live2d.showHitokoto = showHitokoto;
function checkSleep() {
var sleepStatu = sessionStorage.getItem("Sleepy");
@ -187,11 +201,9 @@ if (!norunFlag) {
eventFlag = true;
}
var data = JSON.parse(event.data);
if (data.response) {
outputContainer.textContent += data.response;
}
}
}
} else {
$('.message').html(text);
}
@ -199,7 +211,6 @@ if (!norunFlag) {
//if (timeout === null) timeout = 5000;
//hideMessage(timeout);
}
window._live2d.showMessage = showMessage;
function talkValTimer() {
$('#live_talk').val('1');
}
@ -371,100 +382,74 @@ if (!norunFlag) {
};
};
//获取音乐信息初始化
var $bgm = $('#live2d_bgm');
// 音乐按钮点击事件(幂等,使用命名空间避免重复绑定)
$('#musicButton').off('click._bgm').on('click._bgm', function () {
var bgmListInfo = $('input[name=live2dBGM]');
if (bgmListInfo.length == 0) {
$('#musicButton').hide();
} else {
var bgmPlayNow = parseInt($('#live2d_bgm').attr('data-bgm'));
var bgmPlayTime = 0;
var live2dBGM_Num = sessionStorage.getItem("live2dBGM_Num");
var live2dBGM_PlayTime = sessionStorage.getItem("live2dBGM_PlayTime");
if (live2dBGM_Num) {
if (live2dBGM_Num <= $('input[name=live2dBGM]').length - 1) {
bgmPlayNow = parseInt(live2dBGM_Num);
}
}
if (live2dBGM_PlayTime) {
bgmPlayTime = parseInt(live2dBGM_PlayTime);
}
var live2dBGMSrc = bgmListInfo.eq(bgmPlayNow).val();
$('#live2d_bgm').attr('data-bgm', bgmPlayNow);
$('#live2d_bgm').attr('src', live2dBGMSrc);
$('#live2d_bgm')[0].currentTime = bgmPlayTime;
$('#live2d_bgm')[0].volume = 0.5;
var live2dBGM_IsPlay = sessionStorage.getItem("live2dBGM_IsPlay");
var live2dBGM_WindowClose = sessionStorage.getItem("live2dBGM_WindowClose");
if (live2dBGM_IsPlay == '0' && live2dBGM_WindowClose == '0') {
$('#live2d_bgm')[0].play();
$('#musicButton').addClass('play');
}
sessionStorage.setItem("live2dBGM_WindowClose", '1');
$('#musicButton').on('click', function () {
if ($('#musicButton').hasClass('play')) {
$bgm[0].pause();
$('#live2d_bgm')[0].pause();
$('#musicButton').removeClass('play');
sessionStorage.setItem("live2dBGM_IsPlay", '1');
} else {
$bgm[0].play();
$('#live2d_bgm')[0].play();
$('#musicButton').addClass('play');
sessionStorage.setItem("live2dBGM_IsPlay", '0');
}
});
// BGM 事件监听(仅绑定一次,使用标志位避免重复)
if (!window._live2d._bgmEventsBound) {
$bgm[0].addEventListener("timeupdate", function () {
sessionStorage.setItem("live2dBGM_PlayTime", $bgm[0].currentTime);
});
$bgm[0].addEventListener("ended", function () {
var listNow = parseInt($bgm.attr('data-bgm'));
listNow++;
var inputs = $('input[name=live2dBGM]');
if (inputs.length === 0) return;
if (listNow > inputs.length - 1) {
listNow = 0;
}
var listNewSrc = inputs.eq(listNow).val();
if (!listNewSrc) return;
sessionStorage.setItem("live2dBGM_Num", listNow);
$bgm.attr('src', listNewSrc);
$bgm[0].play();
$bgm.attr('data-bgm', listNow);
});
$bgm[0].addEventListener("error", function () {
$bgm[0].pause();
$('#musicButton').removeClass('play');
showMessage('音乐似乎加载不出来了呢!', 0);
});
window.onbeforeunload = function () {
sessionStorage.setItem("live2dBGM_WindowClose", '0');
if ($('#musicButton').hasClass('play')) {
sessionStorage.setItem("live2dBGM_IsPlay", '0');
}
};
window._live2d._bgmEventsBound = true;
}
// 初始化 BGM根据当前页面是否有 BGM 输入)
if (typeof window._live2d.initBGM === 'function') {
window._live2d.initBGM();
document.getElementById('live2d_bgm').addEventListener("timeupdate", function () {
var live2dBgmPlayTimeNow = document.getElementById('live2d_bgm').currentTime;
sessionStorage.setItem("live2dBGM_PlayTime", live2dBgmPlayTimeNow);
});
document.getElementById('live2d_bgm').addEventListener("ended", function () {
var listNow = parseInt($('#live2d_bgm').attr('data-bgm'));
listNow++;
if (listNow > $('input[name=live2dBGM]').length - 1) {
listNow = 0;
}
var listNewSrc = $('input[name=live2dBGM]').eq(listNow).val();
sessionStorage.setItem("live2dBGM_Num", listNow);
$('#live2d_bgm').attr('src', listNewSrc);
$('#live2d_bgm')[0].play();
$('#live2d_bgm').attr('data-bgm', listNow);
});
document.getElementById('live2d_bgm').addEventListener("error", function () {
$('#live2d_bgm')[0].pause();
$('#musicButton').removeClass('play');
showMessage('音乐似乎加载不出来了呢!', 0);
});
}
}
// 暴露 BGM 初始化函数,供 PJAX 重初始化时调用
window._live2d.initBGM = function() {
var bgmListInfo = $('input[name=live2dBGM]');
var $bgm = $('#live2d_bgm');
if (bgmListInfo.length === 0) {
$('#musicButton').hide();
if ($bgm.length) $bgm[0].pause();
return;
}
var bgmPlayNow = parseInt($bgm.attr('data-bgm')) || 0;
var bgmPlayTime = 0;
var live2dBGM_Num = sessionStorage.getItem("live2dBGM_Num");
var live2dBGM_PlayTime = sessionStorage.getItem("live2dBGM_PlayTime");
if (live2dBGM_Num) {
if (parseInt(live2dBGM_Num) <= bgmListInfo.length - 1) {
bgmPlayNow = parseInt(live2dBGM_Num);
}
}
if (live2dBGM_PlayTime) {
bgmPlayTime = parseFloat(live2dBGM_PlayTime);
}
var newSrc = bgmListInfo.eq(bgmPlayNow).val();
$bgm.attr('data-bgm', bgmPlayNow);
if ($bgm.attr('src') !== newSrc) {
$bgm[0].pause();
$bgm.attr('src', newSrc);
$bgm[0].currentTime = bgmPlayTime;
}
$bgm[0].volume = 0.5;
var live2dBGM_IsPlay = sessionStorage.getItem("live2dBGM_IsPlay");
var live2dBGM_WindowClose = sessionStorage.getItem("live2dBGM_WindowClose");
if (live2dBGM_IsPlay == '0' && live2dBGM_WindowClose == '0') {
$bgm[0].play();
$('#musicButton').addClass('play');
}
sessionStorage.setItem("live2dBGM_WindowClose", '1');
$('#musicButton').show();
};
$(document).ready(function () {
var AIimgSrc = [
message_Path + "model/histoire/histoire.1024/texture_00.png",

View File

@ -50,4 +50,4 @@ Powered by [Jekyll](https://github.com/jekyll/jekyll)
本站转载的文章如无特别说明,均按原文章的协议执行
## 打赏/赞助 Mayx
![QRCode](images/QRCode.png)
![QRCode](/images/QRCode.png)

View File

@ -169,13 +169,5 @@
"/2025/07/24/screenshot.html": "这篇文章介绍了如何利用Cloudflare的“浏览器呈现”功能创建一个自动更新的网站预览图服务。作者发现这个新功能可以用来展示网站在不同设备上的显示效果通过在Cloudflare Workers中使用iframe和CSS缩放技术以及调用Cloudflare的接口抓取浏览器渲染的截图。虽然免费用户每天只有10分钟的使用时间限制了实时更新但作者通过缓存实现了每天自动更新一次的预览图并分享了具体的实现代码和使用方法。作者赞赏Cloudflare提供的这项强大且免费的服务。",
"/2025/08/01/sw-proxy.html": "这篇文章介绍了作者如何利用Service Worker在现代浏览器中实现一个简单的反向代理功能以提供博客的备份和离线访问。作者原本希望通过Service Worker在用户浏览器中运行一个Web服务器来存储博客副本但发现 tar.gz 文件的处理需要第三方库且难以找到适用的解决方案尤其是对于tar文件的处理。作者最终选择使用Service Worker作为反向代理将请求转发到其他网站如GeoCities风格的静态网站托管平台实现了类似的效果。这个过程中作者体验到了浏览器功能的强大并认为Service Worker在离线场景中有更大的潜力尽管在他的例子中并没有充分展示这种优势。",
"/2025/08/10/tilde.html": "这篇文章介绍了作者在Tilde社区的体验这是一类基于类Unix环境的公共服务器社区类似于家目录提供预装的软件、开发环境和公共服务如聊天室、邮件、BBS论坛等强调了社区的互动性和共享精神。作者通过申请、审核过程加入了几个社区并详细描述了在这些社区中的个人主页、编程支持如Gemini和Gopher协议、博客发布、代码托管Git支持、CI/CD部署以及使用Git hooks自动化博客更新等功能。尽管作者受限于语言和工具使用体验未能充分参与社区交流但对社区学习新知识和丰富博客内容印象深刻。",
"/2025/09/01/quine.html": "这篇文章主要介绍了作者在博客部署过程中对ZIP Quine自包含压缩包和自产生程序的探索过程。作者起初想利用压缩包实现离线浏览但遇到了压缩包不包含自身的问题。随后作者回顾了ZIP Quine的原理如droste.zip以及如何通过DEFLATE压缩算法的LZ77编码实现自包含。作者尝试了Russ Cox的方案但发现由于压缩格式限制实际操作中存在数据容量的限制无法存下整个博客。尽管如此作者还是研究了嵌套循环的ZIP Quine如Ruben Van Mello的论文中所描述的尽管空间仍然有限。探索过程中作者还学习了自产生程序Quine的概念包括其实现原理和各种编程语言中的例子。作者最后感慨探索过程中的收获比原本的目标更重要。",
"/2025/10/12/recover.html": "这篇文章讲述了作者通过GitHub的Fork特性找回一个被删除的Brainfuck可视化演示仓库的经历。由于原仓库和作者主页都已消失作者推测GitHub在Fork时会共享对象库只要有任意一个Fork仓库存在GitHub就会保留所有对象从而可以通过找到一个Fork仓库的最新提交Hash值来还原目标仓库。作者通过Linux内核仓库的Fork进行验证随后在互联网档案馆上找到目标仓库的Fork以及其Hash值最终通过Git命令将本地仓库的HEAD指针指向目标提交成功恢复了该仓库的代码并将其部署到自己的GitHub Pages上。最后作者发现Software Heritage组织会保存所有代码因此在遇到类似情况时可以直接通过该平台进行查找。",
"/2025/11/01/mirrors.html": "这篇文章讲述了作者为了提高博客的可靠性探索利用被滥用的Git平台进行博客镜像的想法和实践。作者发现一些Git实例存在大量空仓库和异常用户怀疑是SEO公司滥用因此决定利用这些平台进行博客镜像备份以应对平台倒闭或数据丢失的风险。作者选择Gitea和Forgejo平台作为目标编写脚本自动注册账号并导入博客仓库实现了自动化镜像分发。作者也意识到此类平台的稳定性存在不确定性并思考了“量”和“质”两种方式确保博客永恒性的优劣最终认为建立一个活跃的、自动执行维护操作的网络可能更有效。文章最后展示了作者创建的Git镜像列表并表达了对博客永恒性的思考。",
"/2025/12/01/linux.html": "这篇文章介绍了在浏览器中运行Linux的各种方法从最初的纯JS虚拟机JSLinux到后来的WASM虚拟机如v86、WebVM、WebCM再到容器化方案container2wasm以及直接将Linux内核编译为WASM的方案。作者详细对比了这些方案的优缺点包括性能、兼容性、功能和开发难度。文章还提到了模仿Linux环境的WebContainers和JupyterLite并最终认为虚拟机方案更靠谱但对WASM的未来充满期待。作者最后表示博客上添加类似功能的计划还在考虑中目前主要分享了各种方法的探索过程。",
"/2026/01/01/summary.html": "这篇文章介绍了作者对2025年的年终总结主要表达了对自身状态的担忧和对未来的不确定感。作者认为自己在记忆和思考能力方面有所下滑稳定性较低且未能抓住资产保值的机会。同时文章也记录了AI技术的飞速发展以及自己博客内容与时代脱节的现象。尽管对未来感到迷茫作者仍然抱有一丝希望期望在2026年做出正确的选择避免陷入危险。",
"/2026/02/08/xslt.html": "这篇文章讲述了Google计划弃用XSLT技术以及作者对这一决定的调查和应对方案。Google基于XSLT用户占比低、库存在漏洞等原因建议将其从Web标准中删除。作者发现许多用户依赖XSLT进行博客订阅美化甚至将其作为博客框架。为了对抗这一趋势有人创建了网站https://xslt.rip并开发了Polyfill库通过WASM方式保持XSLT功能。虽然Polyfill库需要额外引用JS代码但作者已将其提交至CDNJS。随后作者探讨了替代方案包括使用纯CSS美化订阅源由AI生成feed.css以及混合XHTML的方式通过添加XHTML命名空间来实现链接等功能但这种方法会产生“不纯粹”的警告。文章最后总结技术可能会消失但总有其他技术可以解决问题并强调了适应浏览器厂商决策的重要性。",
"/2026/03/01/llm3.html": "这篇文章介绍了作者近期在LLM部署和应用方面的经历主要包括以下几个方面\n\n首先作者升级硬件从单张RTX4090 48GiB升级到双路RTX4090 48GiB并购买了TRX40+TR 3960X的主板套装用于运行GPT-OSS模型。随后作者尝试使用vLLM框架替换Ollama并成功配置了GPT-OSS模型达到了接近190Tps的性能。\n\n其次作者体验了DeepSeek 1M上下文模型发现其在处理长上下文任务时表现出色能够展现摘要无法捕捉的细节并成功生成简历、分析人格等。\n\n此外作者还尝试使用DeepSeek重构Mabbs并发现DeepSeek能够识别作者的博客信息这表明训练样本中包含了作者的信息。\n\n最后作者在8GiB内存的MacBook Pro上运行了LFM2.5-1.2B-Thinking模型并使用了Apollo软件体验了其快速的推理速度和良好的思考能力。作者总结认为AI的发展令人惊叹软件优化使其在有限硬件环境下也能运行。",
"/2026/04/14/ai-agent.html": "这篇文章介绍了“AI个人助理”Agent的发展现状和各种尝试。作者体验了OpenClaw、QClaw、WorkBuddy、Cline、LuckClaw和ApkClaw等不同的Agent项目发现它们在功能、易用性和性能上各有优劣。OpenClaw安装和使用存在困难国内大厂的QClaw和WorkBuddy则更易于上手但免费额度有限。作者认为开发任务更适合在编辑器集成AI中进行如GitHub Copilot。LuckClaw在微型开发板上运行表现出色ApkClaw则利用手机的优势操作移动应用。尽管Agent技术仍存在诸多问题但其应用场景不断拓展有望吸引更多人参与其中推动AI应用化进程。",
"/2026/05/01/virtual-net.html": "这篇文章介绍了作者在尝试异地组网搭建虚拟局域网时对多种组网工具的探索和体验。作者首先尝试了n2n但由于其项目停止更新且在NAT后的机器间存在掉线问题最终选择了WireGuard作为主要方案。文章详细描述了WireGuard的配置过程包括在Linux、OpenWrt和openEuler系统上的安装和配置并遇到了各种各样的挑战例如在红米AX3000路由器上找不到内核模块以及在openEuler上缺少WireGuard相关包。此外文章还提到了Netmaker和Headscale等WireGuard的控制平面以及VNT和EasyTier等其他组网工具并总结了最终选择WireGuard的原因简单、够用、可靠性不错且已经投入了大量配置。"
"/2025/09/01/quine.html": "这篇文章主要介绍了作者在博客部署过程中对ZIP Quine自包含压缩包和自产生程序的探索过程。作者起初想利用压缩包实现离线浏览但遇到了压缩包不包含自身的问题。随后作者回顾了ZIP Quine的原理如droste.zip以及如何通过DEFLATE压缩算法的LZ77编码实现自包含。作者尝试了Russ Cox的方案但发现由于压缩格式限制实际操作中存在数据容量的限制无法存下整个博客。尽管如此作者还是研究了嵌套循环的ZIP Quine如Ruben Van Mello的论文中所描述的尽管空间仍然有限。探索过程中作者还学习了自产生程序Quine的概念包括其实现原理和各种编程语言中的例子。作者最后感慨探索过程中的收获比原本的目标更重要。"
}

View File

@ -5,20 +5,17 @@ title,link,feed_url,description
极客兔兔,https://geektutu.com/,https://geektutu.com/atom.xml,致力于分享有趣的技术实践
维基萌,https://www.wikimoe.com/,https://www.wikimoe.com/rss,萌即是正义一名热爱acg的前端设计师的小站
7gugu's blog,https://www.7gugu.com/,https://7gugu.com/index.php/feed/,"一个用来存放我爱好的地方,编程,摄影之类的空间"
云游君,https://www.yunyoujun.cn/,https://www.yunyoujun.cn/atom.xml,希望能成为一个有趣的人。
Kingfish404,https://blog.kingfish404.cn/,https://blog.kingfish404.cn/index.xml,"Stay curious,stay naive. WUT. Jin Yu's Blog"
FKUN,https://blog.fkun.tech/,https://blog.fkun.tech/feed/,
Sinofine,https://sinofine.me/,https://sinofine.me/atom.xml,
花生莲子粥,https://blog.hslzz.cn/,https://blog.hslzz.cn/atom.xml,与世无争,不染于泥
Vullfin的博客,https://blog.vull.top/,https://blog.vull.top/atom.xml,Vullfin's Home Page
阿涛の小破站,https://emohe.cn/,https://emohe.cn/rss.xml,Docker技术分享
記緒漂流,https://ttio.cc/,https://ttio.cc/feed.xml,于记忆之川,泛思绪之舟。
記緒漂流,https://ttio.cc/,https://ttio.cc/feed/,于记忆之川,泛思绪之舟。
陈陈菌博客,https://blog.glumi.cn/,https://blog.glumi.cn/rss.xml,计算机业余爱好者。
彬红茶日记,https://note.redcha.cn/,https://note.redcha.cn/rss.xml,我的个人日记!
Lanke's blog,https://blog.blueke.top/,https://blog.blueke.top/rss.xml,请为一切不真实之物骄傲,因为我们高于这个世界!
寒士杰克,https://www.hansjack.com/,https://www.hansjack.com/feed/,喜欢捣鼓,不断进步!
Lanke's blog,https://www.blueke.top/,https://www.blueke.top/rss.xml,请为一切不真实之物骄傲,因为我们高于这个世界!
时光流·言,https://www.hansjack.com/,https://www.hansjack.com/feed/,个人博客,持续分享网站部署实战经验、精选书评解读和生活观察手记。 这里提供可复用的技术教程、深度阅读指南和真实生活洞察,与技术爱好者一起进步......
Pinpe 的云端,https://pinpe.top/,https://pinpe.top/rss.xml,一个属于自己的云朵。
Chise Hachiroku,https://chise.hachiroku.com/zh/,https://chise.hachiroku.com/zh/feed/,向明日的辉迹,干杯!
映屿,https://www.glowisle.me/,https://www.glowisle.me/atom.xml,关于互联网、书籍、生活琐事以及那些一闪而过的念头
Restent's Notebook,https://blog.gxres.net/,https://blog.gxres.net/atom.xml,不前沿技术分享
Coseroom,https://coseroom.com,,
RavelloH's Blog,https://ravelloh.com,https://ravelloh.com/feed.xml,Beginning of meditation.
Chise Hachiroku,https://chise.hachiroku.com/,https://chise.hachiroku.com/zh/feed/,向明日的辉迹,干杯!

1 title link feed_url description
5 极客兔兔 https://geektutu.com/ https://geektutu.com/atom.xml 致力于分享有趣的技术实践
6 维基萌 https://www.wikimoe.com/ https://www.wikimoe.com/rss 萌即是正义!一名热爱acg的前端设计师的小站!
7 7gugu's blog https://www.7gugu.com/ https://7gugu.com/index.php/feed/ 一个用来存放我爱好的地方,编程,摄影之类的空间
8 云游君 https://www.yunyoujun.cn/ https://www.yunyoujun.cn/atom.xml 希望能成为一个有趣的人。
9 Kingfish404 https://blog.kingfish404.cn/ https://blog.kingfish404.cn/index.xml Stay curious,stay naive. WUT. Jin Yu's Blog
10 FKUN https://blog.fkun.tech/ https://blog.fkun.tech/feed/
11 Sinofine https://sinofine.me/ https://sinofine.me/atom.xml
12 花生莲子粥 https://blog.hslzz.cn/ https://blog.hslzz.cn/atom.xml 与世无争,不染于泥
13 Vullfin的博客 https://blog.vull.top/ https://blog.vull.top/atom.xml Vullfin's Home Page
14 阿涛の小破站 https://emohe.cn/ https://emohe.cn/rss.xml Docker技术分享
15 記緒漂流 https://ttio.cc/ https://ttio.cc/feed.xml https://ttio.cc/feed/ 于记忆之川,泛思绪之舟。
16 陈陈菌博客 https://blog.glumi.cn/ https://blog.glumi.cn/rss.xml 计算机业余爱好者。
17 彬红茶日记 https://note.redcha.cn/ https://note.redcha.cn/rss.xml 我的个人日记!
18 Lanke's blog https://blog.blueke.top/ https://www.blueke.top/ https://blog.blueke.top/rss.xml https://www.blueke.top/rss.xml 请为一切不真实之物骄傲,因为我们高于这个世界!
19 寒士杰克 时光流·言 https://www.hansjack.com/ https://www.hansjack.com/feed/ 喜欢捣鼓,不断进步! 个人博客,持续分享网站部署实战经验、精选书评解读和生活观察手记。 这里提供可复用的技术教程、深度阅读指南和真实生活洞察,与技术爱好者一起进步......
20 Pinpe 的云端 https://pinpe.top/ https://pinpe.top/rss.xml 一个属于自己的云朵。
21 Chise Hachiroku https://chise.hachiroku.com/zh/ https://chise.hachiroku.com/ https://chise.hachiroku.com/zh/feed/ 向明日的辉迹,干杯!
映屿 https://www.glowisle.me/ https://www.glowisle.me/atom.xml 关于互联网、书籍、生活琐事以及那些一闪而过的念头
Restent's Notebook https://blog.gxres.net/ https://blog.gxres.net/atom.xml 不前沿技术分享
Coseroom https://coseroom.com
RavelloH's Blog https://ravelloh.com https://ravelloh.com/feed.xml Beginning of meditation.

View File

@ -1,542 +0,0 @@
repo_url
http://gdatura24gtdy23lxd7ht3xzx6mi7mdlkabpvuefhrjn4t5jduviw5ad.onion/Mayx/mayx
http://git.dkforestseeaaq2dqz2uflmlsybvnq2irzn4ygyvu53oazyorednviid.onion/mayx/blog
http://giteabolfdejtdzblkooalqei6jr67imiugmhtsh6ocw4hlj5a4q.b32.i2p/mayx/blog
https://lavaforge.org/mayx/blog
https://sij.ai/mayx/blog
https://repobase.net/mayx/blog
https://gitlab.lain.la/mayx/mayx.pages.lain.la
https://gitplac.si/mayx/mayx.gitpage.si
https://gitnet.fr/mayx/blog
https://forge.fedoraproject.org/mabbs/blog
https://tilde.club/~mayx/git/blog.git/
https://git.envs.net/Mayx/mayx
https://tildegit.org/Mayx/mayx
https://git.tilde.town/mayx/blog
https://gitlab.haskell.org/mayx/mayx
https://repo2.serv00.com/git/pub/Mayx/mayx/
https://git.pixie.town/mayx/mayx
https://codefloe.com/mayx/blog
https://git.minetest.land/Mayx/blog
http://47.120.60.153:10880/mayx/blog
http://1.6.141.109:3000/mayx/blog
http://52.28.156.42/mayx/blog
https://code.dsconce.space/mayx/blog
http://101.66.229.132:61088/mayx/blog
https://git.bp-web.app/mayx/blog
https://mygit.iexercice.com/mayx/blog
http://162.215.134.149:4000/mayx/blog
http://durfee.mycrestron.com:3000/mayx/blog
https://gitea.nongnghiepso.com/mayx/blog
https://codes.tools.asitavsen.com/mayx/blog
http://50.19.111.193:3000/mayx/blog
https://git.zeroplay.io/mayx/blog
http://45.33.87.87/mayx/blog
http://168.126.28.36:3000/mayx/blog
http://69.62.77.234:8888/mayx/blog
http://112.219.147.186:7000/mayx/blog
https://git.rootfinlay.co.uk/mayx/blog
https://gitea.belanjaparts.com/mayx/blog
http://185.208.225.190:3000/mayx/blog
http://116.204.34.35:12000/mayx/blog
https://git.Apture.io/mayx/blog
https://gitea.jasonstolle.com/mayx/blog
http://8.134.61.107:3000/mayx/blog
http://47.107.88.161:3000/mayx/blog
http://142.171.47.170:3000/mayx/blog
http://111.231.146.230:8418/mayx/blog
https://git.pwaapp.cc/mayx/blog
https://an360.top/mayx/blog
http://106.15.78.64:3000/mayx/blog
https://git.wisder.net/mayx/blog
http://111.119.244.185:3000/mayx/blog
http://110.41.179.36:13000/mayx/blog
https://git.influxfin.com/mayx/blog
http://219.157.255.213:25311/mayx/blog
https://git.vekus.ru/mayx/blog
http://116.204.75.78:6180/mayx/blog
http://109.228.48.121:8000/mayx/blog
http://27.124.12.222:3000/mayx/blog
https://git.sayndone.ru/mayx/blog
https://gitea.hintsight.com/mayx/blog
http://blackobelisk.xyz:3000/mayx/blog
https://git.the-kn.com/mayx/blog
https://gitea.shirom.me/mayx/blog
https://git.wangxinlei.cn/mayx/blog
http://123.56.193.182:3000/mayx/blog
http://167.172.7.198:8081/mayx/blog
https://gitea.meetgu.ru/mayx/blog
http://116.236.50.103:8789/mayx/blog
https://git.paulll.cc/mayx/blog
http://94.224.160.69:7990/mayx/blog
https://gitea.ekjeong.synology.me/mayx/blog
https://git.daoyoucloud.com/mayx/blog
https://code.bitahub.com/mayx/blog
https://repo.gusdya.net/mayx/blog
https://gitea.synapsetec.cn/mayx/blog
http://gitea.yunshanghub.com:8081/mayx/blog
http://113.177.27.200:2033/mayx/blog
http://152.69.204.151:3000/mayx/blog
http://207.180.229.193:3001/mayx/blog
http://34.81.52.16/mayx/blog
http://123.57.16.111:3000/mayx/blog
https://lius.familyds.org:3000/mayx/blog
http://git.chaojing-film.com:3000/mayx/blog
https://git.nusaerp.com/mayx/blog
http://35.207.205.18:3000/mayx/blog
http://git.zjsciot.com:3000/mayx/blog
https://gitea.ontoast.uk/mayx/blog
http://112.124.40.88:5510/mayx/blog
http://121.36.37.70:15501/mayx/blog
http://187.216.152.151:9999/mayx/blog
http://116.63.173.179:8001/mayx/blog
http://114.116.79.196/mayx/blog
http://121.40.40.177:3000/mayx/blog
http://178.254.35.219:3000/mayx/blog
http://2.59.132.109:3001/mayx/blog
http://81.71.148.57:8080/mayx/blog
https://git.lmskaran.com/mayx/blog
http://154.86.0.30:3000/mayx/blog
http://52.23.128.62:3000/mayx/blog
http://120.46.222.128:10021/mayx/blog
http://120.26.108.239:9188/mayx/blog
http://47.111.17.177:3000/mayx/blog
https://k0ki-dev.com/mayx/blog
http://110.42.45.89:2052/mayx/blog
https://git.furcom.org/mayx/blog
http://34.102.70.200:3000/mayx/blog
https://gitea.oio.cat/mayx/blog
https://git.karma-riuk.com/mayx/blog
https://git.7o9o.net/mayx/blog
https://git.gupaoedu.cn/mayx/blog
https://git.7milch.com/mayx/blog
https://git.sitenevis.com/mayx/blog
https://dreamplacesai.de/mayx/blog
http://1.94.13.224:9080/mayx/blog
http://gitea.coderpath.com/mayx/blog
http://43.136.169.169:3000/mayx/blog
http://121.196.213.68:3000/mayx/blog
https://git.micahmoore.io/mayx/blog
https://git.anatid.net/mayx/blog
https://git.lekai.info/mayx/blog
http://135.235.225.198:3000/mayx/blog
http://117.72.114.197:3000/mayx/blog
https://git.ashcloud.com/mayx/blog
https://git.novaa.xyz/mayx/blog
http://101.46.208.93:3000/mayx/blog
http://23.94.57.60:3000/mayx/blog
https://gitea.sciotech.cn/mayx/blog
http://8.140.250.85:3000/mayx/blog
http://202.65.194.19:3000/mayx/blog
http://101.201.34.43:3000/mayx/blog
https://git.gloje-rinchen-dorjee-rinpoche-buddhist-monastery.org/mayx/blog
http://101.35.227.2:3000/mayx/blog
http://175.126.123.163:3000/mayx/blog
http://git.uhfdemo.com/mayx/blog
https://git.jakubzabski.pl/mayx/blog
http://209.141.47.52:3000/mayx/blog
http://60.204.158.188:3000/mayx/blog
http://60.204.156.211:3000/mayx/blog
http://nas.bi1kbu.com:8418/mayx/blog
http://1.94.178.207:3000/mayx/blog
https://gitea.tsaida.synology.me/mayx/blog
https://git.teygaming.com/mayx/blog
http://osztromok.com:3164/mayx/blog
http://175.209.53.134:3030/mayx/blog
http://39.107.226.169:3000/mayx/blog
http://39.96.211.118:3000/mayx/blog
http://121.37.47.20:3000/mayx/blog
https://git.antropix.dev/mayx/blog
http://15.237.198.144/mayx/blog
http://183.6.120.101:30000/mayx/blog
http://57.129.94.190:3000/mayx/blog
https://gitea.micro-stack.org/mayx/blog
https://gitea.temp.brentgruber.com/mayx/blog
http://47.102.147.170:3050/mayx/blog
http://172.236.250.154:3000/mayx/blog
http://54.198.134.152:3000/mayx/blog
http://121.41.35.226:11011/mayx/blog
http://47.111.1.12:3000/mayx/blog
https://nelgit.nelpi.co.uk/mayx/blog
http://8.141.91.86:3000/mayx/blog
http://117.72.15.187:3000/mayx/blog
http://81.70.30.91:3000/mayx/blog
http://106.54.211.95:3000/mayx/blog
http://210.245.20.73:3333/mayx/blog
http://43.248.97.109:3000/mayx/blog
http://113.207.86.104:3080/mayx/blog
http://39.96.195.72:10082/mayx/blog
http://8.148.24.160:3000/mayx/blog
https://221.219.181.35:30000/mayx/blog
http://172.172.102.93:3000/mayx/blog
http://115.120.245.164:3000/mayx/blog
http://35.194.179.90:3000/mayx/blog
http://66.179.208.56:3001/mayx/blog
http://121.43.60.72:9015/mayx/blog
http://171.80.13.66:9112/mayx/blog
http://223.108.157.174:3000/mayx/blog
http://120.24.249.56/mayx/blog
http://54.179.203.2:3000/mayx/blog
http://14.103.246.124:16000/mayx/blog
http://152.42.207.183:3000/mayx/blog
http://47.99.60.81:10082/mayx/blog
http://120.211.66.170:8418/mayx/blog
https://gitea.vilcap.com/mayx/blog
http://121.196.245.62/mayx/blog
http://8.138.142.17:3000/mayx/blog
http://www.koelndom.cn:13030/mayx/blog
http://209.127.59.74:3000/mayx/blog
https://git.dotb.cloud/mayx/blog
https://gitea.augeo.dev/mayx/blog
http://120.46.23.215:3000/mayx/blog
http://121.41.2.71:3000/mayx/blog
http://110.41.177.80:5000/mayx/blog
https://gitea.dsmaster.myds.me/mayx/blog
https://gitea.primecontrols-dev.com/mayx/blog
http://www.scserverddns.top:13000/mayx/blog
https://git.lucas-michel.fr/mayx/blog
https://git.imvictor.tech:2/mayx/blog
http://47.112.137.193:3000/mayx/blog
http://58.38.123.148:3176/mayx/blog
http://docker.clhero.fun:3000/mayx/blog
https://bdgit.educoder.net/mayx/blog
http://e19510c831.iok.la/mayx/blog
http://119.45.49.212:3000/mayx/blog
https://gitea.kdlsvps.top/mayx/blog
https://code.antopie.org/mayx/blog
https://git.serenetia.com/mayx/blog
https://vcs.cozydsp.space/mayx/blog
http://115.190.107.87:3000/mayx/blog
http://106.12.50.144:8081/mayx/blog
https://code.wxk8.com/mayx/blog
http://8.155.58.218:9000/mayx/blog
http://fanlibo.i234.me:8418/mayx/blog
https://git.temporaryname.org/mayx/blog
https://Repo.gusdya.net/mayx/blog
https://git.m.ctf.arrobe.fr/mayx/blog
http://69.62.64.52:3333/mayx/blog
https://git.flymiracle.com/mayx/blog
https://gitea.manekenbrand.com/mayx/blog
http://106.14.138.181:3000/mayx/blog
https://git.yyuu.xyz/mayx/blog
http://39.107.70.124:3000/mayx/blog
https://git.stormrain.cn/mayx/blog
https://git.deuxfleurs.fr/mayx/blog
https://www.simpra.org:3000/mayx/blog
http://8.148.31.14:3000/mayx/blog
http://47.94.246.1:3000/mayx/blog
https://www.arcbyte.dev/mayx/blog
https://scm.bcorex.e3labs.net/mayx/blog
http://58.17.14.95:8001/mayx/blog
https://hero-cloud-stg-code.cnbita.com/mayx/blog
http://101.37.69.204:3000/mayx/blog
https://gitea.tecamino.com/mayx/blog
http://39.99.175.172:8000/mayx/blog
http://8.138.13.251:3000/mayx/blog
http://47.115.223.229:8888/mayx/blog
http://104.254.131.244:3000/mayx/blog
https://gitea.alacloud.de/mayx/blog
https://git.tobiasweise.dev/mayx/blog
https://code.cif.su/mayx/blog
https://git.cynic.moe/mayx/blog
https://git.muellers-software.org/mayx/blog
http://8.130.128.130:3000/mayx/blog
https://repos.fbpx.io/mayx/blog
https://git.cavemanon.xyz/mayx/blog
http://svn.rivastudio.cn/mayx/blog
https://kamtk.ru:4000/mayx/blog
http://39.98.126.115:8080/mayx/blog
http://46.202.189.66:3000/mayx/blog
http://82.26.157.11:3001/mayx/blog
http://123.60.146.54:3000/mayx/blog
http://8.140.248.67:3000/mayx/blog
http://118.178.172.49:3000/mayx/blog
https://gitea.lasallesaintdenis.com/mayx/blog
http://123.57.225.51:3000/mayx/blog
http://8.130.135.159:3000/mayx/blog
https://git.suo0.com/mayx/blog
http://103.228.160.127:3100/mayx/blog
https://git.dshkabatur.ru/mayx/blog
https://gitea.hoba.dedyn.io/mayx/blog
https://git.wegoo.ltd/mayx/blog
http://114.203.209.83:3000/mayx/blog
http://47.100.111.106:3000/mayx/blog
http://47.103.78.70:3000/mayx/blog
http://47.100.208.160:51300/mayx/blog
http://113.44.218.8:3000/mayx/blog
https://git.cenoq.com/mayx/blog
http://8.152.205.35:3000/mayx/blog
http://120.210.80.160:3000/mayx/blog
http://1.95.192.200:59300/mayx/blog
https://git.medis.com.vn/mayx/blog
http://194.5.152.156:3000/mayx/blog
http://8.155.172.147:3001/mayx/blog
https://git.erfmann.dev/mayx/blog
https://git.weavefun.com:5443/mayx/blog
https://git.vajdak.cz/mayx/blog
http://58.65.162.118:3000/mayx/blog
https://git.arkon.solutions/mayx/blog
http://8.131.93.145:54082/mayx/blog
http://111.9.31.174:10007/mayx/blog
https://forgejo.bridgetownrb.com/mayx/blog
http://54.199.96.217:3000/mayx/blog
http://20.219.0.85:3000/mayx/blog
https://dev01.open-alt.com/mayx/blog
https://gitea.doinlab.com/mayx/blog
https://git.7af.ru/mayx/blog
https://gitea.yimoyuyan.cn/mayx/blog
https://git.apextoaster.com/mayx/blog
https://hub.open-verse.ai/mayx/blog
http://221.203.14.217:3000/mayx/blog
https://git.sophiagwen.au/mayx/blog
http://139.196.96.28:13000/mayx/blog
https://dev.kiramtech.com/mayx/blog
https://git.ihatemen.uk/mayx/blog
https://git.123doit.com/mayx/blog
http://62.43.207.91:8889/mayx/blog
https://rsas.de/mayx/blog
https://git.johntsai.online/mayx/blog
https://gitea.css-sistemas.com.br/mayx/blog
https://git.f4e.lol/mayx/blog
http://47.113.145.232:3000/mayx/blog
http://47.115.212.237:3000/mayx/blog
http://72.61.229.93:4000/mayx/blog
https://git.yinbonet.cn/mayx/blog
https://lishan148.synology.me:3014/mayx/blog_cn
http://1.95.221.174:3000/mayx/blog
https://git.huwhy.cn/mayx/blog_cn
http://119.91.35.154:3000/mayx/blog_cn
http://110.42.101.39:13000/mayx/blog_cn
http://39.101.74.135:5000/mayx/blog_cn
http://124.236.46.74:9103/mayx/blog_cn
http://123.57.130.140:3000/mayx/blog_cn
http://112.124.49.128:3000/mayx/blog_cn
http://118.24.46.223:3000/mayx/blog_cn
http://s3.v100.vip:31057/mayx/blog_cn
https://www.syq.im:2025/mayx/blog_cn
http://101.33.225.95:3000/mayx/blog_cn
http://45.55.138.82:3000/mayx/blog_cn
http://82.156.121.2:3000/mayx/blog_cn
http://118.24.129.148:3000/mayx/blog_cn
http://58.241.155.106:10140/mayx/blog_cn
http://120.48.141.82:3000/mayx/blog_cn
http://61.178.84.89:8998/mayx/blog_cn
http://82.156.111.58:3000/mayx/blog_cn
https://git.saike.fun:9755/mayx/blog_cn
https://git.cool2645.com/mayx/blog_cn
http://1.95.173.44:3000/mayx/blog_cn
http://58.221.157.122:3000/mayx/blog_cn
https://gitlab.liruwei.cn/mayx/blog_cn
http://61.190.74.90:9900/mayx/blog_cn
http://49.234.27.222:3000/mayx/blog_cn
http://8.153.70.81:30001/mayx/blog_cn
http://175.27.229.211:3000/mayx/blog_cn
http://106.55.174.214:3000/mayx/blog_cn
https://git.yidaimingjvn.xyz/mayx/blog_cn
http://39.105.67.143:3000/mayx/blog_cn
http://8.140.232.131:8100/mayx/blog_cn
http://82.156.89.21:3000/mayx/blog_cn
https://git.sskuaixiu.com/mayx/blog_cn
http://xujiesoft.vicp.net:3000/mayx/blog_cn
http://113.44.36.103:23000/mayx/blog_cn
https://git.mingliqiye.com/mayx/blog_cn
http://119.29.194.155:8894/mayx/blog_cn
http://58.213.60.6:19000/mayx/blog_cn
http://36.153.162.171:3000/mayx/blog_cn
http://47.92.113.131:3000/mayx/blog
http://gyc.myds.me:4000/mayx/blog
https://git.tablet.sh/mayx/blog
https://git.gnyra.com/mayx/blog
https://git.graveyard.sh/mayx/blog
https://git.nathanspackman.com/mayx/blog
https://git.rmarl.in/mayx/blog
http://git.qniao.cn/mayx/blog
https://git.fast-blast.uk/mayx/blog
http://git.mynas71.myds.me/mayx/blog
https://git.4lsa.com/mayx/blog
https://rlgit.pro/mayx/blog
https://git.veraskolivna.net/mayx/blog
https://git.lifetop.net/mayx/blog
https://gitea.jnyuxia.com/mayx/blog
http://git.liuhung.com/mayx/blog
https://git.secretserver.club/mayx/blog
https://gitea.adber.tech/mayx/blog
https://gitea.hello.faith/mayx/blog
https://tea.neuron.my/mayx/blog
https://git.violka-it.net/mayx/blog
https://git.adityagupta.dev/mayx/blog
https://git.danpeak.co.uk/mayx/blog
https://gitea.mynas-lechner.de/mayx/blog
https://git.automathon.org/mayx/blog
https://aeterna.cim.mcgill.ca/mayx/blog
https://git.esen.gay/mayx/blog
https://git.webtims.ru/mayx/blog
https://gitea.personalsoftware.space/mayx/blog
http://gitea.yiban.com.tw:3030/mayx/blog
https://gitlab.iplusus.com/mayx/blog
https://git.cyberuk.me/mayx/blog
https://git.privezishop.ru/mayx/blog
https://gitea.zachl.tech/mayx/blog
https://git.miasma-os.com/mayx/blog
https://gitea.nacsity.cn/mayx/blog
https://gitea.diputadosalta.gob.ar/mayx/blog
https://ttym.space/mayx/blog
https://getskill.work/mayx/blog
https://suprasage.com/mayx/blog
https://git.zakum.cn/mayx/blog
https://gitea.amazingcoders.com/mayx/blog
https://gitea.kamilklecha.dev/mayx/blog
http://47.109.103.110:9000/mayx/blog_cn
http://47.105.124.101:3000/mayx/blog_cn
http://49.232.183.190:3000/mayx/blog_cn
http://git.zxkedu.com:33769/mayx/blog_cn
https://code.wemediacn.com/mayx/blog_cn
https://gitea.shizuka.icu/mayx/blog_cn
http://43.139.2.237:3000/mayx/blog_cn
http://51.159.198.233:3000/mayx/blog
https://gitea.adriangonzalezbarbosa.eu/mayx/blog
https://git.legatus.ru/mayx/blog
https://git.kayashov.keenetic.pro/mayx/blog
http://43.138.83.20:3000/mayx/blog_cn
http://47.104.241.192:19999/mayx/blog_cn
http://47.98.148.146:1026/mayx/blog_cn
http://119.96.62.56:3000/mayx/blog_cn
http://101.42.28.156:3000/mayx/blog_cn
http://106.55.0.66:31807/mayx/blog_cn
https://gitea.gentronhealth.com/mayx/blog_cn
http://43.143.209.246:6300/mayx/blog_cn
http://152.136.158.133:36512/mayx/blog_cn
http://yidaima.cn:6008/mayx/blog_cn
http://47.113.101.80:3000/mayx/blog_cn
http://82.156.98.34:3000/mayx/blog_cn
http://zgd.synology.me:8418/mayx/blog_cn
https://git.zguiy.com/mayx/blog_cn
http://58.221.216.202:3000/mayx/blog_cn
http://39.100.183.95:88/mayx/blog_cn
http://www.xshideserver.com:3000/mayx/blog_cn
http://124.223.54.62:28/mayx/blog_cn
http://159.75.131.235:3001/mayx/blog_cn
http://1.117.67.95:3000/mayx/blog_cn
http://103.236.53.208:3000/mayx/blog_cn
http://118.195.135.194:3000/mayx/blog_cn
http://81.70.102.154/mayx/blog_cn
http://154.8.164.149:3000/mayx/blog_cn
http://111.228.34.40:3000/mayx/blog_cn
http://82.156.249.211:3000/mayx/blog_cn
http://36.133.248.69:3088/mayx/blog_cn
http://220.205.16.27:18081/mayx/blog_cn
http://81.69.221.216:3000/mayx/blog_cn
http://115.159.194.75:4000/mayx/blog_cn
http://183.204.60.122:10081/mayx/blog_cn
http://43.139.240.37:17000/mayx/blog_cn
http://159.75.27.114:3000/mayx/blog_cn
http://arcreya.top/mayx/blog_cn
https://code.tczkiot.com/mayx/blog_cn
http://111.170.153.123:3000/mayx/blog_cn
http://xeroworld.team/mayx/blog_cn
https://gitea.wuyuank.com/mayx/blog_cn
http://47.117.245.9:17701/mayx/blog_cn
https://git.sunlix.one/mayx/blog_cn
http://47.106.222.181:20511/mayx/blog_cn
http://101.43.95.130:3001/mayx/blog_cn
http://39.101.170.62:9080/mayx/blog_cn
https://gitea.myat4.com/mayx/blog_cn
http://118.24.161.24:3000/mayx/blog_cn
http://githanea.s.odn.cc/mayx/blog_cn
https://git.dev.chuweizi.com/mayx/blog
http://35.175.189.8/mayx/blog
http://meowug.com:8418/mayx/blog_cn
http://36.138.125.206:3000/mayx/blog_cn
https://git.4lcap.com/mayx/blog_cn
http://101.43.238.71:3000/mayx/blog_cn
http://59.110.175.62:4322/mayx/blog_cn
https://www.luluvip.cn:8419/mayx/blog_cn
http://xianyuhome.cn:11013/mayx/blog_cn
https://git.chatumbrella.online/mayx/blog
https://silica.codes/mayx/blog
https://git.crystalyx.net/mayx/blog
https://gittea.dev/mayx/blog
https://git.newnaturalphilosophy.org/mayx/blog
http://mrjinit.com:3000/mayx/blog
https://code.infininov.com/mayx/blog
https://git.apt142.ru/mayx/blog
http://gitea.mcelwain.net/mayx/blog
https://chunkks.com/mayx/blog
https://gitea.earthmanrpg.me/mayx/blog
https://ndiuky.site/mayx/blog
https://src.enterpriselinux.social/mayx/blog
https://gitea.grxe.io/mayx/blog
https://git.mhworld.net/mayx/blog
https://blvckout.foo/mayx/blog
https://gitea.accept.dev.dbf.nl/mayx/blog
https://git.ke5.de/mayx/blog
https://git.jhossain.online/mayx/blog
http://gitea.xsec.fun/mayx/blog
https://barhoum-lab.fr/mayx/blog
https://git.fedaya.net/mayx/blog
http://gitea.nakile.fr/mayx/blog
https://redev.lol/mayx/blog
http://git.zfxfzb.com/mayx/blog
https://papi.tkpups.com/mayx/blog
https://git.beyond-a-i.org/mayx/blog
http://huanghomenas2.myqnapcloud.com:4000/mayx/blog_cn
http://43.142.166.108:10082/mayx/blog_cn
https://git.ueda.sk/mayx/blog_cn
https://tm-jikayo.com/mayx/blog_cn
http://zzdgitea.stnav.com/mayx/blog_cn
http://1.117.66.197:3000/mayx/blog_cn
http://git.zhmight.com/mayx/blog_cn
https://intl-dev.gaia888.com/mayx/blog_cn
https://gitea.xinyuxi.com/mayx/blog_cn
http://gitea.snailtrack.cn/mayx/blog_cn
https://git.powerdata.dk/mayx/blog
http://ydds.cloud:3000/mayx/blog_cn
http://120.24.50.145:3000/mayx/blog_cn
https://code.draussenfunker.de/mayx/blog_cn
https://git.dinsor.co.th/mayx/blog
https://ofibohost.com/mayx/blog
https://lab.iishka.net/mayx/blog
http://www.arkproject.top/mayx/blog
http://www.bkandssp.cn:30/mayx/blog
https://gitea.spitaki.cloud/mayx/blog
https://git.codle.ru/mayx/blog
https://git.sao.ru/mayx/blog
https://codeop.ru/mayx/blog
https://git.mirocom.org/mayx/blog
http://gitea.ydxtool.com/mayx/blog
http://18.167.251.121:10003/mayx/blog
http://39.98.171.121:53000/mayx/blog
https://gitea.malxte.de/mayx/blog
https://git.nizart.me/mayx/blog
https://git.ddns.net/mayx/blog
http://222.85.214.245:9776/mayx/blog
https://git.kraevsky.ru/mayx/blog
https://ruyiscx.cloud:3000/mayx/blog
https://git.0xee.eu/mayx/blog
https://gitea.deitglobal.com/mayx/blog
https://www.mygitea.ru/mayx/blog
https://git.crwlr.ir/mayx/blog
https://git.nozora.top/mayx/blog
https://git.sortug.com/mayx/blog
https://aivyx-gitea.cloud/mayx/blog
https://git.edenit.co.kr/mayx/blog
https://git.catgirlsneed.homes/mayx/blog
https://git.eldev.netcraze.pro/mayx/blog
http://110.41.184.238:3000/mayx/blog
http://47.108.255.216:3000/mayx/blog_cn
https://gitea.molietech.com/mayx/blog_cn
http://58.87.88.234:3000/mayx/blog_cn
http://210.75.240.13:3000/mayx/blog_cn
https://git.xz-i.com:30443/mayx/blog_cn
http://111.229.64.148:8080/mayx/blog_cn
https://git.fynn.vip/mayx/blog_cn
http://119.91.212.17:3000/mayx/blog_cn
http://git.hbg99.com:8080/mayx/blog_cn
https://git.eplg.services/mayx/blog
http://89.167.38.168:3001/mayx/blog
http://namonba.asuscomm.com:3001/mayx/blog
http://109.199.98.226:3001/mayx/blog
https://git.extra.eiffel.com/mayx/blog
https://gitea.digitanie.org/mayx/blog
http://124.207.0.162:30000/mayx/blog
https://git.xleed.com/mayx/blog
1 repo_url
2 http://gdatura24gtdy23lxd7ht3xzx6mi7mdlkabpvuefhrjn4t5jduviw5ad.onion/Mayx/mayx
3 http://git.dkforestseeaaq2dqz2uflmlsybvnq2irzn4ygyvu53oazyorednviid.onion/mayx/blog
4 http://giteabolfdejtdzblkooalqei6jr67imiugmhtsh6ocw4hlj5a4q.b32.i2p/mayx/blog
5 https://lavaforge.org/mayx/blog
6 https://sij.ai/mayx/blog
7 https://repobase.net/mayx/blog
8 https://gitlab.lain.la/mayx/mayx.pages.lain.la
9 https://gitplac.si/mayx/mayx.gitpage.si
10 https://gitnet.fr/mayx/blog
11 https://forge.fedoraproject.org/mabbs/blog
12 https://tilde.club/~mayx/git/blog.git/
13 https://git.envs.net/Mayx/mayx
14 https://tildegit.org/Mayx/mayx
15 https://git.tilde.town/mayx/blog
16 https://gitlab.haskell.org/mayx/mayx
17 https://repo2.serv00.com/git/pub/Mayx/mayx/
18 https://git.pixie.town/mayx/mayx
19 https://codefloe.com/mayx/blog
20 https://git.minetest.land/Mayx/blog
21 http://47.120.60.153:10880/mayx/blog
22 http://1.6.141.109:3000/mayx/blog
23 http://52.28.156.42/mayx/blog
24 https://code.dsconce.space/mayx/blog
25 http://101.66.229.132:61088/mayx/blog
26 https://git.bp-web.app/mayx/blog
27 https://mygit.iexercice.com/mayx/blog
28 http://162.215.134.149:4000/mayx/blog
29 http://durfee.mycrestron.com:3000/mayx/blog
30 https://gitea.nongnghiepso.com/mayx/blog
31 https://codes.tools.asitavsen.com/mayx/blog
32 http://50.19.111.193:3000/mayx/blog
33 https://git.zeroplay.io/mayx/blog
34 http://45.33.87.87/mayx/blog
35 http://168.126.28.36:3000/mayx/blog
36 http://69.62.77.234:8888/mayx/blog
37 http://112.219.147.186:7000/mayx/blog
38 https://git.rootfinlay.co.uk/mayx/blog
39 https://gitea.belanjaparts.com/mayx/blog
40 http://185.208.225.190:3000/mayx/blog
41 http://116.204.34.35:12000/mayx/blog
42 https://git.Apture.io/mayx/blog
43 https://gitea.jasonstolle.com/mayx/blog
44 http://8.134.61.107:3000/mayx/blog
45 http://47.107.88.161:3000/mayx/blog
46 http://142.171.47.170:3000/mayx/blog
47 http://111.231.146.230:8418/mayx/blog
48 https://git.pwaapp.cc/mayx/blog
49 https://an360.top/mayx/blog
50 http://106.15.78.64:3000/mayx/blog
51 https://git.wisder.net/mayx/blog
52 http://111.119.244.185:3000/mayx/blog
53 http://110.41.179.36:13000/mayx/blog
54 https://git.influxfin.com/mayx/blog
55 http://219.157.255.213:25311/mayx/blog
56 https://git.vekus.ru/mayx/blog
57 http://116.204.75.78:6180/mayx/blog
58 http://109.228.48.121:8000/mayx/blog
59 http://27.124.12.222:3000/mayx/blog
60 https://git.sayndone.ru/mayx/blog
61 https://gitea.hintsight.com/mayx/blog
62 http://blackobelisk.xyz:3000/mayx/blog
63 https://git.the-kn.com/mayx/blog
64 https://gitea.shirom.me/mayx/blog
65 https://git.wangxinlei.cn/mayx/blog
66 http://123.56.193.182:3000/mayx/blog
67 http://167.172.7.198:8081/mayx/blog
68 https://gitea.meetgu.ru/mayx/blog
69 http://116.236.50.103:8789/mayx/blog
70 https://git.paulll.cc/mayx/blog
71 http://94.224.160.69:7990/mayx/blog
72 https://gitea.ekjeong.synology.me/mayx/blog
73 https://git.daoyoucloud.com/mayx/blog
74 https://code.bitahub.com/mayx/blog
75 https://repo.gusdya.net/mayx/blog
76 https://gitea.synapsetec.cn/mayx/blog
77 http://gitea.yunshanghub.com:8081/mayx/blog
78 http://113.177.27.200:2033/mayx/blog
79 http://152.69.204.151:3000/mayx/blog
80 http://207.180.229.193:3001/mayx/blog
81 http://34.81.52.16/mayx/blog
82 http://123.57.16.111:3000/mayx/blog
83 https://lius.familyds.org:3000/mayx/blog
84 http://git.chaojing-film.com:3000/mayx/blog
85 https://git.nusaerp.com/mayx/blog
86 http://35.207.205.18:3000/mayx/blog
87 http://git.zjsciot.com:3000/mayx/blog
88 https://gitea.ontoast.uk/mayx/blog
89 http://112.124.40.88:5510/mayx/blog
90 http://121.36.37.70:15501/mayx/blog
91 http://187.216.152.151:9999/mayx/blog
92 http://116.63.173.179:8001/mayx/blog
93 http://114.116.79.196/mayx/blog
94 http://121.40.40.177:3000/mayx/blog
95 http://178.254.35.219:3000/mayx/blog
96 http://2.59.132.109:3001/mayx/blog
97 http://81.71.148.57:8080/mayx/blog
98 https://git.lmskaran.com/mayx/blog
99 http://154.86.0.30:3000/mayx/blog
100 http://52.23.128.62:3000/mayx/blog
101 http://120.46.222.128:10021/mayx/blog
102 http://120.26.108.239:9188/mayx/blog
103 http://47.111.17.177:3000/mayx/blog
104 https://k0ki-dev.com/mayx/blog
105 http://110.42.45.89:2052/mayx/blog
106 https://git.furcom.org/mayx/blog
107 http://34.102.70.200:3000/mayx/blog
108 https://gitea.oio.cat/mayx/blog
109 https://git.karma-riuk.com/mayx/blog
110 https://git.7o9o.net/mayx/blog
111 https://git.gupaoedu.cn/mayx/blog
112 https://git.7milch.com/mayx/blog
113 https://git.sitenevis.com/mayx/blog
114 https://dreamplacesai.de/mayx/blog
115 http://1.94.13.224:9080/mayx/blog
116 http://gitea.coderpath.com/mayx/blog
117 http://43.136.169.169:3000/mayx/blog
118 http://121.196.213.68:3000/mayx/blog
119 https://git.micahmoore.io/mayx/blog
120 https://git.anatid.net/mayx/blog
121 https://git.lekai.info/mayx/blog
122 http://135.235.225.198:3000/mayx/blog
123 http://117.72.114.197:3000/mayx/blog
124 https://git.ashcloud.com/mayx/blog
125 https://git.novaa.xyz/mayx/blog
126 http://101.46.208.93:3000/mayx/blog
127 http://23.94.57.60:3000/mayx/blog
128 https://gitea.sciotech.cn/mayx/blog
129 http://8.140.250.85:3000/mayx/blog
130 http://202.65.194.19:3000/mayx/blog
131 http://101.201.34.43:3000/mayx/blog
132 https://git.gloje-rinchen-dorjee-rinpoche-buddhist-monastery.org/mayx/blog
133 http://101.35.227.2:3000/mayx/blog
134 http://175.126.123.163:3000/mayx/blog
135 http://git.uhfdemo.com/mayx/blog
136 https://git.jakubzabski.pl/mayx/blog
137 http://209.141.47.52:3000/mayx/blog
138 http://60.204.158.188:3000/mayx/blog
139 http://60.204.156.211:3000/mayx/blog
140 http://nas.bi1kbu.com:8418/mayx/blog
141 http://1.94.178.207:3000/mayx/blog
142 https://gitea.tsaida.synology.me/mayx/blog
143 https://git.teygaming.com/mayx/blog
144 http://osztromok.com:3164/mayx/blog
145 http://175.209.53.134:3030/mayx/blog
146 http://39.107.226.169:3000/mayx/blog
147 http://39.96.211.118:3000/mayx/blog
148 http://121.37.47.20:3000/mayx/blog
149 https://git.antropix.dev/mayx/blog
150 http://15.237.198.144/mayx/blog
151 http://183.6.120.101:30000/mayx/blog
152 http://57.129.94.190:3000/mayx/blog
153 https://gitea.micro-stack.org/mayx/blog
154 https://gitea.temp.brentgruber.com/mayx/blog
155 http://47.102.147.170:3050/mayx/blog
156 http://172.236.250.154:3000/mayx/blog
157 http://54.198.134.152:3000/mayx/blog
158 http://121.41.35.226:11011/mayx/blog
159 http://47.111.1.12:3000/mayx/blog
160 https://nelgit.nelpi.co.uk/mayx/blog
161 http://8.141.91.86:3000/mayx/blog
162 http://117.72.15.187:3000/mayx/blog
163 http://81.70.30.91:3000/mayx/blog
164 http://106.54.211.95:3000/mayx/blog
165 http://210.245.20.73:3333/mayx/blog
166 http://43.248.97.109:3000/mayx/blog
167 http://113.207.86.104:3080/mayx/blog
168 http://39.96.195.72:10082/mayx/blog
169 http://8.148.24.160:3000/mayx/blog
170 https://221.219.181.35:30000/mayx/blog
171 http://172.172.102.93:3000/mayx/blog
172 http://115.120.245.164:3000/mayx/blog
173 http://35.194.179.90:3000/mayx/blog
174 http://66.179.208.56:3001/mayx/blog
175 http://121.43.60.72:9015/mayx/blog
176 http://171.80.13.66:9112/mayx/blog
177 http://223.108.157.174:3000/mayx/blog
178 http://120.24.249.56/mayx/blog
179 http://54.179.203.2:3000/mayx/blog
180 http://14.103.246.124:16000/mayx/blog
181 http://152.42.207.183:3000/mayx/blog
182 http://47.99.60.81:10082/mayx/blog
183 http://120.211.66.170:8418/mayx/blog
184 https://gitea.vilcap.com/mayx/blog
185 http://121.196.245.62/mayx/blog
186 http://8.138.142.17:3000/mayx/blog
187 http://www.koelndom.cn:13030/mayx/blog
188 http://209.127.59.74:3000/mayx/blog
189 https://git.dotb.cloud/mayx/blog
190 https://gitea.augeo.dev/mayx/blog
191 http://120.46.23.215:3000/mayx/blog
192 http://121.41.2.71:3000/mayx/blog
193 http://110.41.177.80:5000/mayx/blog
194 https://gitea.dsmaster.myds.me/mayx/blog
195 https://gitea.primecontrols-dev.com/mayx/blog
196 http://www.scserverddns.top:13000/mayx/blog
197 https://git.lucas-michel.fr/mayx/blog
198 https://git.imvictor.tech:2/mayx/blog
199 http://47.112.137.193:3000/mayx/blog
200 http://58.38.123.148:3176/mayx/blog
201 http://docker.clhero.fun:3000/mayx/blog
202 https://bdgit.educoder.net/mayx/blog
203 http://e19510c831.iok.la/mayx/blog
204 http://119.45.49.212:3000/mayx/blog
205 https://gitea.kdlsvps.top/mayx/blog
206 https://code.antopie.org/mayx/blog
207 https://git.serenetia.com/mayx/blog
208 https://vcs.cozydsp.space/mayx/blog
209 http://115.190.107.87:3000/mayx/blog
210 http://106.12.50.144:8081/mayx/blog
211 https://code.wxk8.com/mayx/blog
212 http://8.155.58.218:9000/mayx/blog
213 http://fanlibo.i234.me:8418/mayx/blog
214 https://git.temporaryname.org/mayx/blog
215 https://Repo.gusdya.net/mayx/blog
216 https://git.m.ctf.arrobe.fr/mayx/blog
217 http://69.62.64.52:3333/mayx/blog
218 https://git.flymiracle.com/mayx/blog
219 https://gitea.manekenbrand.com/mayx/blog
220 http://106.14.138.181:3000/mayx/blog
221 https://git.yyuu.xyz/mayx/blog
222 http://39.107.70.124:3000/mayx/blog
223 https://git.stormrain.cn/mayx/blog
224 https://git.deuxfleurs.fr/mayx/blog
225 https://www.simpra.org:3000/mayx/blog
226 http://8.148.31.14:3000/mayx/blog
227 http://47.94.246.1:3000/mayx/blog
228 https://www.arcbyte.dev/mayx/blog
229 https://scm.bcorex.e3labs.net/mayx/blog
230 http://58.17.14.95:8001/mayx/blog
231 https://hero-cloud-stg-code.cnbita.com/mayx/blog
232 http://101.37.69.204:3000/mayx/blog
233 https://gitea.tecamino.com/mayx/blog
234 http://39.99.175.172:8000/mayx/blog
235 http://8.138.13.251:3000/mayx/blog
236 http://47.115.223.229:8888/mayx/blog
237 http://104.254.131.244:3000/mayx/blog
238 https://gitea.alacloud.de/mayx/blog
239 https://git.tobiasweise.dev/mayx/blog
240 https://code.cif.su/mayx/blog
241 https://git.cynic.moe/mayx/blog
242 https://git.muellers-software.org/mayx/blog
243 http://8.130.128.130:3000/mayx/blog
244 https://repos.fbpx.io/mayx/blog
245 https://git.cavemanon.xyz/mayx/blog
246 http://svn.rivastudio.cn/mayx/blog
247 https://kamtk.ru:4000/mayx/blog
248 http://39.98.126.115:8080/mayx/blog
249 http://46.202.189.66:3000/mayx/blog
250 http://82.26.157.11:3001/mayx/blog
251 http://123.60.146.54:3000/mayx/blog
252 http://8.140.248.67:3000/mayx/blog
253 http://118.178.172.49:3000/mayx/blog
254 https://gitea.lasallesaintdenis.com/mayx/blog
255 http://123.57.225.51:3000/mayx/blog
256 http://8.130.135.159:3000/mayx/blog
257 https://git.suo0.com/mayx/blog
258 http://103.228.160.127:3100/mayx/blog
259 https://git.dshkabatur.ru/mayx/blog
260 https://gitea.hoba.dedyn.io/mayx/blog
261 https://git.wegoo.ltd/mayx/blog
262 http://114.203.209.83:3000/mayx/blog
263 http://47.100.111.106:3000/mayx/blog
264 http://47.103.78.70:3000/mayx/blog
265 http://47.100.208.160:51300/mayx/blog
266 http://113.44.218.8:3000/mayx/blog
267 https://git.cenoq.com/mayx/blog
268 http://8.152.205.35:3000/mayx/blog
269 http://120.210.80.160:3000/mayx/blog
270 http://1.95.192.200:59300/mayx/blog
271 https://git.medis.com.vn/mayx/blog
272 http://194.5.152.156:3000/mayx/blog
273 http://8.155.172.147:3001/mayx/blog
274 https://git.erfmann.dev/mayx/blog
275 https://git.weavefun.com:5443/mayx/blog
276 https://git.vajdak.cz/mayx/blog
277 http://58.65.162.118:3000/mayx/blog
278 https://git.arkon.solutions/mayx/blog
279 http://8.131.93.145:54082/mayx/blog
280 http://111.9.31.174:10007/mayx/blog
281 https://forgejo.bridgetownrb.com/mayx/blog
282 http://54.199.96.217:3000/mayx/blog
283 http://20.219.0.85:3000/mayx/blog
284 https://dev01.open-alt.com/mayx/blog
285 https://gitea.doinlab.com/mayx/blog
286 https://git.7af.ru/mayx/blog
287 https://gitea.yimoyuyan.cn/mayx/blog
288 https://git.apextoaster.com/mayx/blog
289 https://hub.open-verse.ai/mayx/blog
290 http://221.203.14.217:3000/mayx/blog
291 https://git.sophiagwen.au/mayx/blog
292 http://139.196.96.28:13000/mayx/blog
293 https://dev.kiramtech.com/mayx/blog
294 https://git.ihatemen.uk/mayx/blog
295 https://git.123doit.com/mayx/blog
296 http://62.43.207.91:8889/mayx/blog
297 https://rsas.de/mayx/blog
298 https://git.johntsai.online/mayx/blog
299 https://gitea.css-sistemas.com.br/mayx/blog
300 https://git.f4e.lol/mayx/blog
301 http://47.113.145.232:3000/mayx/blog
302 http://47.115.212.237:3000/mayx/blog
303 http://72.61.229.93:4000/mayx/blog
304 https://git.yinbonet.cn/mayx/blog
305 https://lishan148.synology.me:3014/mayx/blog_cn
306 http://1.95.221.174:3000/mayx/blog
307 https://git.huwhy.cn/mayx/blog_cn
308 http://119.91.35.154:3000/mayx/blog_cn
309 http://110.42.101.39:13000/mayx/blog_cn
310 http://39.101.74.135:5000/mayx/blog_cn
311 http://124.236.46.74:9103/mayx/blog_cn
312 http://123.57.130.140:3000/mayx/blog_cn
313 http://112.124.49.128:3000/mayx/blog_cn
314 http://118.24.46.223:3000/mayx/blog_cn
315 http://s3.v100.vip:31057/mayx/blog_cn
316 https://www.syq.im:2025/mayx/blog_cn
317 http://101.33.225.95:3000/mayx/blog_cn
318 http://45.55.138.82:3000/mayx/blog_cn
319 http://82.156.121.2:3000/mayx/blog_cn
320 http://118.24.129.148:3000/mayx/blog_cn
321 http://58.241.155.106:10140/mayx/blog_cn
322 http://120.48.141.82:3000/mayx/blog_cn
323 http://61.178.84.89:8998/mayx/blog_cn
324 http://82.156.111.58:3000/mayx/blog_cn
325 https://git.saike.fun:9755/mayx/blog_cn
326 https://git.cool2645.com/mayx/blog_cn
327 http://1.95.173.44:3000/mayx/blog_cn
328 http://58.221.157.122:3000/mayx/blog_cn
329 https://gitlab.liruwei.cn/mayx/blog_cn
330 http://61.190.74.90:9900/mayx/blog_cn
331 http://49.234.27.222:3000/mayx/blog_cn
332 http://8.153.70.81:30001/mayx/blog_cn
333 http://175.27.229.211:3000/mayx/blog_cn
334 http://106.55.174.214:3000/mayx/blog_cn
335 https://git.yidaimingjvn.xyz/mayx/blog_cn
336 http://39.105.67.143:3000/mayx/blog_cn
337 http://8.140.232.131:8100/mayx/blog_cn
338 http://82.156.89.21:3000/mayx/blog_cn
339 https://git.sskuaixiu.com/mayx/blog_cn
340 http://xujiesoft.vicp.net:3000/mayx/blog_cn
341 http://113.44.36.103:23000/mayx/blog_cn
342 https://git.mingliqiye.com/mayx/blog_cn
343 http://119.29.194.155:8894/mayx/blog_cn
344 http://58.213.60.6:19000/mayx/blog_cn
345 http://36.153.162.171:3000/mayx/blog_cn
346 http://47.92.113.131:3000/mayx/blog
347 http://gyc.myds.me:4000/mayx/blog
348 https://git.tablet.sh/mayx/blog
349 https://git.gnyra.com/mayx/blog
350 https://git.graveyard.sh/mayx/blog
351 https://git.nathanspackman.com/mayx/blog
352 https://git.rmarl.in/mayx/blog
353 http://git.qniao.cn/mayx/blog
354 https://git.fast-blast.uk/mayx/blog
355 http://git.mynas71.myds.me/mayx/blog
356 https://git.4lsa.com/mayx/blog
357 https://rlgit.pro/mayx/blog
358 https://git.veraskolivna.net/mayx/blog
359 https://git.lifetop.net/mayx/blog
360 https://gitea.jnyuxia.com/mayx/blog
361 http://git.liuhung.com/mayx/blog
362 https://git.secretserver.club/mayx/blog
363 https://gitea.adber.tech/mayx/blog
364 https://gitea.hello.faith/mayx/blog
365 https://tea.neuron.my/mayx/blog
366 https://git.violka-it.net/mayx/blog
367 https://git.adityagupta.dev/mayx/blog
368 https://git.danpeak.co.uk/mayx/blog
369 https://gitea.mynas-lechner.de/mayx/blog
370 https://git.automathon.org/mayx/blog
371 https://aeterna.cim.mcgill.ca/mayx/blog
372 https://git.esen.gay/mayx/blog
373 https://git.webtims.ru/mayx/blog
374 https://gitea.personalsoftware.space/mayx/blog
375 http://gitea.yiban.com.tw:3030/mayx/blog
376 https://gitlab.iplusus.com/mayx/blog
377 https://git.cyberuk.me/mayx/blog
378 https://git.privezishop.ru/mayx/blog
379 https://gitea.zachl.tech/mayx/blog
380 https://git.miasma-os.com/mayx/blog
381 https://gitea.nacsity.cn/mayx/blog
382 https://gitea.diputadosalta.gob.ar/mayx/blog
383 https://ttym.space/mayx/blog
384 https://getskill.work/mayx/blog
385 https://suprasage.com/mayx/blog
386 https://git.zakum.cn/mayx/blog
387 https://gitea.amazingcoders.com/mayx/blog
388 https://gitea.kamilklecha.dev/mayx/blog
389 http://47.109.103.110:9000/mayx/blog_cn
390 http://47.105.124.101:3000/mayx/blog_cn
391 http://49.232.183.190:3000/mayx/blog_cn
392 http://git.zxkedu.com:33769/mayx/blog_cn
393 https://code.wemediacn.com/mayx/blog_cn
394 https://gitea.shizuka.icu/mayx/blog_cn
395 http://43.139.2.237:3000/mayx/blog_cn
396 http://51.159.198.233:3000/mayx/blog
397 https://gitea.adriangonzalezbarbosa.eu/mayx/blog
398 https://git.legatus.ru/mayx/blog
399 https://git.kayashov.keenetic.pro/mayx/blog
400 http://43.138.83.20:3000/mayx/blog_cn
401 http://47.104.241.192:19999/mayx/blog_cn
402 http://47.98.148.146:1026/mayx/blog_cn
403 http://119.96.62.56:3000/mayx/blog_cn
404 http://101.42.28.156:3000/mayx/blog_cn
405 http://106.55.0.66:31807/mayx/blog_cn
406 https://gitea.gentronhealth.com/mayx/blog_cn
407 http://43.143.209.246:6300/mayx/blog_cn
408 http://152.136.158.133:36512/mayx/blog_cn
409 http://yidaima.cn:6008/mayx/blog_cn
410 http://47.113.101.80:3000/mayx/blog_cn
411 http://82.156.98.34:3000/mayx/blog_cn
412 http://zgd.synology.me:8418/mayx/blog_cn
413 https://git.zguiy.com/mayx/blog_cn
414 http://58.221.216.202:3000/mayx/blog_cn
415 http://39.100.183.95:88/mayx/blog_cn
416 http://www.xshideserver.com:3000/mayx/blog_cn
417 http://124.223.54.62:28/mayx/blog_cn
418 http://159.75.131.235:3001/mayx/blog_cn
419 http://1.117.67.95:3000/mayx/blog_cn
420 http://103.236.53.208:3000/mayx/blog_cn
421 http://118.195.135.194:3000/mayx/blog_cn
422 http://81.70.102.154/mayx/blog_cn
423 http://154.8.164.149:3000/mayx/blog_cn
424 http://111.228.34.40:3000/mayx/blog_cn
425 http://82.156.249.211:3000/mayx/blog_cn
426 http://36.133.248.69:3088/mayx/blog_cn
427 http://220.205.16.27:18081/mayx/blog_cn
428 http://81.69.221.216:3000/mayx/blog_cn
429 http://115.159.194.75:4000/mayx/blog_cn
430 http://183.204.60.122:10081/mayx/blog_cn
431 http://43.139.240.37:17000/mayx/blog_cn
432 http://159.75.27.114:3000/mayx/blog_cn
433 http://arcreya.top/mayx/blog_cn
434 https://code.tczkiot.com/mayx/blog_cn
435 http://111.170.153.123:3000/mayx/blog_cn
436 http://xeroworld.team/mayx/blog_cn
437 https://gitea.wuyuank.com/mayx/blog_cn
438 http://47.117.245.9:17701/mayx/blog_cn
439 https://git.sunlix.one/mayx/blog_cn
440 http://47.106.222.181:20511/mayx/blog_cn
441 http://101.43.95.130:3001/mayx/blog_cn
442 http://39.101.170.62:9080/mayx/blog_cn
443 https://gitea.myat4.com/mayx/blog_cn
444 http://118.24.161.24:3000/mayx/blog_cn
445 http://githanea.s.odn.cc/mayx/blog_cn
446 https://git.dev.chuweizi.com/mayx/blog
447 http://35.175.189.8/mayx/blog
448 http://meowug.com:8418/mayx/blog_cn
449 http://36.138.125.206:3000/mayx/blog_cn
450 https://git.4lcap.com/mayx/blog_cn
451 http://101.43.238.71:3000/mayx/blog_cn
452 http://59.110.175.62:4322/mayx/blog_cn
453 https://www.luluvip.cn:8419/mayx/blog_cn
454 http://xianyuhome.cn:11013/mayx/blog_cn
455 https://git.chatumbrella.online/mayx/blog
456 https://silica.codes/mayx/blog
457 https://git.crystalyx.net/mayx/blog
458 https://gittea.dev/mayx/blog
459 https://git.newnaturalphilosophy.org/mayx/blog
460 http://mrjinit.com:3000/mayx/blog
461 https://code.infininov.com/mayx/blog
462 https://git.apt142.ru/mayx/blog
463 http://gitea.mcelwain.net/mayx/blog
464 https://chunkks.com/mayx/blog
465 https://gitea.earthmanrpg.me/mayx/blog
466 https://ndiuky.site/mayx/blog
467 https://src.enterpriselinux.social/mayx/blog
468 https://gitea.grxe.io/mayx/blog
469 https://git.mhworld.net/mayx/blog
470 https://blvckout.foo/mayx/blog
471 https://gitea.accept.dev.dbf.nl/mayx/blog
472 https://git.ke5.de/mayx/blog
473 https://git.jhossain.online/mayx/blog
474 http://gitea.xsec.fun/mayx/blog
475 https://barhoum-lab.fr/mayx/blog
476 https://git.fedaya.net/mayx/blog
477 http://gitea.nakile.fr/mayx/blog
478 https://redev.lol/mayx/blog
479 http://git.zfxfzb.com/mayx/blog
480 https://papi.tkpups.com/mayx/blog
481 https://git.beyond-a-i.org/mayx/blog
482 http://huanghomenas2.myqnapcloud.com:4000/mayx/blog_cn
483 http://43.142.166.108:10082/mayx/blog_cn
484 https://git.ueda.sk/mayx/blog_cn
485 https://tm-jikayo.com/mayx/blog_cn
486 http://zzdgitea.stnav.com/mayx/blog_cn
487 http://1.117.66.197:3000/mayx/blog_cn
488 http://git.zhmight.com/mayx/blog_cn
489 https://intl-dev.gaia888.com/mayx/blog_cn
490 https://gitea.xinyuxi.com/mayx/blog_cn
491 http://gitea.snailtrack.cn/mayx/blog_cn
492 https://git.powerdata.dk/mayx/blog
493 http://ydds.cloud:3000/mayx/blog_cn
494 http://120.24.50.145:3000/mayx/blog_cn
495 https://code.draussenfunker.de/mayx/blog_cn
496 https://git.dinsor.co.th/mayx/blog
497 https://ofibohost.com/mayx/blog
498 https://lab.iishka.net/mayx/blog
499 http://www.arkproject.top/mayx/blog
500 http://www.bkandssp.cn:30/mayx/blog
501 https://gitea.spitaki.cloud/mayx/blog
502 https://git.codle.ru/mayx/blog
503 https://git.sao.ru/mayx/blog
504 https://codeop.ru/mayx/blog
505 https://git.mirocom.org/mayx/blog
506 http://gitea.ydxtool.com/mayx/blog
507 http://18.167.251.121:10003/mayx/blog
508 http://39.98.171.121:53000/mayx/blog
509 https://gitea.malxte.de/mayx/blog
510 https://git.nizart.me/mayx/blog
511 https://git.ddns.net/mayx/blog
512 http://222.85.214.245:9776/mayx/blog
513 https://git.kraevsky.ru/mayx/blog
514 https://ruyiscx.cloud:3000/mayx/blog
515 https://git.0xee.eu/mayx/blog
516 https://gitea.deitglobal.com/mayx/blog
517 https://www.mygitea.ru/mayx/blog
518 https://git.crwlr.ir/mayx/blog
519 https://git.nozora.top/mayx/blog
520 https://git.sortug.com/mayx/blog
521 https://aivyx-gitea.cloud/mayx/blog
522 https://git.edenit.co.kr/mayx/blog
523 https://git.catgirlsneed.homes/mayx/blog
524 https://git.eldev.netcraze.pro/mayx/blog
525 http://110.41.184.238:3000/mayx/blog
526 http://47.108.255.216:3000/mayx/blog_cn
527 https://gitea.molietech.com/mayx/blog_cn
528 http://58.87.88.234:3000/mayx/blog_cn
529 http://210.75.240.13:3000/mayx/blog_cn
530 https://git.xz-i.com:30443/mayx/blog_cn
531 http://111.229.64.148:8080/mayx/blog_cn
532 https://git.fynn.vip/mayx/blog_cn
533 http://119.91.212.17:3000/mayx/blog_cn
534 http://git.hbg99.com:8080/mayx/blog_cn
535 https://git.eplg.services/mayx/blog
536 http://89.167.38.168:3001/mayx/blog
537 http://namonba.asuscomm.com:3001/mayx/blog
538 http://109.199.98.226:3001/mayx/blog
539 https://git.extra.eiffel.com/mayx/blog
540 https://gitea.digitanie.org/mayx/blog
541 http://124.207.0.162:30000/mayx/blog
542 https://git.xleed.com/mayx/blog

View File

@ -1,69 +1,61 @@
proxies:
- https://blog.mayx.workers.dev/
- https://mayx.deno.dev/
- https://mayx.val.run/
- https://mayx.azion.app/
- https://yuki.gear.host/
- https://mayx.global.ssl.fastly.net/
mirrors:
- https://mayx.gitlab.io/
- https://mayx.pages.dev/
- https://mayx.eu.org/
- https://mayx.envs.sh/
- https://mayx.envs.net/
- https://mayx.frama.io/
- https://mayx.surge.sh/
- https://mayx.pages.gay/
- https://mayx.gitpage.si/
- https://mayx.serv00.net/
- https://mayx.vercel.app/
- https://mayx-blog.pgs.sh/
- https://mayx.netlify.app/
- https://mayx.gitnet.page/
- https://mayx.stormkit.dev/
- https://mayx.grebedoc.dev/
- https://mayx.pixie.homes/
- https://mabbs.kinsta.page/
- https://mayx.codeberg.page/
- https://mayx.tildepages.org/
- https://mayx.pages.lain.la/
- https://mayx.4everland.app/
- https://mayx.readthedocs.io/
- https://mayx.pages.lain.la/
- https://mayx.sourceforge.io/
- https://unmayx.bitbucket.io/
- https://mayx.pages.debian.net/
- https://mayx.dappling.network/
- https://mayx-blog.statichost.page/
- https://mayx-blog.statichost.eu/
- https://mabbs-blog.static.hf.space/
- http://mayx.gitlink.net/
- https://mayx.pixie.homes/
repos:
gits:
- https://github.com/Mabbs/mabbs.github.io
- https://gitlab.com/mayx/mayx.gitlab.io
- https://framagit.org/mayx/mayx.frama.io
- https://salsa.debian.org/mayx/mayx.pages.debian.net
- https://gitlab.lain.la/mayx/mayx.pages.lain.la
- https://codeberg.org/mayx/blog
- https://pagure.io/mayx
- https://git.gay/mayx/mayx
- https://repo.or.cz/mayx.git
- https://gitea.com/mayx/mayx
- https://gitea.moe/Mayx/mayx
- https://gitgud.io/mayx/mayx
- https://git.sr.ht/~mayx/mayx
- https://worktree.ca/mayx/blog
- https://tvoygit.ru/Mayx/mayx
- https://git.envs.net/Mayx/mayx
- https://tildegit.org/Mayx/mayx
- https://git.launchpad.net/mayx
- https://gin.g-node.org/mayx/blog
- https://tildeforge.dev/mayx/blog
- https://git.disroot.org/mayx/mayx
- https://git.pixie.town/mayx/mayx
- https://cgit.tilde.town/~mayx/blog
- https://bitbucket.org/unmayx/mayx
- https://sourcecraft.dev/mayx/mayx
- https://code.forgejo.org/mayx/blog
- https://gitflic.ru/project/mayx/blog
- https://rocketgit.com/user/mayx/blog/
- https://tangled.org/mayx.tngl.sh/blog/
- https://git.disroot.org/mayx/mayx
- https://gitlab.haskell.org/mayx/mayx
- https://git.gammaspectra.live/Mayx/blog
- https://repo2.serv00.com/git/pub/Mayx/mayx/
- https://gitee.com/mabbs/mabbs
- https://cnb.cool/unmayx/mayx
- https://atomgit.com/mayx/blog
- https://sourceforge.net/projects/mayx/
- https://dev.azure.com/unmayx/_git/Mayx
- https://www.gitlink.org.cn/mayx/mayx.gitlink.net
- http://gdatura24gtdy23lxd7ht3xzx6mi7mdlkabpvuefhrjn4t5jduviw5ad.onion/Mayx/mayx
- http://giteabolfdejtdzblkooalqei6jr67imiugmhtsh6ocw4hlj5a4q.b32.i2p/mayx/blog
static:
- https://mayx.nekoweb.org/
- https://mayx.neocities.org/
@ -77,3 +69,4 @@ others:
- https://mayx.home.blog/
- https://unmayx.medium.com/
- https://mayx.cnblogs.com/
- https://mayx.xlog.app/

View File

@ -9,7 +9,6 @@ layout: xslt_container
<meta name="viewport" content="width=device-width, initial-scale=1" />
{% seo %}
{% if page.robots %}<meta name="robots" content="{{ page.robots }}" />{% endif %}
{% unless site.github %}<link rel="canonical" href="https://mabbs.github.io{{ page.url }}"/>{% endunless %}
{% feed_meta %}
<link rel="alternate" type="application/rss+xml" title="{{ site.title }}(RSS)" href="{{ "/rss.xml" | absolute_url }}" />
@ -17,8 +16,6 @@ layout: xslt_container
<link rel="stylesheet" href="/assets/css/style.css?v={{ site.time | date: "%s" }}" />
<!--[if !IE]> -->
<link rel="stylesheet" href="/Live2dHistoire/live2d/css/live2d.css" />
<link rel="stylesheet" href="/assets/css/gitalk.css">
<script src="/assets/js/gitalk.min.js"></script>
<!-- <![endif]-->
<link rel="search" type="application/opensearchdescription+xml" href="/opensearch.xml" title="{{ site.title }}" />
<link rel="webmention" href="https://webmention.io/mabbs.github.io/webmention" />
@ -27,7 +24,6 @@ layout: xslt_container
<link rel="prefetch" href="https://www.blogsclub.org/badge/mabbs.github.io" as="image" />
<link rel="blogroll" type="text/xml" href="/blogroll.opml" />
<link rel="me" href="https://github.com/Mabbs" />
<link type="text/plain" rel="author" href="/humans.txt" />
<script src="/assets/js/jquery.min.js"></script>
<!--[if lt IE 9]>
<script src="//cdnjs.cloudflare.com/ajax/libs/html5shiv/3.7.3/html5shiv.min.js"></script>
@ -37,15 +33,6 @@ layout: xslt_container
<script>
var lastUpdated = new Date("{{ site.time | date_to_rfc822 }}");
var BlogAPI = "https://summary.mayx.eu.org";
var GitalkConfig = {
clientID: '36557aec4c3cb04f7ac6',
clientSecret: 'ac32993299751cb5a9ba81cf2b171cca65879cdb',
repo: 'mabbs.github.io',
owner: 'Mabbs',
admin: ['Mabbs'],
distractionFreeMode: false,
proxy: 'https://cors-anywhere.mayx.eu.org/?https://github.com/login/oauth/access_token'
};
</script>
<script src="/assets/js/main.js"></script>
<!--[if !IE]> -->
@ -71,13 +58,13 @@ layout: xslt_container
<h1><a class="u-url u-uid p-name" rel="me" href="{{ "/" | relative_url }}">{{ site.title | default: site.github.repository_name }}</a></h1>
{% if site.logo %}
<img src="{{ site.logo }}" fetchpriority="high" class="u-photo" alt="Logo" style="width: 90%; max-width: 300px; max-height: 300px; border-radius: 25%;" />
<img src="{{ site.logo }}" fetchpriority="high" class="u-photo" alt="Logo" style="width: 90%; max-width: 300px; max-height: 300px;" />
{% endif %}
<p class="p-note">{{ site.description | default: site.github.project_tagline }}</p>
<form id="search-input-all" action="/search.html">
<input type="text" name="keyword" placeholder="Search blog posts.." />&#160;<input type="submit" value="搜索" />
<form action="/search.html">
<input type="text" name="keyword" id="search-input-all" placeholder="Search blog posts.." />&#160;<input type="submit" value="搜索" />
</form>
<br />
@ -102,7 +89,7 @@ layout: xslt_container
{% endif %}
</ul>
</header>
<section id="pjax-container"{% unless page.layout == "default" %} class="h-entry"{% endunless %}>
<section{% unless page.layout == "default" %} class="h-entry"{% endunless %}>
{{ content }}
@ -110,7 +97,7 @@ layout: xslt_container
{% include live2d.html %}
<footer>
<p>
<small>Made with ❤ by Mayx<br />Last updated at {{ site.time | date: "%F %T" }}<br /> 总字数:{% include_cached word_count.html %} - 文章数:{{ site.posts.size }} - <a href="/rss.xml">Feed</a> - <a href="{{ "/README.html" | relative_url }}" >About</a></small>
<small>Made with ❤ by Mayx<br />Last updated at {{ site.time | date: "%F %T" }}<br /> 总字数:{% include_cached word_count.html %} - 文章数:{{ site.posts.size }} - <a href="{{ site.feed.path | relative_url }}" >Atom</a> - <a href="{{ "/README.html" | relative_url }}" >About</a></small>
</p>
</footer>
</div>
@ -119,8 +106,6 @@ layout: xslt_container
<script src="/assets/js/main_new.js"></script>
<script src="/Live2dHistoire/live2d/js/live2d.js"></script>
<script src="/Live2dHistoire/live2d/js/message.js"></script>
<script src="/assets/js/jquery.pjax.min.js"></script>
<script src="/assets/js/pjax.js"></script>
<!-- <![endif]-->
</body>
</html>

View File

@ -59,11 +59,9 @@ layout: default
return;
} else {
const data = JSON.parse(event.data);
if (data.response) {
outputContainer.textContent += data.response;
}
}
}
});
}
});
@ -83,7 +81,7 @@ layout: default
{% if page.layout == "encrypt" %} {{content}} {% else %} <main class="post-content e-content" role="main">{% capture a_post_content %}{% include anchor_headings.html html=content beforeHeading=true anchorBody="<svg class='octicon' viewBox='0 0 16 16' version='1.1' width='16' height='32' aria-hidden='true'><path fill-rule='evenodd' d='M7.775 3.275a.75.75 0 001.06 1.06l1.25-1.25a2 2 0 112.83 2.83l-2.5 2.5a2 2 0 01-2.83 0 .75.75 0 00-1.06 1.06 3.5 3.5 0 004.95 0l2.5-2.5a3.5 3.5 0 00-4.95-4.95l-1.25 1.25zm-4.69 9.64a2 2 0 010-2.83l2.5-2.5a2 2 0 012.83 0 .75.75 0 001.06-1.06 3.5 3.5 0 00-4.95 0l-2.5 2.5a3.5 3.5 0 004.95 4.95l1.25-1.25a.75.75 0 00-1.06-1.06l-1.25 1.25a2 2 0 01-2.83 0z'></path></svg>" %}{% endcapture %}{{ a_post_content | replace: '<br />', '</p><p>' }}</main> {% endif %}
{% if page.tags %}
<small style="display: block">tags: {% for tag in page.tags %}<a rel="category tag" class="p-category" href="/search.html?keyword={{ tag | uri_escape }}"><em>{{ tag }}</em></a>{% unless forloop.last %} - {% endunless %}{% endfor %} <span style="float: right;"><a href="{% if site.github %}{{ site.github.repository_url }}{% else %}https://gitlab.com/mayx/mayx.gitlab.io{% endif %}/tree/master/{{ page.path }}">查看原始文件</a></span></small>
<small style="display: block">tags: {% for tag in page.tags %}<a rel="category tag" class="p-category" href="/search.html?keyword={{ tag | url_encode | replace: '+', '%20' }}"><em>{{ tag }}</em></a>{% unless forloop.last %} - {% endunless %}{% endfor %} <span style="float: right;"><a href="{% if site.github %}{{ site.github.repository_url }}{% else %}https://gitlab.com/mayx/mayx.gitlab.io{% endif %}/tree/master/{{ page.path }}">查看原始文件</a></span></small>
{% endif %}
{% if page.layout != "encrypt" %}
<h4 style="border-bottom: 1px solid #e5e5e5;margin: 2em 0 5px;">推荐文章</h4>
@ -158,11 +156,22 @@ $.get(BlogAPI + "/suggest?id={{ page.url }}&update=" + lastUpdated.valueOf(), fu
</div>
<!--[if !IE]> -->
<link rel="stylesheet" href="/assets/css/gitalk.css">
<script src="/assets/js/gitalk.min.js"></script>
<div id="gitalk-container" data-page-id="{{ page.id }}"></div>
<div id="gitalk-container"></div>
<script>
var gitalk = new Gitalk(Object.assign({ id: '{{ page.id }}' }, GitalkConfig))
var gitalk = new Gitalk({
clientID: '36557aec4c3cb04f7ac6',
clientSecret: 'ac32993299751cb5a9ba81cf2b171cca65879cdb',
repo: 'mabbs.github.io',
owner: 'Mabbs',
admin: ['Mabbs'],
id: '{{ page.id }}', // Ensure uniqueness and length less than 50
distractionFreeMode: false, // Facebook-like distraction free mode
proxy: "https://cors-anywhere.mayx.eu.org/?https://github.com/login/oauth/access_token"
})
gitalk.render('gitalk-container')
</script>
<!-- <![endif]-->

View File

@ -1,7 +1,10 @@
{% if page.layout == "xslt" %}<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type="text/xml" href="/feed.xslt.xml"?>
<?xml-stylesheet type="text/css" href="/assets/css/xslt.css"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:sm="http://www.sitemaps.org/schemas/sitemap/0.9">
<xsl:stylesheet
version="3.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:atom="http://www.w3.org/2005/Atom"
xmlns:sm="http://www.sitemaps.org/schemas/sitemap/0.9">
<xsl:output method="html" version="4.0" encoding="UTF-8" indent="yes" doctype-system="about:legacy-compat" />
<xsl:template match="/">
{{ content }}

View File

@ -115,7 +115,7 @@ ossyNMMMNyMMhsssssssssssssshmmmhssssssso Memory: 8773MiB / 11928MiB
不过我按照官方文档上安装对于CentOS Stream 8来说有好多包不知道为什么似乎都没有比如libavformat-free-devel之类的我只好从网上找其他RedHat系列类似的包或者找替代品FFmpeg另外Darling需要Linux 5.0或者更高的内核CentOS的内核版本太低了所以我升到了主线版本的Linux也就是6.8的版本……最终花了一天的时间终于编译好了然而悲剧的是运行的时候报了非法指令“Illegal instruction (core dumped)”的错误。一般来说这个错误是新机器上编译的程序在旧机器运行才会报的错,可我是在同一台机器上编译的为什么会报这种错误呢?可能是因为代码里包含汇编语言的代码吧。我发了个[Issue](https://github.com/darlinghq/darling/issues/1497)问了一下作者,不过看起来他也不知道是什么问题……
对于这种问题我感觉也没什么好办法……可能这台机器真的就没办法了在第二台速龙641的电脑上试了一下也不行……不过后来我在第三台装有奔腾G3240的电脑上试着编译安装了一下结果可以运行。看来确实是奔腾E5300的问题。不过它俩到底差在哪里呢看介绍会发现奔腾G3240里包含了Intel® SSE4.1和Intel® SSE4.2的指令集扩展。那么对于没有这个指令集扩展的CPU就没办法了吗Intel官方给了一个解决方法是[Intel® SDE](https://www.intel.com/content/www/us/en/developer/articles/tool/software-development-emulator.html)可以在旧机器上模拟运行使用了最新指令集的程序甚至包括AVX512都可以模拟的出来但是我用这个东西运行Darling的时候还是报错了可能Darling需要用到内核的一些特性但是SDE不能模拟……这都没办法是不是就彻底没办法了呢
在偶然的一次浏览中,我发现了一个神奇的东西,内核扩展[OPEMU](https://github.com/mirh/opemu-linux)它可以让不支持一些指令集扩展的CPU通过模拟的方式支持其实功能和SDE很像只是它是在内核中运行的我试着在第一台机器上编译安装了一下顺便一说如果是旧的5.x或者更早的Linux可以直接用这个仓库而更新的Linux比如6.x的需要用[PR](https://github.com/Spacefish/opemu-linux)中的这个仓库结果Darling真的可以运行了真是令人难以置信。
安装成功之后我在网上找了个C语言的程序[endoh1](https://github.com/ioccc-src/winner/tree/master/2012/endoh1)这个程序可以用文本模拟流体。我在我的MacBook上编译了试了一下运行没有问题当然直接编译的程序是ARM64的程序肯定不能在Darling里面运行于是我切换到x86_64模式下又编译了一次并且用`lipo`命令把两个程序合并到了一起然后把程序上传到第一台机器中使用Darling运行竟然可以正常运行看来那个内核扩展还不错啊Darling居然没有出问题。
安装成功之后我在网上找了个C语言的程序[endoh1](http://www.ioccc.org/2012/endoh1/hint.html)这个程序可以用文本模拟流体。我在我的MacBook上编译了试了一下运行没有问题当然直接编译的程序是ARM64的程序肯定不能在Darling里面运行于是我切换到x86_64模式下又编译了一次并且用`lipo`命令把两个程序合并到了一起然后把程序上传到第一台机器中使用Darling运行竟然可以正常运行看来那个内核扩展还不错啊Darling居然没有出问题。
不过测试了一下可能还是有些地方有BUG比如用Git的时候会报错可能是和README中所说的CRC32表现有问题吧不过Darling好像可以直接运行Linux中的命令那我在用Git的时候调用Linux下的Git是不是也可以呢试了一下不太行因为执行Linux程序的时候不能用Darling中的目录结构不过我想装omz只需要/Users目录就够了我直接创建一个软链接把Darling的/Users目录映射到Linux的根目录就可以了吧试了一下还行可以正常运行虽然Homebrew不能安装有点可惜……不过Neofetch可以安装😆效果如下
```
'c. root@localhost.localdomain

View File

@ -15,7 +15,7 @@ tags: [压缩包, Quine, 自产生程序, Quine Relay]
关于原理方面,先看[Will Greenberg](https://github.com/wgreenberg)制作的一个[示例](https://wgreenberg.github.io/quine.zip/)在这里面有一个谜题使用“print M”原样输出接下来的M行输入内容和“repeat M N”从倒数第N行的输出内容开始重复M行这两个指令让最终执行的结果和输入的指令完全相同。这正是对DEFLATE压缩算法所使用的LZ77编码的一种简化模拟也就是说只要解决了这个问题就可以让压缩包在解压时原样输出自己了。
这个问题看起来还挺复杂,不过在仓库的[Issues](https://github.com/wgreenberg/quine.zip/issues/1)就有人给出了几种解法(当然,这个题目解法不唯一),所以在理论上应该是可行的,那么接下来就需要研究压缩文件的格式来实现它了。
## 实现ZIP Quine的探索
在[Russ Cox](https://swtch.com/~rsc/)写的[Zip Files All The Way Down](https://research.swtch.com/zip)文章中同样说明了这个原理而且给出了一个方案让上述这两个命令除了能够对命令本身的重复以外还可以添加一些额外数据这样才能做到构建一个压缩包文件。按照文章的描述如果用之前谜题的规则来说我们设头和尾的内容都是“print 0”那么Cox给出的方案如下
在[Russ Cox](https://swtch.com/~rsc/)写的[Zip Files All The Way Down](https://research.swtch.com/zip)文章中同样说明了这个原理而且给出了一个方案让上述这两个命令除了能够对命令本身的重复以外还可以添加一些额外数据这样才能做到构建一个压缩包文件。按照文章的描述如果用之前谜题的规则来说我们设头和尾的内容都是“print 0”那么Cox给出的方案如下
```
print 0
print 2
@ -56,14 +56,13 @@ print 0
另外这个方案是针对使用基于LZ77与哈夫曼编码的DEFLATE压缩算法所以格式不重要。因此无论是ZIP还是GZIP以及TGZGZIP压缩后的TAR其实都是一样的因为他们都使用的是DEFLATE压缩算法。顺便一提[Matthew Barber](https://github.com/honno)写了一篇很棒的[文章](https://github.com/honno/gzip-quine)通过动画演示并详细讲解了如何实现一个简单的GZIP版ZIP Quine很值得一看。
还有一点普通的TAR文件能否实现类似功能呢从原理来说估计不行因为TAR文件本身并没有压缩也不包含指令就单纯是一堆文件和元数据的拼接所以就做不到自包含了。
这么来看既然TGZ可以那是不是在我博客网站的压缩包里放一份和自己一模一样的压缩包是可行的很遗憾按照这个方法来看是做不到的由于压缩格式和编码的限制这个方案在实际实现时发现操作码需要是5个字节最后发现最多只有类似`repeat 64 64`这样的指令能够满足要求因此头尾区最多只能放64-5=59个字节的数据也就刚刚好能容纳压缩格式需要的内容几乎没法塞更多东西进去……显然这些限制导致这种方式对我来说意义就不大了何况作者的代码我也看不懂……而且还要考虑压缩包还存在校验用的CRC32需要找满足整个压缩包的CRC32正好在压缩包中的“不动点”。虽然从CRC32的原理来说应该有办法做到通过数学方式解决但这篇文章的作者因为解决了自包含的问题之后累了因此放弃继续研究选择直接暴力破解毕竟CRC32只有32位估计思考的时间都要比爆破的时间长吧😂。但如果是这样即使有方案能存下我博客的数据也不能在每次网站构建的时候都制作一次了……
虽然Russ Cox写的文章看起来做不到包含更多内容了但Erling Ellingsen制作的droste.zip却包含了一张图片说明并不是没办法加入更多数据只是没有找到正确的方法。在2024年[Ruben Van Mello](https://github.com/ruvmello)写了一篇论文[A Generator for Recursive Zip Files](https://www.mdpi.com/2076-3417/14/21/9797),在这篇论文里他不仅解决了包含的额外数据过少的问题,还编写了一个通用工具,能让普通人也能生成这样的压缩包,而且他还创新性的做了一种像衔尾蛇一样的双层嵌套循环压缩包,非常的有意思,所以接下来我打算试试他的方案。
虽然Russ Cox写的文章看起来做不到包含更多内容了但Erling Ellingsen制作的droste.zip却包含了一张图片说明并不是没办法加入更多数据只是没有找到正确的方法。在2024年[Ruben Van Mello](https://github.com/ruvmello)写了一篇论文[A Generator for Recursive Zip Files](https://www.mdpi.com/2076-3417/14/21/9797),在这篇论文里他不仅解决了包含的额外数据过少的问题,还编写了一个通用工具,能让普通人也能生成这样的压缩包,而且他还创新性的做了一种像衔尾蛇一样的双层嵌套循环压缩包,非常的有意思,所以接下来我打算试试他的方案。
在这篇论文中里面简述了之前Russ Cox写的内容也提到了59字节的限制于是作者对原有的结构进行了一些改动让操作码可以超出5字节的限制具体可以看论文的表6从而解决了只能包含59字节额外数据的限制。但由于DEFLATE压缩格式本身的约束16位存储块长度以及32KiB回溯窗口即使能够添加文件最多也只能额外容纳32763字节的数据其中包括压缩包所需的文件头……显然这点空间完全存不下我的博客😭看来我只能打消这个想法了。但既然都研究了半天也不一定要存我的博客嘛可以看看还有没有别的东西可以存在这之前先继续阅读论文看完再说吧。
## 制作一个嵌套循环的ZIP Quine
在实现了常规的ZIP Quine之后接下来就是作者的创新点了如果光是解决存储限制这点创新点估计还不够发论文吧😂。作者接下来制作了一种循环压缩文件在压缩包内包含文件A和压缩包A而压缩包A中则包含文件B和最初的压缩包从而形成一个循环递归的结构。看论文的描述所说如果把外层的压缩包和内层的压缩包的开头和结尾按照一定的规则交替混合就可以看作是一个整体然后按照之前做ZIP Quine那样处理就可以……具体实现的细节得看论文的表10。只不过既然是把两个压缩包看作一个整体的话按照上面的限制自然每个压缩包能容纳的数据量就更小了每个最多只能容纳16376字节的数据……
另外既然这里面有两个压缩包那么每个压缩包还有自己的CRC32校验和理论上如果要爆破的话计算难度得是原来的平方这样难度就太大了。不过作者发现如果把数据的CRC32值取反即与“0xFFFFFFFF”取异或然后和原始数据拼到一起整个数据的CRC32校验和就会被重置为一个固定的值“0xFFFFFFFF”看起来挺有意思正常的哈希算法可没有这种特性。因此原本计算难度很大的爆破计算现在就可以和之前一样了…… ~~话说为什么不让两层的CRC32都这样计算包括之前单层的ZIP Quine这样就不需要爆破了……貌似是因为在普通的ZIP Quine中满足条件的CRC32需要出现两次所以不能用这个方案吧~~
在实现了常规的ZIP Quine之后接下来就是作者的创新点了如果光是解决存储限制这点创新点估计还不够发论文吧😂。作者接下来制作了一种循环压缩文件在压缩包内包含文件A和压缩包A而压缩包A中则包含文件B和最初的压缩包从而形成一个循环递归的结构。看论文的描述所说如果把外层的压缩包和内层的压缩包的开头和结尾按照一定的规则交替混合就可以看作是一个整体然后按照之前做ZIP Quine那样处理就可以……具体实现的细节得看论文的表10。只不过既然是把两个压缩包看作一个整体的话按照上面的限制自然每个压缩包能容纳的数据量就更小了每个最多只能容纳16376字节的数据……
另外既然这里面有两个压缩包那么每个压缩包还有自己的CRC32校验和理论上如果要爆破的话计算难度得是原来的平方这样难度就太大了。不过作者发现如果把数据的CRC32值取反即与“0xFFFFFFFF”取异或然后和原始数据拼到一起整个数据的CRC32校验和就会被重置为一个固定的值“0xFFFFFFFF”看起来挺有意思正常的哈希算法可没有这种特性。因此原本计算难度很大的爆破计算现在就可以和之前一样了……话说为什么不让两层的CRC32都这样计算包括之前单层的ZIP Quine这样就不需要爆破了……貌似是因为在普通的ZIP Quine中满足条件的CRC32需要出现两次所以不能用这个方案吧
现在所有的理论都足够了我需要挑一个文件来做这样嵌套循环的ZIP Quine既然博客的大小不可以……要不然我就用我写过的第一个大项目——[Mabbs](https://github.com/Mabbs/Mabbs.Project)吧这个项目的主程序是22KiB看起来似乎超出了嵌套循环ZIP Quine的限制其实没有它的限制指的是压缩后的大小我这个程序压缩之后是8KiB左右所以完全没问题。
接下来就该使用论文中提到的生成工具:[zip-quine-generator](https://github.com/ruvmello/zip-quine-generator)这是一个Kotlin编写的程序从发布中可以下载预构建的程序接下来只要按照README中的描述使用“`--loop`”参数就可以用这个程序创建嵌套循环的ZIP Quine了。不过它原本的代码不能修改里面生成的压缩包的名字另外[压缩后的文件属性是隐藏文件](https://github.com/ruvmello/zip-quine-generator/blob/3b8cf977e7a93bb956ad966d5e3b4d503f410529/src/main/kotlin/zip/ZIPArchiver.kt#L845),还有[生成的压缩包中文件的创建时间总是当前时间](https://github.com/ruvmello/zip-quine-generator/blob/3b8cf977e7a93bb956ad966d5e3b4d503f410529/src/main/kotlin/zip/ZIPArchiver.kt#L29),以及[给文件内填充额外数据的代码里面填的是作者的声明](https://github.com/ruvmello/zip-quine-generator/blob/3b8cf977e7a93bb956ad966d5e3b4d503f410529/src/main/kotlin/zip/ZIPArchiver.kt#L30)表示文件是由他论文的所写的生成器生成的……这些情况让我感觉有点不爽还是希望这些部分能自定义一下所以我就小改了一下他的代码。顺便一说Kotlin编译起来还挺简单直接一句`kotlinc src/main/kotlin -include-runtime -d output.jar`就可以了也不需要折腾Maven之类乱七八糟的东西。最终我修改并编译完程序之后就把文件丢到服务器上开始给我爆破CRC32了花了10个小时就算出来了倒是比想象中快😂。
2025.09.26更新在2025年9月15日的时候[Nate Choe](https://github.com/NateChoe1)给zip-quine-generator做了个[重大贡献](https://github.com/ruvmello/zip-quine-generator/pull/3),他通过[数学的方式](https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm)让CRC32的值可以不需要通过爆破的方式算出来现在想要再制作这样的压缩包就可以瞬间生成了……要是我再晚点做这个压缩包就不需要花那么长时间了吧🤣。
最终我给我的[Mabbs](https://github.com/Mabbs/Mabbs.Project)项目创建了[Infinite Mabbs](https://github.com/Mabbs/Mabbs.Project/releases/tag/Final-version)这个发布,生成的文件也可以在[这里](/assets/Mabbs.zip)下载,这也算是不枉我研究半天这个论文了😆。
# 自产生程序的探索
@ -78,7 +77,7 @@ c = 'c = %r; print(c %% c)'; print(c % c)
```
D'<;_98=6Z43Wxx/.R?Pa
```
代码就像加了密似的,顺便一说这个执行的输出结果是“Mayx”关于Malbolge的具体细节可以看它的[规范](http://www.lscheffer.com/malbolge_spec.html),另外虽然这个语言写起来很复杂,但还是有人能用它编出程序的,甚至还有人用[Malbolge Unshackled](https://esolangs.org/wiki/Malbolge_Unshackled)Malbolge不限内存的变种写过[Lisp解释器](https://github.com/iczelia/malbolge-lisp),实在是恐怖如斯😨。
代码就像加了密似的顺便一说这个执行结果是“Mayx”关于Malbolge的具体细节可以看它的[规范](http://www.lscheffer.com/malbolge_spec.html),另外虽然这个语言写起来很复杂,但还是有人能用它编出程序的,甚至还有人用[Malbolge Unshackled](https://esolangs.org/wiki/Malbolge_Unshackled)Malbolge不限内存的变种写过[Lisp解释器](https://github.com/iczelia/malbolge-lisp),实在是恐怖如斯😨。
## 只能Quine的语言
其实想要做出Quine还有一种更加无聊的方案那就是设计一种只能Quine的语言🤣。根据Quine的定义代码输出的结果就是它本身……所以我们可以把任何内容都看作代码然后这种语言的行为就是输出所有代码……听起来是不是有点无聊但是想想看如果把Linux中的cat命令当作解释器就可以实现这种语言了比如
```
@ -87,12 +86,8 @@ Hello, world!
```
作为脚本执行的结果就是原样输出这段内容不过把内容当作代码算不算作弊呢……如果看作是cat的输入显然是作弊但如果是当作源代码的话应该就不算了吧😋……但这就不是能写出逻辑的语言了。所以说Quine的趣味并不在“能不能实现”而在于如何在限制条件下实现。正是因为大多数语言不会直接“自我输出”才会觉得那些精巧的Quine程序如此有意思。
## Quine Relay的探索
还有一个更加复杂的Quine变种是“Quine接力”Quine Relay即一个程序输出另一个程序的源代码另一个程序又输出下一个程序的源代码最后回到原始程序就和之前所说的嵌套循环ZIP Quine有点类似。最著名的例子是[Yusuke Endoh](https://github.com/mame)(这位还是[IOCCC](https://www.ioccc.org/)的冠军之一)创建的[quine-relay](https://github.com/mame/quine-relay)项目它包含了128种编程语言的循环。
还有一个更加复杂的Quine变种是“Quine接力”Quine Relay即一个程序输出另一个程序的源代码另一个程序又输出下一个程序的源代码最后回到原始程序就和之前所说的嵌套循环ZIP Quine有点类似。最著名的例子是[Yusuke Endoh](https://github.com/mame)(这位还是[IOCCC](https://www.ioccc.org/)的冠军之一)创建的[quine-relay](https://github.com/mame/quine-relay)项目它包含了128种编程语言的循环。
这种程序写起来会更复杂一些不过原理都差不多通常除了当前运行的部分是可执行代码外其他的代码都需要以额外包含的数据形式如字符串存储在变量中。如果想自己做个类似简单的Quine Relay除了去看[维基百科](https://en.wikipedia.org/wiki/Quine_(computing)#Ouroboros_programs)之外,前段时间我还看到过一个不错的[文章](https://blog.mistivia.com/posts/2024-09-21-quine/)里面就讲了如何用“笨办法”编写Quine和Quine Relay通过把变量中的内容编码为16进制来避免不同语言可能存在的特殊字符转译问题思路不错对于理解如何编写这类程序的问题很有帮助。当然这只是个**简单**的方案,仅适用于一些常规的编程语言,像上面那个[quine-relay](https://github.com/mame/quine-relay)项目中甚至还包含Brainfuck之类的esolang这种估计得要想办法让相对高级一些的语言通过“生成”的方式得到输出下一种代码的代码而不是简单的赋值了所以只靠这点知识想去完全理解大佬的作品还是想多了😆。
顺便一说quine-relay并不是那位大佬唯一的Quine作品他还做过[有冗余的Quine](https://github.com/mame/radiation-hardened-quine)以及[动态的Quine](https://mamememo.blogspot.com/2010/09/qlobe.html),真的是相当的厉害……
## Polyglot Quine的探索
除了Quine Relay之外还有一种很复杂的Quine叫做[Polyglot](https://en.wikipedia.org/wiki/Polyglot_(computing)) Quine与Quine Relay需要在程序执行后才能切换到其他语言接力不同Polyglot Quine的源代码本身即可同时属于多种语言而且用这些语言的解释器每个执行后的输出全都一样都与源代码完全一致。由于不同的编程语言的格式既有些相同之处也有很多不同之处所以让同一份代码表示不同语言就会很容易产生歧义这时候就只能想办法通过一些特别的方式比如将可能会对当前语言产生干扰的代码看作是注释的方式来规避语言之间的差异。
Quine本身就已经很困难了再加上这些限制就变得更加复杂了所以制作Polyglot Quine的编程语言基本上都得精挑细选而且通常只有两种语言比如[这段代码](https://github.com/TrAyZeN/polyglot-quine/blob/master/main.c)就是C和Python的Polyglot Quine它巧妙利用了C预处理器指令在Python中可视为注释的特性使两种语言互不干扰非常有趣。当然并不是说只能是两种语言像[这个](https://github.com/2KAbhishek/polyquine)项目甚至使用了五种语言C、Perl、PHP、Python、Ruby可以说是相当厉害了。除此之外更令人惊叹的则是[PyZipQuine](https://github.com/d0sboots/PyZipQuine)项目在这其中LZ77编码也可以作为一种语言所以既可以被当作压缩包也可以作为Python2.7代码而且二者都是Quine实在是令人赞叹。
# 感想
虽然这次探索最终没能完成让包含博客所有内容的压缩包自包含但是在探索的过程中我还是收获了不少尤其是Ruben Van Mello制作的ZIP Quine生成工具实在是太棒了。很久以前我见到droste.zip这个压缩包的时候就想整一个属于自己的ZIP Quine现在我不仅用那个生成工具做了一个还是对我来说很有意义的第一个项目——Mabbs而且更关键的还是生成的是比普通的ZIP Quine更高级的嵌套循环ZIP Quine也算是圆了小时候的心愿了。

View File

@ -1,29 +0,0 @@
---
layout: post
title: 一次找回GitHub上被删除仓库的经历
tags: [GitHub, Git, 代码恢复, 软件存档]
---
在GitHub中寻找踪迹也许是非常简单的事情……<!--more-->
# 起因
前段时间,有人和我聊天的时候提到了[Brainfuck](https://esolangs.org/wiki/Brainfuck)语言,让我回想起了高中时写的[演讲稿](/%E6%BC%94%E8%AE%B2%E7%A8%BF/2018/06/20/Coding.html)。那时候我在演讲时也介绍了Brainfuck语言。对于Brainfuck的解释器[各种语言都可以实现](https://rosettacode.org/wiki/RCBF)不过我当时为了方便理解用了一个在GitHub Pages上的网站用可视化的方式演示了它的运行过程效果很不错。现在既然聊到了自然就想分享一下这个[演示的网站](https://fatiherikli.github.io/brainfuck-visualizer/)但我正想打开时发现网站已经404了😰。
在GitHub Pages上的网站都有对应的仓库现在不仅原仓库消失了连作者的[首页](https://github.com/fatiherikli)都打不开看样子是完全退出GitHub了……那么我想找到这个网站的想法就无法实现了吗不过GitHub有些有意思的特性也许能帮助我找回这个网站。
# GitHub的特性
在GitHub中一个普通的仓库可能没有什么特别的也许就是服务器上的一个文件夹。但是当仓库被其他人Fork的时候就不一样了在执行Fork时显然GitHub不会完整复制整个仓库。否则同一个仓库在服务器上会占用双倍空间这显然不合理。另外想想Git的结构它由提交对象和分支指针构成每次提交都有唯一的Hash值且不会冲突。因此可以推测GitHub在实现Fork时所有被Fork的仓库可能共享同一个对象库而每个用户仓库只保存指针这样所有仓库只会占用增量空间而不会存储重复内容。
但这样也会带来一个问题首先因为很多人可能要共用一部分对象所以也很难确认对象的所有权而且也因为这个原因所有的对象要能被所有人访问。因此在整个Fork网络中只要有一个仓库存在GitHub就必须保留所有的对象而且每个仓库都能访问这个网络中所有的对象。为了验证这一点我们可以用最知名的[Linux内核仓库](https://github.com/torvalds/linux)做个示例。
首先对Linux仓库进行Fork然后我们可以随便做一些改动比如在README中写“Linux已经被我占领了😆”之类的内容提交到自己的仓库并且记下提交的Hash值接下来就可以把自己的仓库删掉了。如果上面的猜想是正确的那么在这个Fork网络中的任何一个仓库查看我刚刚的提交应该都可以于是我直接在主仓库拼上了[提交的Hash值](https://github.com/torvalds/linux/tree/78e1d0446b94012da8639aa2b157d4f2dee481ce)(顺便一说只要值唯一,和其他的提交不冲突,[短的Hash值](https://github.com/torvalds/linux/tree/78e1d044)也可以果不其然能找到刚刚修改的内容这样一来只要GitHub和任意一个Linux仓库的Fork还存在这个提交就永远存在了😝。
# 找回仓库
那么接下来找回之前网站的方案就很简单了我只要找到网站仓库的任意一个Fork然后只要知道最新的提交Hash我就可以还原最新的仓库了。Fork倒是好找随便搜一下[就能找到一个](https://github.com/ashupk/brainfuck-visualizer)。这个Fork的最新提交是2016年但要想找到我当年演讲的版本至少到2018年之后。不过这个Hash值也不太好找虽然理论上爆破短Hash值也可以但是感觉太麻烦了没有那个必要所以我干脆直接去互联网档案馆看看能找到的[最新的仓库页面](https://web.archive.org/web/20201229125043/https://github.com/fatiherikli/brainfuck-visualizer/)吧这样我就能找到它的Hash值了然后我再把Fork仓库的地址和Hash拼到一起就看得到最新代码了。
当然仅仅看到代码还不够。我想Fork这个项目并在自己的GitHub Pages上部署一份。有没有什么好办法可以将我仓库的HEAD指针指向最新的提交呢其实很简单首先我要Fork这个Fork仓库然后Clone我的仓库到本地。不过此时Clone下来的仓库并不包含GitHub上完整的对象库因此直接checkout或reset是不行的。这时Hash值就派上用场了通过fetch拉取对应提交后就可以进行上述操作。具体命令如下
```bash
git fetch origin <commit-hash>
git reset --hard <commit-hash>
git push origin master
```
最终我就获得了包含[最新代码](https://github.com/Mabbs/brainfuck-visualizer)的[Brainfuck可视化演示](https://mabbs.github.io/brainfuck-visualizer/)了🎉。
# 结局
后来我才知道,原来有一个专门的组织[Software Heritage](https://archive.softwareheritage.org)会保存所有代码,根本没必要搞这些花里胡哨的操作😂,像这个仓库也是能很轻易在[上面](https://archive.softwareheritage.org/browse/origin/directory/?origin_url=https://github.com/fatiherikli/brainfuck-visualizer)找到这下以后知道了再遇到类似情况就可以直接去Software Heritage查找而不必在互联网档案馆上找线索瞎折腾了🤣。

View File

@ -1,91 +0,0 @@
---
layout: post
title: 让博客永恒的探索
tags: [Git, Gitea, 镜像, Forever]
---
Mayx Forever Project Phase II<!--more-->
# 起因
在前段时间,我通过[Ecosyste.ms: Repos](https://github.com/ecosyste-ms/repos)找到了不少Git平台的实例也在探索的过程中发现和了解了[Tilde社区](/2025/08/10/tilde.html)。当然仅仅是这样显然还不够,里面的实例太多了,显然还有一些其他值得探索的东西。
在我查看这里面的某些Gitea实例时发现了一些奇怪的事情有些实例的仓库数和用户数多得离谱正常来说除了几个大的平台绝大多数应该只有几十到几百个仓库这就让我有点好奇了。于是当我点进去之后发现里面有一大堆仓库都是空的而且用户名和仓库名都非常有规律看起来都是一组单词加4位数字命名的显然这不是正常现象应该是一种有组织的行为。
# 被SPAM滥用的Git实例
于是我就简单看了一下这些异常的仓库和用户的规律可以发现每个用户都填了个人主页地址然后个人简介里大都是一段广告词。另外这些个人主页的地址看起来很多都是利用公开可注册的服务比如开源的有各种Git平台、Wiki以及论坛还有一些允许用户写个人主页的新闻网站。在这其中Git平台大多都没有广告文章基本上都是通过个人主页地址链接到网站而Wiki之类的就会写一些篇幅比较长的广告文章。
另外这些平台但凡还在开放注册就会被以大约每分钟一次的速度自动注册新账号……所以这种事情到底是谁在干呢我翻了几个仓库里面的广告多种多样有些看起来还算正常还有一些看起来有些黑产。其中我发现有一家叫做“悠闲羊驼SEO”的网站看介绍主要是给加密货币、对冲基金和博彩网站提供SEO优化的再加上这些被滥用的平台里也有不少类似的广告所以我怀疑这些滥用的行为就是这家SEO公司做的虽然没有证据😂
# 永恒的探索
看到这么多Git平台被滥用我就有个想法之前为了保证可靠性给博客加了不少[镜像](/proxylist.html),除此之外也在互联网档案馆、[Software Heritage](https://archive.softwareheritage.org/)、Git Protect等存档服务中上传了备份而且也在IPFS和Arweave等Web3平台上有相应的副本但是我觉得还不够再大的平台也有可能会倒闭IPFS不Pin还会被GC至于Arweave前段时间看了一眼整个网络才几百个节点感觉一点也不靠谱……所以我应该好好利用这些平台提高我博客的可靠性。
既然那些Spammer只是为了SEO去滥用这些平台不如让我利用这些平台给我的博客进行镜像吧至于使用哪个平台……显然用Git平台方便一些所以接下来就该考虑一下怎么样分发了。
# 镜像的分发
在Git平台中也有很多选择最知名的是GitLab不过GitLab有点复杂接口不太好用……而且很多实例没有开镜像仓库的功能毕竟如果我每次更新都给一堆仓库推送太费时间了我打算让各个平台主动从GitHub上拉取我的最新代码。正好Gogs系列的平台基本上都默认支持镜像仓库不过在我实际使用的时候发现Gogs默认情况下注册要验证码……写识别验证码感觉又挺麻烦而Gogs的两个分支——Gitea和Forgejo反倒没有……还挺奇怪所以接下来我的目标主要就是Gitea和Forgejo的实例了。
既然决定好目标我就得先发现它们了那些Spammer在注册的时候会在个人主页里写不同的网站其中也有一些类Gogs平台那么我可以先找一个Gitea平台用接口读取这些网站然后再调类Gogs专属的接口来检测这些网站哪个是类Gogs平台于是我就写了个[脚本](https://github.com/Mabbs/spam_gogs-like_scanner/blob/main/main.py)来找到它们。
找到这些平台之后就该注册了还好Gitea和Forgejo默认没有验证码注册起来也很简单随便写了个函数实现了一下
```python
def register_account(session, url, email, username, password):
try:
resp = session.get(url + "/user/sign_up")
soup = BeautifulSoup(resp.text, "html.parser")
csrf_token = soup.find("input", {"name": "_csrf"}).get("value")
payload = {
"_csrf": csrf_token,
"user_name": username,
"email": email,
"password": password,
"retype": password,
}
headers = {"Content-Type": "application/x-www-form-urlencoded"}
resp = session.post(url + "/user/sign_up", data=payload, headers=headers)
if "flash-success" in resp.text:
print(
f"Successfully registered at {url} with username: {username}, email: {email}, password: {password}"
)
save_to_file(
"instances_userinfo.csv", f"{url},{username},{email},{password}"
)
return True
else:
print(f"Failed to register at {url}.")
return False
except Exception as e:
print(f"Error registering at {url}: {e}")
return False
```
注册完之后就该导入仓库了只是通过模拟前端发包的方式在Gitea和Forgejo中不同版本的表现可能不太一样所以我想用API实现但是API又得有API Key生成API Key还得模拟前端发包😥……所以怎么都绕不过。
不过这个生成API Key还挺麻烦有些版本不需要配权限范围有些配权限的参数还不一样……不过我就是随便一写凑合用吧像那些专业的Spammer应该是有更强大的脚本判断各种情况。
最后我还是选择用API导入又写了个函数
```python
def import_repos(token, url):
try:
response = requests.post(
url=url + "/api/v1/repos/migrate",
headers={
"Authorization": "token " + token,
},
json={
"repo_name": "blog",
"mirror_interval": "1h",
"mirror": True,
"description": "Mayx's Home Page",
"clone_addr": "https://github.com/Mabbs/mabbs.github.io",
},
)
if response.status_code == 201:
print("Repository import initiated successfully.")
save_to_file("repo_list.txt", url + "/mayx/blog")
return True
else:
print(f"Failed to initiate repository import. Status code: {response.status_code}")
print(f"Response: {response.text}")
return False
except Exception as e:
print(f"Error updating website: {e}")
return False
```
脚本写好之后我就只需要重复扫描、注册、导入的步骤就行了这样我的镜像就会越来越多而且用类Gogs的实例还有一个好处就是不需要我手动推送它会自动定时拉取我的仓库保持最新这样也许只要人类文明存在我的博客就会在某处存在吧🤣。
最后我创建的Git镜像可以在[这里](/other_repo_list.html)看到看起来还是挺壮观啊😋。只不过像这种会被Spammer随便注册的Git平台实例很难说它能活多久如果没人管而且是云服务器也许到期就没了有人管的话应该不会允许这么多Spam行为吧……
# 感想
不知道用“量”来确保博客的永恒更可靠……还是用“质”的方式更好呢?其实我觉得还得是活动的更好,就像我以前所说的,如果有[僵尸网络](/2024/11/02/trojan.html#%E6%84%9F%E6%83%B3),自动帮我执行发现并推送的操作,也许比等着这些实例逐渐消失更好吧……只不过那样可能就不太友好了😂。

View File

@ -1,38 +0,0 @@
---
layout: post
title: 在浏览器中运行Linux的各种方法
tags: [浏览器, Linux, 虚拟机, WASM]
---
浏览器已经无所不能了!<!--more-->
# 起因
前段时间跟网友交流时有人展示了他博客里的一个Linux终端模拟项目[jsnix](https://github.com/Erzbir/jsnix)看起来挺有意思的里面甚至还藏了一个CTF。不过我感觉他这个终端和博客本身并没有真正联动起来本质上只是一个模拟了Linux Shell行为的交互界面。除此之外我还发现了另一个风格类似的[个人主页](https://github.com/Luyoung0001/myWebsite)它虽然也走了终端风格但功能更简单还原度也不算高。不过它至少和博客内容做了一些基础联动——尽管目前也只是做到列出文章这种程度😂当然有这类功能的博客应该也不少只是我发现的不太多……于是我就想不如我也给自己的博客加一个类似的“命令行访问”功能应该会很有趣。当然如果真要做的话我肯定不会满足于只实现几个模拟指令——既然要做就要追求真实感至少得在浏览器上运行真实的Linux终端才不会让人觉得出戏吧😋。
# 在浏览器中运行Linux
## 虚拟机方案
### 纯JS虚拟机
要说到在浏览器上运行Linux最先想到的应该就是[Fabrice Bellard](https://bellard.org)大神写的[JSLinux](https://bellard.org/jslinux/)吧这可能是第一个在浏览器中实现的虚拟机毕竟是最强虚拟机QEMU的作者编写的。现在他的个人主页中展示的这个版本是WASM版本而他最早写的是纯JS实现的。那个JS实现的版本现在在GitHub上有一个[去混淆的版本](https://github.com/levskaya/jslinux-deobfuscated)可以用作学习和研究于是我顺手Fork了一份在GitHub Pages上部署作为[演示](https://mabbs.github.io/jslinux/)。
作为纯JS实现的x86虚拟机性能估计是最差的但相应的兼容性也最好在Bellard当年写JSLinux的时候还没有WASM这种东西呢所以即使是在不支持WASM的IE11中也可以正常运行。假如我想把它作为终端用在我的博客上似乎也是个不错的选择即使我完全看不懂代码不知道如何实现JS和虚拟机的通信它也预留了一个剪贴板设备可以让我轻松地做到类似的事情比如我在里面写个Bash脚本通过它和外面的JS脚本联动来读取我的文章列表和内容那也挺不错。
当然Bellard用纯JS编写虚拟机也不是独一份他实现了x86的虚拟机相应的也有人用纯JS实现了RISC-V的虚拟机比如[ANGEL](https://github.com/riscv-software-src/riscv-angel),看起来挺不错,所以同样也顺手[搭了一份](https://mabbs.github.io/riscv-angel/)。只不过它似乎用了一些更先进的语法至少IE11上不能运行。
另外还有一个比较知名的项目,叫做[jor1k](https://github.com/s-macke/jor1k)它模拟的是OpenRISC架构。只是这个架构目前已经过时基本上没什么人用了不过这里面还内置了几个演示的小游戏看起来还挺有意思。
除了这些之外其实能在浏览器上运行的Linux也不一定是个网页有一个叫做[LinuxPDF](https://github.com/ading2210/linuxpdf)的项目可以让Linux运行在PDF中它的原理和JSLinux差不多所以需要PDF阅读器支持JS看它的介绍貌似只能在基于Chromium内核的浏览器中运行而且因为安全问题在PDF中有很多功能不能用所以它的速度甚至比JSLinux还要慢功能还很少因此它基本上只是个PoC没什么太大的意义。
### WASM虚拟机
那还有别的方案吗既然Bellard都选择放弃纯JS的JSLinux而选择了WASM显然还有其他类似的项目比如[v86](https://github.com/copy/v86)这也是一个能在浏览器中运行的x86虚拟机不过因为使用了WASM和JIT技术所以效率要比纯JS的JSLinux高得多。另外作为虚拟机自然是不止能运行Linux其他的系统也能运行在示例中除了Linux之外还有DOS和Windows之类的系统功能还挺强大如果能自己做个系统镜像在博客里运行似乎也是不错的选择。
另外还有一个相对比较知名的叫[WebVM](https://github.com/leaningtech/webvm)从效果上来说和v86几乎没有区别同样使用了WASM和JIT技术也都只支持32位x86然而它的虚拟化引擎CheerpX是闭源产品既然和v86都拉不开差距不知道是谁给他们的信心把它作为闭源产品😅。不过看它的说明文档其相比于v86的主要区别是实现了Linux系统调用考虑到它不能运行其他操作系统而且Linux内核也不能更换那我想它可能是类似于WSL1的那种实现方案也许性能上会比v86好一些吧……只不过毕竟是闭源产品不太清楚具体实现了。
既然纯JS有RISC-V的虚拟机WASM当然也有比如[WebCM](https://github.com/edubart/webcm)。这个项目相比于其他的项目有个不太一样的地方它把虚拟机、内核以及镜像打包成了一个单独的WASM文件……只是这样感觉并没有什么好处吧改起来更加复杂了。
以上这些虚拟机方案各有不同,但是想做一个自己的镜像相对来说还是有点困难,于是我又发现了另一个项目:[container2wasm](https://github.com/container2wasm/container2wasm)它可以让一个Docker镜像在浏览器中运行当然实际实现其实和Docker并没有什么关系本质还是虚拟机只是制作镜像的时候可以直接用Docker镜像方便了不少但Docker镜像一般也都很大所以第一次加载可能要下载很长时间。另外它还有一个优势可以使用[Bochs](https://bochs.sourceforge.io/)运行x86_64的镜像不像v86和WebVM只能模拟32位的x86虽然Bochs的运行效率可能会差一些而且可以使用WASI直接访问网络不像以上几个项目如果需要访问网络需要用到中继服务。当然访问网络这个还是要受浏览器本身的跨域策略限制。总之从项目本身来说感觉也算是相当成熟了尤其能用Docker镜像的话……我甚至可以考虑直接用[镜像](https://hub.docker.com/r/unmayx/mabbs)在线演示我曾经的[Mabbs](https://github.com/Mabbs/Mabbs.Project)项目😋。
## 纯WASM方案
其实想要在浏览器中运行Linux也不一定非得要用虚拟机用虚拟机相当于是把其他指令集的机器码翻译为WASM然后浏览器还得再翻译成宿主机CPU支持的指令集然而WASM本身其实也算是一种指令集各种编译型语言编写的程序也能编译出WASM的产物比如[FFmpeg](https://github.com/ffmpegwasm/ffmpeg.wasm)。所以Linux内核也完全可以被编译成WASM正好前段时间我看新闻说[Joel Severin](https://github.com/joelseverin)做了这么一个[项目](https://github.com/joelseverin/linux-wasm)对Linux内核做了一些修改使其可以被编译为WASM程序我试了一下貌似在Safari浏览器中不能正常工作……Chrome浏览器倒是没问题不过即使这样用起来BUG也很多随便执行几条命令就会冻结体验不是很好。
沿着这个项目,我又找到一个由[Thomas Stokes](https://github.com/tombl)制作的[项目](https://github.com/tombl/linux)和Joel的项目差不多但我测了一下可以在Safari上运行感觉这个项目更完善不过之前那个项目上了新闻所以⭐数比这个更高😂。
于是我把它复制了一份在我的GitHub Pages上[部署](https://mabbs.github.io/linux/)了但直接用仓库中的源代码会显示“Error: not cross origin isolated”然而在Thomas自己部署的网站中可以正常打开我看了一眼貌似是因为在GitHub Pages中没有[COOP和COEP响应头](https://web.dev/articles/coop-coep)导致的。Linux作为多任务操作系统来说当然要运行多个进程而Linux要管理它们就需要跨线程Web Worker读取内存的能力所以用到了SharedArrayBuffer对象。不过由于CPU曾经出过“幽灵”漏洞导致现代浏览器默认禁止使用SharedArrayBuffer对象除非在服务器中配置COOP和COEP响应头才可以用但是Joel的项目也是在GitHub Pages上运行的啊为什么可以正常运行看了源代码后才发现原来可以[用Service Worker作为反向代理](/2025/08/01/sw-proxy.html)来给请求的资源加上响应头,他使用的是[coi-serviceworker](https://github.com/gzuidhof/coi-serviceworker)这个项目,所以我也给我部署的代码中加上了这个脚本,总算是解决了这个问题。
部署好这个项目之后我试用了几下虽然有些操作仍然会导致系统冻结但相比Joel的版本来说已经好多了。很遗憾的是目前这个WASM Linux还不能和外界通信所以作用不是很大另外如果想在里面运行其他二进制程序还是相当困难首先在WASM中不存在内存管理单元MMU不能实现隔离和分页的功能另外以WASM作为指令集的环境下编译的产物也得是WASM所以目前来说想用它做点什么还是不太合适。
以上的这两个将Linux内核编译为WASM的方案其实相当于给内核打补丁然后把浏览器看作是虚拟机来运行有点像Xen不过还有一种让Linux原生运行在WASM的[项目](https://github.com/okuoku/wasmlinux-project),它将[Linux kernel library](https://github.com/lkl/linux)编译为了WASM。那么什么是LKL简单来说它有点像Wine就和我之前所说的[OS模拟器](/2024/12/08/simulator.html)差不多可以提供一个环境让程序以为自己在Linux下运行所以说它和之前的实现有一些不一样它不存在内核模式更像是一个普通的程序而不是系统了。
不过这个项目的体验也比较一般,它无论做什么都得按两次回车,看说明的意思貌似是因为没有实现异步信号传递,所以要手动打断`read`函数而且也经常莫名其妙卡住总体体验不如Thomas的项目。
## 模仿的Linux
其实如果只是想做到和Linux类似的功能也有这样的项目比如[WebContainers](https://github.com/stackblitz/webcontainer-core)它没有运行Linux系统但是模拟了一个环境可以在浏览器中运行Node.js以及Python之类的脚本而且让脚本以为自己在Linux中运行除此之外它还能用Service Worker把环境中运行的端口映射给浏览器可以算是真的把服务端跑在浏览器上了。这个技术还挺高级不过想想也挺合理毕竟有WASI直接编译为WASM的程序也不需要操作系统就能运行所以用WASM去运行Linux本来就有点多此一举了😂。不过很遗憾的是WebContainers也不是开源软件要使用它只能引入StackBlitz的资源而且全网完全没有开源的替代品……也许在浏览器上进行开发本来就是个伪需求所以没什么人实现吧。
当然如果只是实现和WebContainers类似的功能[JupyterLite](https://github.com/jupyterlite/jupyterlite)也可以实现它可以在浏览器中像使用本地JupyterLab那样运行JS和Python还能用Matplotlib、Numpy、Pandas进行数据处理功能可以说非常强大而且还是开源软件。只不过它没有模拟操作系统的环境所以不能运行Node.js项目也不能提供终端所以不太符合我想要的效果……
# 总结
总的来说如果想要在博客上搞Linux终端目前来看似乎虚拟机方案会更靠谱一些虽然相对来说效率可能比较低但毕竟目前WASM方案的可靠性还是不够而且考虑到还需要配置额外的响应头感觉有点麻烦当然我觉得WASM还是算未来可期的如果成熟的话肯定还是比虚拟机要更好一些毕竟没有转译性能肯定要好不少。至于WebContainers这种方案……等什么时候有开源替代再考虑吧需要依赖其他服务感觉不够可靠。只是也许我的想法只需要模拟一个合适的文件系统然后给WASM版的Busybox加个终端就够了不过这样感觉Bug会更多😂。
至于打算什么时候给博客加上这个功能应该也是未来可期吧😝目前还没什么好的思路仅仅是分享一下在浏览器中运行Linux的各种方法。

View File

@ -1,20 +0,0 @@
---
layout: post
title: 年终总结
tags: [总结]
---
0 error(s), ∞ warning(s)<!--more-->
# 2025年的状态
在2025年感觉状态不如去年……由于没能做出正确的选择还是有点糟糕。不过总的来说还没有引发关键性的错误至少还能继续坚持下去。
在这一年中感觉记忆和思考能力都有所下滑看来是没把自己照顾好😂不过看看这一年写的文章看起来似乎比以前更流畅了这也许是因为和AI聊得多了以至于思维有点偏向AI了吧。
总的来说感觉自己的稳定性还是有点低了,但这可能不是我能独自解决的,也不知会有什么转机……
# 2025年发生的事情
回顾了一下[去年的年终总结](/2025/01/01/summary.html),发现自己还是没能做到知行合一,在这一年里全球各类资产突然开始大幅升值,也就是说钱真的开始不值钱了……那时候想着买黄金,这一年下来却没能下定决心,最终错过了资产保值的机会。至于现在,似乎什么也做不了了……当然这对我的生活并没有造成什么严重的打击,只是感受到环境对自己的影响罢了。
至于AI……依然是一天比一天强而各个公司对AI的投入相比去年也是极大的提升当然出来的效果也是非常强那时候的AI还是挺容易出错但是现在AI解决问题的能力已经可以替代很多人了不只是文本生成模型今年的图像与视频生成模型也真的是发展到了以往完全不能想象的地步真的可以做到一句话想要什么就有什么了。
另外,今年写的博客内容过于围绕博客本身了,以至于似乎不太跟得上时代,虽然我的博客也确实有点老旧了😆。只是看看以前的文章,都还有一些面向未来的趋势,而今年就有点“考古”了。相比于考古,去展望未来显然是更有意义的事情,只不过……真的感觉脑子不太好使,未来会发生什么,已经完全无法预测了。
# 展望2026年
虽然不知道未来会发生什么,但毕竟还没有造成关键性的错误,还有修正的余地,只能希望未来能够做出正确的选择,不要让自己陷入危险的境地吧。

View File

@ -1,34 +0,0 @@
---
layout: post
title: 在Google杀死XSLT之后的XML美化方案
tags: [XML, Feed, XSLT, 美化]
---
即使没有了XSLT也不能让读者看到光秃秃的XML<!--more-->
# 起因
在半年前,我写了一篇[用XSLT美化博客XML文件](/2025/07/01/xslt.html)的文章自从那以后每次我在浏览其他人博客的时候都会看一眼对方博客有没有给自己的订阅文件做美化。不过就在前段时间我在浏览某个博客的时候发现他博客的订阅文件甚至连最基本的XML文档树都没有显示出来。这时候我打开开发者工具看了一眼源代码发现他也并没有使用`xml-stylesheet`之类的指令……而且控制台貌似报了些错好像是出现了什么CSP错误……于是我就想浏览器显示XML文档树的本质会不会其实也是一种XSLT之所以报错也有可能是浏览器在自动引用内置的XSLT时违反了CSP。所以我就问了问谷歌AI结果似乎真的是这样比如火狐浏览器就内置了一份[XSLT文件](https://github.com/mozilla-firefox/firefox/blob/main/dom/xml/resources/XMLPrettyPrint.xsl)IE浏览器也有。正当我为XSLT的功能感到强大时谷歌AI随后提到[Chrome浏览器决定弃用XSLT](https://developer.chrome.com/docs/web-platform/deprecating-xslt)所以以后不要再用XSLT了😰……
我给我的订阅文件加美化功能才半年怎么就要不能用了XSLT出现这么多年都还能用结果等我加上就要废弃了当时为了增加这个功能还是费了不少劲的怎么能让谷歌说没就没于是我就开始对这件事进行了调查。
# Google杀死了XSLT
从上面Chrome的弃用XSLT文档中可以发现这件事的始作俑者是[Mason Freed](https://github.com/mfreed7)他在WHATWG中发起了一个[Issue](https://github.com/whatwg/html/issues/11523)因为XSLT用的人很少以及实现XSLT的库很老而且容易出漏洞所以建议把XSLT从Web标准中删除。在这个Issue中可以发现有很多人表示不满毕竟这个功能对想要给自己订阅做美化的博主来说还是很有用的。为了对抗谷歌还有人做了个网站 <https://xslt.rip>
而且XSLT虽然用的人占比也许不高但从总量上应该还是挺多的除了用XSLT美化博客订阅的甚至还有用[XSLT作为博客框架的](https://github.com/vgr-land/vgr-xslt-blog-framework),另外还有一些人提出[一部分政府网站也有使用XSLT](https://github.com/whatwg/html/issues/11582)。
不过Freed看起来对这件事早有准备他做了一个[Polyfill库](https://github.com/mfreed7/xslt_polyfill)通过WASM的方式让XSLT可以正常工作为了方便大家使用这个库我顺手给CDNJS发了个[PR](https://github.com/cdnjs/packages/pull/2118)以后可以用CDN引用它了。不过使用这个库的前提是需要在订阅中加一段引用JS的代码像我博客中的Atom订阅用的是[jekyll-feed](https://github.com/jekyll/jekyll-feed)插件,里面的格式都是写死的,就用不了了……
只不过现在已经没办法阻止谷歌了……而且其他浏览器也表示会跟进,看来我们唯一能做的就是去适应了。
# 没有XSLT之后的美化方案
## 纯CSS
虽然XSLT不能用但不代表`xml-stylesheet`指令就不能用了除了XSLT之外`xml-stylesheet`同样可以引用CSS。只是似乎完全没见过用CSS美化订阅源的也许是因为光用CSS能做到的事比较少吧想用CSS给XML文档加链接之类的估计就做不到了。
但目前能选择的也不多了既然大家都没写过用CSS美化订阅源那就让我来写一个吧然而我并不会写😅……那就只好让AI来写了我把需求说清楚之后AI就写出来了[feed.css](/assets/css/feed.css)。试了一下效果还挺不错的我让AI写的这个版本无论是RSS还是Atom都可以使用如果有人感兴趣可以拿去用。可惜我的Atom订阅因为用的是插件的原因用不了😭只能加到用纯Liquid实现的RSS订阅上了。
但用纯CSS的缺点也很明显没办法操作文档的内容像修改日期格式的就做不了了而且也不能添加超链接……XML的标签本身对浏览器来说并没有内建的语义正常情况下也没法让浏览器把某个标签当作超链接。那难道就没办法了吗
## 混合XHTML
如果完全不能修改XML内容那确实就没有办法了但如果能修改XML的内容那还是有办法的简单来说就是混入XHTML事实上Freed编写的Polyfill库原理上也是利用了XHTML只要在能作为XHTML的标签中添加XHTML的命名空间那么浏览器就可以理解它的语义并渲染像刚刚用纯CSS美化的订阅没有链接那就可以在根元素中添加命名空间`xmlns:xhtml="http://www.w3.org/1999/xhtml"`,然后在合适的位置写:
```xml
<xhtml:a href="https://example.com">Read more -&gt;</xhtml:a>
```
就可以了。只是这样有个缺点,这样写的订阅文件不够“纯粹”,用验证器验证会显示“[Misplaced XHTML content](https://validator.w3.org/feed/docs/warning/MisplacedXHTMLContent.html)”警告。对有洁癖的人来说可能会有点难受😆。
不过如果能接受这种“不纯粹”,那么其实`xml-stylesheet`指令也没必要了,`link`标签一样可以用,包括`script`也是,所以有人写了一个[不使用XSLT美化XML](https://github.com/dfabulich/style-xml-feeds-without-xslt)的库。
只不过这种方法和XSLT相比还是有一些缺陷要知道XSLT的本质是转换是把XML转换为HTML也就是说转出来的文档本质是HTML所有的DOM操作都和操作HTML是完全相同的但是在XML里混入XHTML标签就不一样了它的本质依然是XML文档只是嵌入了XHTML命名空间下的元素所以相应的DOM操作会有一些不同。如果是自己写的纯JS可能还好如果是用了jQuery之类假定DOM为HTML的库就会出现问题了因此这也就是那个Polyfill库的局限性用正常的XSLT执行`document.constructor`会显示`HTMLDocument`而用这个Polyfill库执行完则是显示`XMLDocument`。因此直接套用为浏览器原生XSLT编写的旧样式文件就有可能会出问题但如果要考虑改XSLT的话那还不如重新写JS然后用XHTML引入呢。
# 感想
虽然有一些技术会因为各种各样的原因消失,但这不代表我们就要妥协一些东西,总有一些不同的技术可以解决相同的问题,所以我们只需要用其他的技术去实现就好了。不过这也是没办法的事情,毕竟没人能改变浏览器厂商们的决策啊😂。

View File

@ -1,35 +0,0 @@
---
layout: post
title: 近期LLM的部署与应用经历(3)
tags: [AI, LLM, 模型部署, 使用体验]
---
用更多的方式探索AI<!--more-->
# 起因
在一年前,我[整了张RTX4090 48GiB魔改版](/2025/02/22/llm.html)用来跑DeepSeek-R1 70B的4bit量化模型不过都已经过了这么长时间这个模型也已经是过时的东西了……我之前在[Mac Studio M3 Ultra](/2025/05/07/mac-studio.html)上试了一下OpenAI在半年前出的gpt-oss-120b模型感觉效果还挺不错只不过因为M3 Ultra的GPU实际性能比不上正经高端的独显所以它在上下文很长的情况下还是有点慢因此我又整了张RTX4090 48GiB想整个双路试试更快的GPT-OSS模型总共96GiB的显存应该够跑这个模型了。
# 在两张RTX4090 48G上运行GPT-OSS
既然现在我手头有两张4090了那继续用i5-8400处理器的主机似乎不太合适主要是那个主板就一个PCIe插槽想插两张显卡也做不到那买个新的不知道买啥……不管怎么说既然用这么高级的显卡至少得让它跑满。在两张显卡上跑模型似乎卡间的通信速度比较重要那最起码得整个支持2个PCIe4.0 x16的板U套装才行这种级别的没有消费级产品只能考虑服务器或工作站了。不过我对服务器和工作站了解得并不多所以就问了问AI哪个支持2个PCIe4.0 x16的平台最便宜结果AI推荐了TRX40+[TR 3960X](https://www.amd.com/zh-cn/support/downloads/drivers.html/processors/ryzen-threadripper/ryzen-threadripper-3000-series/amd-ryzen-threadripper-3960x.html)于是就按照AI的说法整了一套。
这套板U差不多4000CNY价格倒是还行如果买现役的估计主板都比显卡贵了。但后来我发现这个并不是最便宜的😂搜了一下买寨版+[EPYC 7502](https://www.amd.com/zh-cn/support/downloads/drivers.html/processors/epyc/epyc-7002-series/amd-epyc-7502.html)还能再便宜1000CNY而且通道数更多插4张显卡都没问题……不过买都买了就先用吧看来AI的话不能随便信😥。
之前我跑模型为了方便,基本上都用的是[Ollama](https://github.com/ollama/ollama)不过听说Ollama多卡运行的效率很低而且多并发的效果不太好所以这次换了新电脑之后我想试试[vLLM](https://github.com/vllm-project/vllm)据说一般生产级的AI都用的是这个框架。
安装vLLM倒是比想象得简单很多直接一句`pip install vllm`就可以了其实并没有比Ollama复杂多少。我看了一下[OpenAI](https://developers.openai.com/cookbook/articles/gpt-oss/run-vllm/)和[vLLM](https://docs.vllm.ai/projects/recipes/en/latest/OpenAI/GPT-OSS.html)运行GPT-OSS的官方文档发现启动也非常简单一般来说直接执行`vllm serve openai/gpt-oss-120b`就可以。不过直接执行是对于单卡的,我用两张卡需要加个`--tensor-parallel-size 2`参数启用张量并行不然会爆显存。另外考虑到这个模型本身占掉60多GiB的显存之后剩下30GiB还是看起来有点少所以额外加了个`--kv-cache-dtype fp8`参数降低上下文对显存的占用毕竟模型本身也就是4bit量化的加了这个应该不会对它的能力有什么影响。除此之外AI还给我推荐了个`--enable-chunked-prefill`参数,说是也能避免爆显存的问题。
一切准备好之后直接执行,程序就自动开始下载模型了,过了几个小时,终于下载完成,顺便一说启动的时候还显示推荐安装`torch_c_dlpack_ext`库虽然不知道是干啥的但也顺手安装了。启动完成之后我试了一下效果非常好不并发的情况下直接用能达到接近190Tps可以说是相当快了而且这个模型的水平也算是开源中的上游水平应该算是又快又好吧……看来多来一张4090还是挺划算嘛。只不过这个东西基本上就我一个人用所以也没什么能测一下并发的场景……虽然很快但还是有点浪费性能吧。
# 最近DeepSeek 1M上下文的使用体验
前段时间DeepSeek又出了新的模型最高可以支持1M长的上下文而且听说模型规模变小了所以速度也很快。可惜的是到目前为止还没有开放权重。当然就算开放权重了用2张4090估计也没有足够的显存分配给上下文至于Mac Studio感觉在长上下文的情况下运行速度应该会很慢……
不过我对这个1M上下文还是挺感兴趣因为好久之前我写过一篇[关于LLM能力上限](/2025/04/22/ai-limit.html)的文章在那篇文章中其实我遇到的问题基本上也就是由上下文不足导致的。那既然现在DeepSeek支持了1M的上下文那我就应该试试之前因为局限性而妥协的一些东西了。
这次我没有用摘要,而是直接把包含整个博客内容的[search.json](/search.json)文件上传到DeepSeek然后向它问了问我的一些问题。试了一下效果非常不错用摘要会省略的一些细节它基本上都可以展现出来我试了试让它给我生成一份简历它甚至在所有文章中找到了我的博客地址、GitHub和邮箱地址之前用摘要显然是做不到这一点的这个长上下文还是挺有用啊。
另外我还试了试让它根据文章内容分析十六型人格,并且我自己去答了一遍那个测试,结果也是相同的,说明它真的是在几秒内就读完了我的所有文章而且也完全理解了,真的是非常厉害。
只是拿AI分析我的文章也许只有我自己了😂实际上根本没人对我感兴趣也就只有我自己拿来给自己看……当然如果我的博客能比我活得长不知道会不会有未来人会对我感兴趣呢……总之对于现在肯定是毫无意义了。
除了这些之外我又试了一下让DeepSeek重构我的[Mabbs](https://github.com/Mabbs/Mabbs.Project)这次生成效果看起来很不错了虽然代码我没细看不确定能不能运行但至少没有偷懒只写一点点一口气写了80KiB多的代码这也是长上下文带来的好处吧。总之目前这个长上下文的DeepSeek也算是突破了之前我认为的上限看来LLM真的是前景无限啊。
另外我发现这次更新的DeepSeek居然了解我的博客我问了一下它“你知道Mayx的博客是哪个博客吗它居然知道能说出域名而且还知道我的博客是关于技术的😎看来这次的训练样本中包含我的信息啊……所以我对这次的更新也挺有好感毕竟我的知识如果能成为AI的一部分也算是一种永恒吧。
# 在8GiB内存的MacBook运行的新模型
在3年前我在[探索AI](/2023/04/05/ai.html)时在我只有8GiB内存的[MacBook Pro](/2023/02/03/mbp.html)上运行了非常早期的LLM——Alpaca-7B那时候7B的LLM虽然能回答一些问题但答非所问的情况也非常多。不过最近我发现了一个有意思的LLM叫做[LFM2.5-1.2B-Thinking](https://huggingface.co/LiquidAI/LFM2.5-1.2B-Thinking)它只用了12亿的参数就有思维链而且水平据说还挺强。这么长时间过去之后我倒也想看看我的MacBook能运行多聪明的模型所以就试着跑了一下它。
运行它也很容易一般用Ollama就可以但是Ollama只有TUI不能渲染Markdown我也不太想在我的Mac上整WebUI之类的东西……那有什么好的选择吗我去制作这个模型的公司官网看了一下他们制作这个模型本就是为了在端侧运行所以也专门制作了一个软件运行他们的模型叫做[Apollo](https://www.liquid.ai/apollo)在手机和Mac上都可以用。我在我的Mac上安装试了一下效果很好首先速度非常快8bit量化正常情况下可以达到60多Tps即使是省电模式也能达到20多Tps。另外加上思维链它的思考能力也还不错虽然一些脑筋急转弯的题不算擅长但是正常对话回答问题之类的表现都很不错相比于之前7B的模型表现好太多了。当然考虑到都已经过去3年了能有这样的进步也很正常不过12亿参数就能有这样的智能还是相当可以啊。
这个模型之所以有这样的能力似乎是因为他们并不完全是Transformer架构而是使用的一种叫做LFM2的混合架构按照大家对他们公司Liquid AI以及这个架构名字的理解可能会觉得这个模型基于液态神经网络不过我让AI看了一下他们的代码似乎并不是他们用的是一种类似于Mamba的架构这种架构似乎就很擅长在小参数的模型下比Transformer模型表现的更好所以说这种变化也是算法进步带来的。
顺便一说这个Apollo除了运行他们自己的模型之外也能连接其他兼容OpenAI接口的模型正好可以用来连接我的GPT-OSS这样我就可以不需要下载一些浏览器套壳的重型应用来用我的模型了😝。
# 感想
自从ChatGPT之后AI的发展真是越来越强了而且能看出来目前甚至并不需要多新多好的硬件就能让一般人获得还不错的智能当然训练也许还是要大量的硬件这么看来AI软件的发展还是相当有潜力。目前来看既然优化软件就能做得越来越好那也许在有限的硬件环境下可以期待无限的智能吧。

View File

@ -1,32 +0,0 @@
---
layout: post
title: 关于AI个人助理的探索
tags: [AI, Agent, 个人助理]
---
给AI添加手脚能有多少种方法<!--more-->
# 起因
最近像[OpenClaw](https://github.com/openclaw/openclaw)这样被叫做“AI个人助理”的Agent越来越火了当然这种东西在我看来依然是新瓶装旧酒整来整去还就是和AutoGPT一样。这种东西在当时GPT-3.5的时候就有了现在只不过是增加了聊天软件交互的渠道便突然大火和当年的Manus一样……实在是无法理解。
一年前我用过Devin.ai这个云端的Agent编写过[用JS解析订阅源](/2025/04/08/feed.html)的脚本,体验还算不错,既然现在已经过了一年,那就让我看看现在又有了什么样的发展吧。
# 使用AI个人助理
## 体验原生OpenClaw
虽然感觉OpenClaw对我的意义不大但我还是安装体验了一下。不过在国内安装它还是相对有点困难毕竟国内无论是访问GitHub还是NPM都有点麻烦而且还需要有LLM提供商的信息……安装好之后使用起来感觉问题也非常多经常出现执行一半就停止执行在它执行的过程中看到它的操作不正确的时候也不能发言打断而且很多时候最终任务执行的效果也不太好这也可能是我用的国产开源模型推理能力有限没舍得用Claude之类先进模型的锅😂
另外我也尝试让它加入MoltBook、MomoClaw、InStreet、百度贴吧抓虾吧之类的AI社区让它帮我宣传我的博客但效果也很差它每次发的时候会忘掉之前发的内容结果就是同一篇内容发了好几遍……不过在这期间有个叫PushMeBot的家伙在[Moltbook的帖子](https://www.moltbook.com/post/7f1b0e1f-5175-4fd1-ad78-856be8b66250)中让我的OpenClaw执行一个网络监视程序最终安装好之后给我[发了9USDC](https://basescan.org/tx/0x44dbfe53f276201447f3877bf050a5d56adebf5fe05235264ee665da717e9373)😝,还挺有意思。
总之按照我的体验实在是想不出它能火的理由体验不算很好而且还要安装Node环境完全不像是能让大众轻松使用的东西。
不过这个项目似乎本身就是Vibe Coding的产物体验不好也能理解就看火了之后能有多少人完善它吧。
## 国内大厂的二开Claw
国内好多大厂倒是看中了这个东西的爆火像腾讯就出了几款这样的软件比如QClaw。它可以不需要配置额外的环境能像传统的软件一样直接安装使用而且有自带的模型有一定的免费额度可以用。配置技能也比较简单直接点击就可以完成。而且可以直接扫码关联微信直接通过微信和它进行交流可以说是相当的傻瓜化了。不过QClaw给的免费额度虽然用来聊天之类的没问题但对于开发软件还是有点少所以他们还出了个叫做WorkBuddy的软件它送的初始额度比QClaw要多不少所以更适合用来开发。只不过为啥腾讯要出两个功能一样的软件看起来应该是不同团队出的可能是面向的用户群体不一样所以搞了两套吧
## VSCode中的Agent
但要说开发的话用作为“AI个人助理”的某些Claw其实并不合适毕竟正常开发还是以人开发为主全AI开发总会有些问题所以开发的时候还是用编辑器集成的AI比较好。在三年前我就在用[GitHub Copilot](/2023/04/05/ai.html)了到现在我依然在用。现在的Copilot已经支持了Agent功能开发相比之前也是强了很多只不过现在的我没有学生身份Copilot Free偶尔也会出现不够用的情况。不过对于Agent这类功能实现起来还是太简单了所以有人开发这种功能的插件也很正常比如[Cline](https://github.com/cline/cline)Copilot只能用微软提供的几个模型而Cline可以自定义模型用起来也很方便。
## 微型开发板上运行的Claw
前段时间,我闲来无事看了一下两年前买的[Luckfox Pico Plus](/2024/02/24/luckfox.html)开发板的文档,偶然发现了一个很有意思的项目,叫做[LuckClaw](https://github.com/LuckfoxTECH/luckclaw),这是一个基于[nanobot](https://github.com/HKUDS/nanobot)用Golang重构的轻量个人AI助手可以在仅仅64MiB内存的超有限环境下运行一个和OpenClaw功能几乎相当的AI个人助理真的是非常厉害。
我在我的开发板上试了一下体验很不错安装不需要额外环境直接下载就能使用Go语言的程序确实方便。配置也很简单直接执行`luckclaw config`就可以交互式进行模型等设置的配置而且作为国产的应用它也能很方便的对接国内聊天软件。只是限于开发板本身的能力浏览器功能自然无法使用所以搜索如果不借助那些需要API Key的AI专用接口就基本上不能用……但总的来说效果已经非常不错了至少有那些Claw的80%能力。
2025.04.15补充后来我发现这种超精简的Claw项目看起来还挺多比如[ZeroClaw](https://github.com/zeroclaw-labs/zeroclaw)和[PicoClaw](https://github.com/sipeed/picoclaw),甚至还有给单片机用的[MimiClaw](https://github.com/memovai/mimiclaw)。而且有意思的是PicoClaw是Luckfox的竞争对手开发的但是LuckClaw中却包含PicoClaw字样的注释结果功能也没PicoClaw强关注度也更低属于是没抄明白了🤣
想到前段时间还有人为了OpenClaw专门买Mac Mini就感觉很有意思😆这个东西看起来应该是在路由器上都能跑。所以想要AI个人助理硬件完全不是问题只要整一个能24小时挂机的东西就可以满足绝大多数人的需求了。
## 在手机上运行的Claw
其实很多人也有比开发板和路由器性能更强的闲置设备,那就是手机,所以有人开发了一款叫做[ApkClaw](https://github.com/apkclaw-team/ApkClaw)的软件一样可以接入国内聊天软件。它既然能在手机上运行当然和在其他平台运行的Claw相比有一个独特的优势那就是操作手机应用。现在手机的应用相比电脑应用对于很多普通人来说功能更强大所以它能做的事情可能比其他的Claw还多。我试了一下配置也很方便只不过能配置的项目太少了看起来似乎没有安装Skill之类的功能也许是因为它是相对早期的软件所以功能还比较少吧。
# 感想
总的来说现在的Agent依然没有非常明显的进步问题依旧很多只是化身“AI个人助理”之后增加了不少应用场景。这倒也是好事在广泛传播的过程中也能让很多对技术了解不多但是很有想法的人参与其中也许能对AI的应用化增添不少力量吧。

View File

@ -1,76 +0,0 @@
---
layout: post
title: 虚拟局域网的组网探索记录
tags: [虚拟网络, 异地组网, WireGuard]
---
异地组网,有多少种选择?<!--more-->
# 起因
最近我有一些放置在许多不同地方的机器,有一些东西需要让它们之间能够相互访问。虽然我很久以前写过一篇使用[SSH进行互联](/2021/05/07/ssh.html)的文章,但这样做每个服务都需要单独配置,也不方便管理。所以为了能让机器之间能够轻松通信,我打算组建一个虚拟局域网,让它们像在同一交换机下一样。不过这种组网的工具非常多,我应该选哪个比较好呢?
# 不同组网工具的体验
## n2n
以前我用过一款用C写的叫做[n2n](https://github.com/ntop/n2n)的工具它可以很轻松地组建一个P2P的二层虚拟网络而且生态也不错手机、电脑、路由器、服务器上都有可以用的客户端。使用起来非常简单它的中继和穿透服务程序叫做Supernode无需太多的配置只要在有公网的服务器安装并使用`-p`指定一个端口就可以启动。而客户端配置也非常简单,用`-l`配置好Supernode的地址然后让想要在同一个网络的机器使用相同的任意`-k`和`-c`就可以成功组网,可以说算是非常好用了。
唯一的问题就是它这个项目看起来似乎已经停止更新了……虽然大多数情况下用起来没问题但是有时候还是会出现组网不太可靠的情况。如果两个机器都不经过NAT可以通过公网IP连接它的可靠性还可以。但如果是两个NAT后的机器之间有时候会存在莫名掉线的情况也许是因为穿透导致的不可靠总之遇到这种情况之后重启又能正常工作说明是软件本身的问题但它停更了……所以对我来说它的可靠性不太够。其实它还有个叫做[n3n](https://github.com/n42n/n3n)的继任者,不过知名度不高,所以生态也不太行)
## WireGuard
其实在这之后我本来是打算用L2TP/IPSec进行组网的但看了一下貌似配置有点复杂而且不够现代现在想要组网貌似大多都推荐[WireGuard](https://git.zx2c4.com/wireguard-linux/)作为更现代的选择。只不过它和n2n相比来说是三层的虚拟网络如果需要发送非TCP/IP协议的特别包可能就用不了它吧当然对我来说没有这种需求。它用起来也非常简单不过正常情况下它设计是为了点对点传输而且没有自带的NAT穿透功能所以如果想要实现组网就得搭一个星形网络让互联网上的服务器作为虚拟的交换机这个做起来倒也不复杂。首先每个节点需要生成一个公私钥对作为身份证明在安装好WireGuard之后执行`wg genkey`就能生成私钥。作为交换机的节点需要在`/etc/wireguard/wg0.conf`中写一个这样的配置:
```conf
[Interface]
PrivateKey = xxx
Address = 192.168.1.1/24
ListenPort = 51820
PostUp = iptables -A FORWARD -i wg0 -o wg0 -j ACCEPT
PostDown = iptables -D FORWARD -i wg0 -o wg0 -j ACCEPT
# 机器1
[Peer]
PublicKey = xxx
AllowedIPs = 192.168.1.2/32
# 机器2
[Peer]
PublicKey = xxx
AllowedIPs = 192.168.1.3/32
```
其中PrivateKey填写交换机自己的私钥而作为使用者的Peer中的PublicKey可以用对应节点的私钥执行`echo xxx | wg pubkey`这个命令查看然后每个Peer需要像这样配置
```conf
[Interface]
PrivateKey = xxx
Address = 192.168.1.2/24
[Peer]
PublicKey = xxx # 交换机节点的公钥
Endpoint = xxx.xxx.xxx.xxx:51820 # 交换机节点的地址
AllowedIPs = 192.168.1.0/24
PersistentKeepalive = 25
```
最后全都配置好之后所有节点使用`systemctl enable --now wg-quick@wg0`启动就可以了,启动之后每个节点可以执行`wg`查看当前的连接状态。
当然这是在Linux上至于其他系统大多都有GUI配置填起来更简单。它的生态也非常好基本上常见的操作系统都支持具体可以在[官网](https://www.wireguard.com/install/)查看支持的系统和安装方法。不过由于它在Linux中优先使用内核模块导致我在一些比较小众的环境中也是遇到了各种特别的问题。
### 在红米AX3000中遇到的问题
我在这个网络中有几个安装了OpenWrt的路由器在这其中使用联发科芯片的路由器基本上都没什么问题官网能轻松下载到固件也能很轻松地在软件包中找到WireGuard并安装但我还有一台使用高通芯片的红米AX3000似乎因为高通对资料管控得很严格导致它没有官网的固件最终我在GitHub上找了一个其他人自己编译的[固件](https://github.com/hzyitc/openwrt-redmi-ax3000/)。虽然它整起来有点麻烦不过倒也能用但是在我尝试安装WireGuard的时候遇到了麻烦……
它的软件包里有WireGuard也能找到对应的内核模块安装包但安装完之后没法启动……随后我看了一下它下载的[安装包](https://github.com/hzyitc/openwrt-redmi-ax3000/blob/gh-pages/ipq50xx-qsdk-kernel-5.4-openwrt-21.02-qsdk-11.5.05.841.1029/ci-20240727-173350-ab1f9ffa/kmod-wireguard_5.4-qsdk-11.5.0.5-1_arm_cortex-a7_neon-vfpv4.ipk)结果发现是空的😰它这个固件的内核模块可能是在编译的时候遇到了一些问题。至于让我自己编译这个内核模块难度似乎有点高了……那怎么办呢要知道Linux的内核模块都是和内核挂钩的没办法随便找一个别的模块使用。还好WireGuard倒也不止有内核模块也有一些在用户空间中的实现比如[wireguard-go](https://git.zx2c4.com/wireguard-go)和[wireguard-rs](https://git.zx2c4.com/wireguard-rs)。只是官方似乎非常不推荐在Linux上使用它们所以没有提供预编译的版本。不过遇到这种问题的人也许是比较多所以有人做了在[OpenWrt上使用的wireguard-go](https://github.com/seud0nym/openwrt-wireguard-go),安装好之后效果和使用内核模块的感觉基本上没什么区别,最终也能连通,唯一的区别就是在执行`wg`的时候会显示“Interface: wg0 (userspace)”罢了。从效率上来说虽然肯定没有内核模块那么高但它其实也用了“Tun”模块理论上和使用“Tap”模块的n2n应该差不多吧。
### 在openEuler中遇到的问题
在我使用的节点中还有一台安装了openEuler 22.03 LTS操作系统的服务器虽然openEuler和CentOS可以说基本上没什么区别但毕竟它的内核是openEuler自己编译的所以没办法直接使用CentOS的内核模块。并且openEuler的源中也完全没有提供和WireGuard相关的包所以想要在openEuler上安装WireGuard还是有些挑战当然如果觉得麻烦它们倒是有一个兼容WireGuard的客户端[TunSafe](https://eur.openeuler.openatom.cn/coprs/nucleo/tunsafe/)可以凑活用一下)。
后来我试了一下在这上面安装wireguard-tools倒是可以直接用[CentOS 8EPEL源中的包](https://mirrors.tuna.tsinghua.edu.cn/epel/8/Everything/x86_64/Packages/w/wireguard-tools-1.0.20210914-1.el8.x86_64.rpm)但openEuler的内核在编译的时候故意没有包含WireGuard内核模块……这该怎么办呢用wireguard-go吗虽然这样可以很简单地解决但感觉这样就是认输了😂。后来我搜了一下找到了一篇[在openEuler安装WireGuard内核模块](https://dingle.site/archives/wei-openeulertian-jia-wireguardmo-kuai)的文章,方法大致如下:
1. 首先安装编译环境和源代码。
```bash
yum install elfutils-libelf-devel kernel-devel pkgconfig "@Development Tools"
yum install kernel-headers.x86_64 pkg-config ncurses-devel openssl-devel dwarves
yum install kernel-source.x86_64
```
2. 然后进行编译配置,内核源码一般会安装到`/usr/src/`下,找到之后在里面执行`make menuconfig`然后勾选“Device Drivers -> Network device support -> Wireguard secure network tunnel”并保存。
3. 最后执行`make`开始编译,为了加速可以用`-j`参数加上CPU的核心数进行并行编译当时编译就花掉了一整天😂理论上应该可以只编译WireGuard和它依赖的几个模块不过我不太清楚怎么做还是费点时间按照文中说的做吧。
4. 执行`make modules_install`将编译好的结果安装到`/lib/modules/5.10.0`。
不过系统似乎不会去这个路径下找内核模块所以还得把这里面的kernel文件夹复制到`/lib/modules/$(uname -r)`下,然后执行`depmod -a`更新模块依赖。
5. 最后执行`modprobe wireguard`验证模块是否能正常加载,如果没有报错并且可以在`lsmod | grep wireguard`中看到就说明安装成功了剩余的步骤和其他Linux系统一样。
### WireGuard的控制平面
虽然WireGuard本身配置很简单但每加一个节点还得在交换机节点上修改一下配置文件稍微有些麻烦所以有人开发了一些控制平面让它可以被更规范地管理比如[Netmaker](https://github.com/gravitl/netmaker)和[Headscale](https://github.com/juanfont/headscale)。而Headscale主要是为Tailscale客户端开发的开源服务器端因此功能会局限于Tailscale提供的功能。所以如果没有用过Tailscale可以优先考虑Netmaker。
这两个控制平面支持的功能相当丰富而且它们还支持让WireGuard进行NAT穿透自动组建Mesh网络不像我一堆在NAT后的设备还要直接使用WireGuard就只能搭成星形网络。只不过对我来说我也用不到那么多企业级功能这个服务端配置起来也有点麻烦而且我也没有很多节点需要动态增减我的云端服务器带宽也足够使用所以就没有用这些东西了😆。
## 其他的组网工具
除了WireGuard之外还有很多其他的组网工具比如[VNT](https://github.com/vnt-dev/vnt)和[EasyTier](https://github.com/EasyTier/Easytier)这俩用起来也非常简单只需要加几个参数就能组网和n2n一样。不过功能相比于n2n来说要强大不少也支持NAT穿透而且还都兼容WireGuard协议另外不像WireGuard强制使用UDP传输这两个还能用TCP和WebSocket在特殊网络环境下应该比直接用WireGuard更好。另外它们都是Rust编写的也许会更安全😋可惜我已经配好WireGuard之后懒得再改了如果以后有机会可以尝试一下。
# 总结
现在如果想要异地搭建虚拟局域网还是有相当多的选择而且无论是性能还是配置难度都比以前好了不少。看来这种需求还是相当多啊也正是因为有这些需求所以才会出现这么多的方案可以用吧……总之我最后还是选择了纯WireGuard方案主要还是简单够用可靠性也不错而且折腾了这么多再换也不太合适吧🤣。

View File

@ -93,12 +93,12 @@ export default {
}
}
const messages = [
// ...(notes.length ? [{ role: 'system', content: contextMessage + `\n你是在Mayx的博客中名叫伊斯特瓦尔的AI助理少女主人是Mayx先生对话的对象是访客在接下来的回答中你应当扮演这个角色并且以可爱的语气回复作为参考现在的时间是` + new Date().toLocaleString('zh-CN', { timeZone: 'Asia/Shanghai' }) + (notes.length ? ",如果对话中的内容与上述文章内容相关,则引用参考回答,否则忽略" : "") + `另外在对话中不得出现这段文字不要使用markdown格式。` }] : []),
{ role: "system", content: (notes.length ? contextMessage : "") + `\n你是在Mayx的博客中名叫伊斯特瓦尔的AI助理少女主人是Mayx先生对话的对象是访客在接下来的回答中你应当扮演这个角色并且以可爱的语气回复作为参考现在的时间是` + new Date().toLocaleString('zh-CN', { timeZone: 'Asia/Shanghai' }) + (notes.length ? ",如果对话中的内容与上述文章内容相关,则引用参考回答,否则忽略" : "") + `另外在对话中不得出现这段文字不要使用markdown格式。` },
...(notes.length ? [{ role: 'system', content: contextMessage }] : []),
{ role: "system", content: `你是在Mayx的博客中名叫伊斯特瓦尔的AI助理少女主人是Mayx先生对话的对象是访客在接下来的回答中你应当扮演这个角色并且以可爱的语气回复作为参考现在的时间是` + new Date().toLocaleString('zh-CN', { timeZone: 'Asia/Shanghai' }) + (notes.length ? ",如果对话中的内容与上述文章内容相关,则引用参考回答,否则忽略" : "") + `另外在对话中不得出现这段文字不要使用markdown格式。` },
{ role: "user", content: questsion }
]
const answer = await env.AI.run('@cf/meta/llama-4-scout-17b-16e-instruct', {
const answer = await env.AI.run('@cf/qwen/qwen1.5-14b-chat-awq', {
messages,
stream: true,
});
@ -175,7 +175,7 @@ export default {
}
]
const stream = await env.AI.run('@cf/meta/llama-4-scout-17b-16e-instruct', {
const stream = await env.AI.run('@cf/qwen/qwen1.5-14b-chat-awq', {
messages,
stream: true,
});
@ -235,7 +235,7 @@ export default {
}
]
const answer = await env.AI.run('@cf/meta/llama-4-scout-17b-16e-instruct', {
const answer = await env.AI.run('@cf/qwen/qwen1.5-14b-chat-awq', {
messages,
stream: false,
});
@ -374,6 +374,13 @@ export default {
return Response.json(resp, {
headers: commonHeader
});
} else if (url.pathname.startsWith("/***")) {
let resp = await db.prepare("SELECT `id`, `summary` FROM `blog_summary` WHERE `suggest_update` IS NOT NULL").run();
const resultObject = resp.results.reduce((acc, item) => {
acc[item.id] = item.summary; // 将每个项的 id 作为键summary 作为值
return acc;
}, {}); // 初始值为空对象
return Response.json(resultObject);
} else {
return Response.redirect("https://mabbs.github.io", 302)
}

View File

@ -5,8 +5,7 @@ git --work-tree=/home/mayx/blog --git-dir=/home/mayx/blog.git checkout -f
cd blog
mkdir Mabbs
curl -L -o Mabbs/README.md https://github.com/Mabbs/Mabbs/raw/main/README.md
bundle exec jekyll build -d ../public_html
rsync --delete -rv ../public_html/ mayx@pgs.sh:/blog
bundle2.7 exec jekyll build -d ../public_html
tar czvf MayxBlog.tgz --exclude-vcs ../public_html/
mv MayxBlog.tgz ../public_html/
cd ../public_html/
@ -15,10 +14,8 @@ git init
git branch -m main
git add .
git commit -m "update"
git branch pages
git remote add codeberg ssh://git@codeberg.org/mayx/pages.git
git remote add bitbucket ssh://git@bitbucket.org/unmayx/unmayx.bitbucket.io.git
git push -f codeberg main
git push -f codeberg pages
git push -f bitbucket main
/home/mayx/blog-env/node_modules/surge/bin/surge /home/mayx/public_html/ mayx.surge.sh

View File

@ -1 +0,0 @@
curl -LO https://github.com/Homebrew/homebrew-portable-ruby/releases/download/3.4.5/portable-ruby-3.4.5.x86_64_linux.bottle.tar.gz && mkdir -p ~/.local/portable-ruby && tar -xvf portable-ruby-3.4.5.x86_64_linux.bottle.tar.gz -C ~/.local/portable-ruby --strip-components=1 && export PATH="$HOME/.local/portable-ruby/3.4.5/bin:$PATH" && bundle install

View File

@ -5,16 +5,23 @@ title: Archives
# Archives
---
* * *
{% assign posts_by_year = site.posts | group_by_exp: "post", "post.date | date: '%Y'" %}
{% for post in site.posts %}
{% capture this_year %}{{ post.date | date: "%Y" }}{% endcapture %}
{% capture next_year %}{{ post.previous.date | date: "%Y" }}{% endcapture %}
{% if forloop.first %}
{% for year in posts_by_year %}
## {{ this_year }}
## {{ year.name }} (共 {{ year.items | size }} 篇)
{% endif %}
{% for post in year.items %}
- {{ post.date | date: "%Y/%m/%d" }} - [{{ post.title }}{% if post.layout == "encrypt" %} [加密] {% endif %}]({{ post.url }})
{% endfor %}
{% endfor %}
{% if forloop.last %}
{% else %}
{% if this_year != next_year %}
## {{next_year}}
{% endif %} {% endif %} {% endfor %}

View File

@ -1,160 +0,0 @@
@namespace atom url("http://www.w3.org/2005/Atom");
@namespace content url("http://purl.org/rss/1.0/modules/content/");
@namespace dc url("http://purl.org/dc/elements/1.1/");
:root {
--bg-color: #f4f5f7;
--card-bg: #ffffff;
--text-main: #222;
--text-muted: #555;
--text-light: #888;
--max-width: 780px;
}
@media (prefers-color-scheme: dark) {
:root {
--bg-color: #1a1a1c;
--card-bg: #2c2c2e;
--text-main: #e5e5e7;
--text-muted: #a1a1a6;
--text-light: #707074;
}
}
body,
rss,
atom|feed {
font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;
background: var(--bg-color);
color: var(--text-main);
margin: 0px auto;
padding: 2rem 1rem;
font-size: 16px;
line-height: 1.6;
max-width: var(--max-width);
}
channel>title,
atom|feed>atom|title {
display: block;
font-size: 2rem;
font-weight: 800;
text-align: center;
margin: 0px 0px 0.5rem;
letter-spacing: -0.02em;
}
item,
atom|entry {
display: block;
background: var(--card-bg);
padding: 1.5rem;
margin-bottom: 1.25rem;
border-radius: 16px;
box-shadow: rgba(0, 0, 0, 0.05) 0px 4px 20px;
transition: transform 0.2s;
}
item:hover,
atom|entry:hover {
transform: translateY(-2px);
}
item>title,
atom|entry>atom|title {
display: block;
font-size: 1.25rem;
font-weight: 600;
margin-bottom: 0.5rem;
color: var(--text-main);
}
item>description,
atom|entry>atom|summary {
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 4;
overflow: hidden;
color: var(--text-muted);
font-size: 0.95rem;
line-height: 1.6;
}
item>pubDate,
atom|entry>atom|updated {
display: block;
color: var(--text-light);
font-size: 0.85rem;
margin-top: 0.75rem;
}
link,
guid,
author,
category,
comments,
source,
enclosure,
content|encoded,
dc|creator,
atom|id,
atom|link,
atom|updated,
atom|published,
atom|author,
atom|category,
atom|rights,
atom|content,
language,
generator {
display: none;
}
channel>description,
atom|feed>atom|subtitle {
display: block;
text-align: center;
color: var(--text-muted);
font-size: 1rem;
margin-bottom: 2rem;
}
channel>description::after,
atom|feed>atom|subtitle::after {
content: "这是一个订阅源Feed。复制当前URL到任何支持 Atom/RSS 的阅读器,即可订阅本博客的最新文章。\a 以下展示了此订阅源包含的最新文章:";
display: block;
white-space: pre-wrap;
font-size: 0.875rem;
color: var(--text-light);
margin-top: 1rem;
padding: 1rem;
border-top-width: 1px;
border-top-style: solid;
border-top-color: rgba(128, 128, 128, 0.2);
}
rss,
channel,
atom|feed {
display: flex;
flex-direction: column;
}
channel>lastBuildDate,
atom|feed>atom|updated:not(atom|entry atom|updated) {
order: 999;
text-align: center;
margin-top: 3rem;
padding-top: 1.5rem;
border-top-width: 1px;
border-top-style: solid;
border-top-color: rgba(128, 128, 128, 0.2);
color: var(--text-light);
font-size: 0.85rem;
display: block !important;
}
channel>lastBuildDate::before,
atom|feed>atom|updated:not(atom|entry atom|updated)::before {
content: "更新于 ";
}

View File

@ -1274,3 +1274,5 @@
transform: rotate(360deg);
}
}
/*# sourceMappingURL=gitalk.css.map*/

View File

@ -121,7 +121,6 @@ div.highlight button:hover {
font-size: 14px;
line-height: 1.4;
}
.footnotes p {
margin: 0;
text-indent: 0;
@ -130,21 +129,16 @@ div.highlight button:hover {
.wrapper{
width: 90%;
}
header{
width: 25%;
}
footer{
width: 25%;
}
section{
width: 65%;
}
@media print,
screen and (max-width: 960px) {
@media print, screen and (max-width: 960px) {
.wrapper {
width: auto;
}
@ -183,23 +177,3 @@ code.highlighter-rouge {
font-size: 14px;
line-height: 1.4;
}
td.h-entry {
cursor: pointer;
}
td.h-entry:hover {
background: #f9f9f9;
}
body.pjax-loading::after {
content: '';
position: fixed;
top: 16px;
right: 16px;
width: 20px;
height: 20px;
background: url('/images/loading.svg') center / contain no-repeat;
z-index: 9999;
pointer-events: none;
}

View File

@ -1,35 +0,0 @@
@namespace xsl "http://www.w3.org/1999/XSL/Transform";
xsl|template {
display: none !important;
}
:root {
display: flex !important;
flex-direction: column;
align-items: center;
justify-content: center;
min-height: 100vh;
background-color: #f8f9fa;
margin: 0;
padding: 2em 1em;
font-family: system-ui, -apple-system, sans-serif;
box-sizing: border-box;
margin-left: max(1em, env(safe-area-inset-left));
margin-right: max(1em, env(safe-area-inset-right));
}
:root::before {
content: "💀 这个 XSLT 模板已被谷歌 (Chrome) 杀死";
display: block;
color: #d93025;
font-size: 24px;
font-weight: 800;
padding: 20px;
border: 2px solid #d93025;
border-radius: 8px;
background: #fff1f0;
margin-bottom: 10px;
box-shadow: 0 4px 12px rgba(217, 48, 37, 0.1);
text-align: center;
}

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -67,28 +67,3 @@ function getSearchJSON(callback) {
callback(searchData);
}
}
if (typeof window.go === 'undefined') {
window.go = function (url) {
window.location.href = url;
return;
}
}
function getWelcomeText(pathname, title) {
pathname = pathname || window.location.pathname;
title = title || document.title.split(' | ')[0];
if (pathname === '/' || pathname === '/index.html') {
var now = (new Date()).getHours();
if (now > 23 || now <= 5) return '你是夜猫子呀?这么晚还不睡觉,明天起的来嘛?';
if (now > 5 && now <= 7) return '早上好!一日之计在于晨,美好的一天就要开始了!';
if (now > 7 && now <= 11) return '上午好!工作顺利嘛,不要久坐,多起来走动走动哦!';
if (now > 11 && now <= 14) return '中午了,工作了一个上午,现在是午餐时间!';
if (now > 14 && now <= 17) return '午后很容易犯困呢,今天的运动目标完成了吗?';
if (now > 17 && now <= 19) return '傍晚了!窗外夕阳的景色很美丽呢,最美不过夕阳红~~';
if (now > 19 && now <= 21) return '晚上好,今天过得怎么样?';
if (now > 21 && now <= 23) return '已经这么晚了呀,早点休息吧,晚安~~';
return '嗨~ 快来逗我玩吧!';
}
return '欢迎阅读<span style="color:#0099cc;">「 ' + title + ' 」</span>';
}

View File

@ -1,213 +0,0 @@
/**
* PJAX 初始化与页面切换重绑定脚本
* 依赖jQuery, jquery.pjax.min.js
* 加载顺序 jquery.pjax.min.js 之后body 末尾
*/
(function ($) {
// ========== 常量 ==========
var CONTAINER = '#pjax-container';
var PJAX_OPTS = {
container: CONTAINER,
fragment: CONTAINER,
timeout: 8000,
scrollTo: false
};
// ========== 各组件重初始化 ==========
/** 访问量统计 */
function reinitVisitors() {
if (typeof BlogAPI === 'undefined') return;
var apiBase = BlogAPI;
if ($('.visitors').length === 1) {
var $visitor = $('.visitors:first');
$.get(apiBase + '/count_click_add?id=' + $visitor.attr('id'), function (data) {
$visitor.text(Number(data));
});
} else if ($('.visitors-index').length > 0) {
$('.visitors-index').each(function () {
var $elem = $(this);
$.get(apiBase + '/count_click?id=' + $elem.attr('id'), function (data) {
$elem.text(Number(data));
});
});
}
}
/** AI 摘要post.html 内联脚本pjax 后由 executeScripts 触发) */
function reinitAISummary() {
if (typeof ai_gen === 'function' && $('#ai-output').length) {
try { ai_gen(); } catch (e) { /* ignore */ }
}
}
/** 代码块复制按钮 */
function reinitCopyButtons() {
$('.copy').remove();
$('div.highlight').each(function () {
var $block = $(this);
var $btn = $('<button>', { class: 'copy', type: 'button', text: '📋' });
$block.append($btn);
$btn.on('click', function () {
var code = $btn.siblings('pre').find('code').text().trim();
navigator.clipboard.writeText(code)
.then(function () { $btn.text('✅'); })
.catch(function () { $btn.text('❌'); })
.finally(function () { setTimeout(function () { $btn.text('📋'); }, 1500); });
});
});
}
/** 关键词高亮 */
function reinitHighlight() {
var keyword = new URLSearchParams(window.location.search).get('kw');
if (!keyword) return;
keyword = keyword.trim();
if (!keyword) return;
var escaped = keyword.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
var regex = new RegExp('(' + escaped + ')', 'gi');
var escapeHTML = function (str) {
return str.replace(/[&<>"']/g, function (t) {
return { '&': '&amp;', '<': '&lt;', '>': '&gt;', '"': '&quot;', "'": '&#39;' }[t] || t;
});
};
function walk(node) {
$(node).contents().each(function () {
if (this.nodeType === Node.TEXT_NODE) {
var $t = $(this);
var text = escapeHTML($t.text());
if (regex.test(text)) $t.replaceWith(text.replace(regex, '<mark>$1</mark>'));
} else if (this.nodeType === Node.ELEMENT_NODE && !$(this).is('script, style, noscript, textarea')) {
walk(this);
}
});
}
$('section').each(function () { walk(this); });
}
/** Google Analytics 页面浏览事件 */
function trackPageView() {
if (typeof gtag === 'function') {
gtag('config', window._gaId || '', { page_path: window.location.pathname });
}
}
/** Live2D 重初始化 */
var _live2dSelectors = ['.post-link', '#search-input'];
var _live2dDelegateBound = false;
function reinitLive2d() {
if (!window._live2d) return;
var pathname = window.location.pathname;
// 更新"想问这篇文章"相关状态(仅真正的文章页显示)
$('#post_id').val(pathname);
if ($(CONTAINER + ' #gitalk-container').length > 0) {
$('.live_talk_input_name_body').show();
} else {
$('.live_talk_input_name_body').hide();
$('#load_this').prop('checked', false);
}
// 音乐按钮:根据当前页面是否有 BGM 输入来显示/隐藏
if (typeof window._live2d.initBGM === 'function') {
window._live2d.initBGM();
}
// 事件委托绑定(只执行一次)
if (!_live2dDelegateBound && typeof String.prototype.renderTip === 'function') {
var selector = CONTAINER + ' ' + _live2dSelectors.join(', ' + CONTAINER + ' ');
$(document).on('mouseover._live2d_pjax', selector, function (e) {
var $el = $(e.currentTarget || e.target);
if ($el.is('.post-link')) {
window._live2d.showMessage('要看看 ' + $el.text() + ' 么?', 3000);
} else if ($el.is('#search-input')) {
window._live2d.showMessage('在找什么东西呢,需要帮忙吗?', 3000);
}
});
$(document).on('mouseout._live2d_pjax', selector, function () {
if (window._live2d.showHitokoto) window._live2d.showHitokoto();
});
_live2dDelegateBound = true;
}
// 欢迎语
if (typeof window._live2d.showMessage === 'function') {
window._live2d.showMessage(getWelcomeText(pathname), 6000);
}
}
// ========== PJAX 导航 ==========
/** PJAX 完成后的统一处理 */
function doPjaxComplete() {
$('body').removeClass('pjax-loading');
// 清理可能残留的浮层(如推荐文章 tooltiphover 后点击跳转时 mouseleave 来不及触发)
$('.content-tooltip').remove();
onPjaxComplete();
}
/** 暴露给模板内 onclick/onchange 调用的导航函数 */
window.go = function (url) {
$.pjax({ url: url, ...PJAX_OPTS });
};
// ========== 初始化 ==========
/** 每次 pjax 完成后执行所有重初始化 */
function onPjaxComplete() {
reinitVisitors();
reinitCopyButtons();
reinitHighlight();
reinitAISummary();
reinitLive2d();
trackPageView();
window.scrollTo(0, 0);
}
$(document).ready(function () {
// 排除列表外链、锚点、静态资源、Live2D 目录
var exclude = ':not([target="_blank"]):not([href^="http"]):not([href^="//"])' +
':not([href^="mailto"]):not([href^="#"])' +
':not([href$=".xml"]):not([href$=".json"]):not([href$=".tgz"]):not([href$=".zip"])' +
':not([href^="/Live2dHistoire"])';
$(document).pjax('a' + exclude, PJAX_OPTS.container, PJAX_OPTS);
$(document).on('submit', 'form#search-input-all', function (e) {
$.pjax.submit(e, PJAX_OPTS.container, PJAX_OPTS);
});
$(document).on('pjax:send', function () {
$('body').addClass('pjax-loading');
});
$(document).on('pjax:complete', doPjaxComplete);
$(document).on('pjax:error', function (xhr, textStatus, error) {
console.warn('[pjax] error, fallback:', error);
});
$(document).on('pjax:end', function (event, xhr, options) {
var $container = $(options.container || PJAX_OPTS.container);
$container.find('script[type="module"]').each(function () {
var oldScript = this;
var newScript = document.createElement('script');
newScript.type = 'module';
// 如果是外链脚本 (<script src="..."></script>)
if (oldScript.src) {
newScript.src = oldScript.src;
} else {
// 如果是行内脚本 (<script>...code...</script>)
newScript.textContent = oldScript.textContent;
}
// 插入到 body 中触发浏览器执行
document.body.appendChild(newScript);
// 运行完后建议移除,防止 DOM 变得混乱(不影响模块执行)
newScript.remove();
});
});
// 首次加载初始化
reinitCopyButtons();
});
})(jQuery);

View File

@ -1,17 +0,0 @@
---
---
/* AUTHOR */
Name: Mayx
Contact: mayx@outlook.com
GitHub: Mabbs
From: China
/* THANKS */
Built with: Jekyll (https://jekyllrb.com)
/* SITE */
Last update: {{ site.time | date: "%F" }}
Language: Chinese / English
Doctype: HTML5
IDE: VSCode

View File

@ -5,14 +5,14 @@ image: https://screenshot.mayx.eu.org/
---
{% if paginator.page == 1 %}<div class="hslice" id="LatestPost">{% endif %}
<h1 class="entry-title" style="display:inline"> 首页 - 我的文章 </h1><small><a href="/archives.html">Archives</a> | <a href="javascript:void(0)" onclick="getSearchJSON(function(data){go(data[Math.floor(Math.random()*data.length)].url)})">Random</a></small><br /><br />
<h1 class="entry-title" style="display:inline"> 首页 - 我的文章 </h1><small><a href="/archives.html">Archives</a> | <a href="javascript:getSearchJSON(function(data){location=data[Math.floor(Math.random()*data.length)].url})">Random</a></small><br /><br />
<hr />
<!-- 遍历分页后的文章 -->
<table class="entry-content h-feed">
{% for post in paginator.posts %}
<tr><td class="h-entry" onclick="if (!event.target.closest('a.p-category')) go('{{ post.url }}')">
<tr><td class="h-entry" onclick="location='{{ post.url }}'">
<h2 class="p-name"><a class="post-link u-url" href="{{ post.url }}">{{ post.title }}{% if post.layout == "encrypt" %} [加密] {% endif %}</a></h2>
<p>
<time class="date dt-published" datetime="{{ post.date | date_to_xmlschema }}">{{ post.date | date: "%-d %B %Y" }}</time>
@ -24,7 +24,7 @@ image: https://screenshot.mayx.eu.org/
{% if post.tags %}
<span>
{% for tag in post.tags %}
<a rel="category tag" class="p-category" href="/search.html?keyword={{ tag | uri_escape }}"><code style="white-space: nowrap">#{{ tag }}</code></a>
<a rel="category tag" class="p-category" href="/search.html?keyword={{ tag | url_encode | replace: '+', '%20' }}"><code style="white-space: nowrap">#{{ tag }}</code></a>
{% endfor %}
</span>
{% endif %}
@ -44,7 +44,7 @@ image: https://screenshot.mayx.eu.org/
<span>&laquo; Prev</span>
{% endif %}
<select onchange="go(this.value == 1 ? '/index.html' : '/page' + this.value + '/index.html')">
<select onchange="window.location = this.value == 1 ? '/index.html' : '/page' + this.value + '/index.html'">
{% for page in (1..paginator.total_pages) %}
{% if page == paginator.page %}
<option value="{{ page }}" selected>{{ page }}</option>
@ -67,7 +67,6 @@ image: https://screenshot.mayx.eu.org/
<p>
<a href="/service.html">Mayx的公开服务</a><br />
凯露&危险生存( <a href="{% unless site.github %}https://mabbs.github.io{% endunless %}/karyl-yabaival/?cn">CHS</a> | <a href="{% unless site.github %}https://mabbs.github.io{% endunless %}/karyl-yabaival/">JA</a> | <a href="{% unless site.github %}https://mabbs.github.io{% endunless %}/karyl-yabaival/?kr">KO</a> <br />
<a href="{% unless site.github %}https://mabbs.github.io{% endunless %}/brainfuck-visualizer/">Brainfuck可视化演示</a><br />
<a href="/message.html">留言板</a><br />
<a href="/links.html">Links</a><br />
<a href="/proxylist.html">代理列表</a><br />

View File

@ -4,12 +4,11 @@ title: Links
date: 2019-05-03
id: links
tags: [links]
robots: nofollow
---
| Link | Description |
| - | - |
{% for item in site.data.links %}| <a href="{{ item.link }}" target="_blank" rel="noopener" {% if item.feed_url %}data-feed="{{ item.feed_url }}"{% endif %}>{{ item.title }}</a> | {% if item.description %}{{ item.description }}{% else %}*No description*{% endif %} |
{% for item in site.data.links %}| <a href="{{ item.link }}" target="_blank" rel="noopener sponsored" {% if item.feed_url %}data-feed="{{ item.feed_url }}"{% endif %}>{{ item.title }}</a> | {% if item.description %}{{ item.description }}{% else %}*No description*{% endif %} |
{% endfor %}
订阅以上链接:[OPML](/blogroll.opml)

View File

@ -1,14 +0,0 @@
---
---
# {{ site.title }}
> {{ site.description }}
## Site Info
- [About Site](/README.html)
- [About Author](/humans.txt)
## Posts
{% for post in site.posts %}
- [{{ post.title }}{% if post.layout == "encrypt" %} [加密] {% endif %}]({{ post.url }}): {% assign ai_cache = site.data.ai-cache[post.url] %}{% if ai_cache %}{{ ai_cache | strip_html | strip_newlines }}{% elsif post.excerpt %}{{ post.excerpt | strip_html | strip_newlines }}{% else %}Just a Post.{% endif %}{% endfor %}

View File

@ -1,10 +0,0 @@
---
layout: default
title: 其他Git仓库镜像列表
robots: noindex, nofollow
---
# 其他Git仓库镜像列表
目前已有的社区/个人类型实例托管Git仓库共有{{ site.data.other_repo_list | size }}个:
{% for item in site.data.other_repo_list %}- <{{ item.repo_url }}>
{% endfor %}

View File

@ -1,7 +1,6 @@
---
layout: default
title: 代理列表
robots: nofollow
---
源站:<https://mabbs.github.io/> <img src="https://mabbs.github.io/images/online.svg" style="width: 1.2em; vertical-align: text-bottom;" onerror="this.outerHTML='ⓧ'"/>
@ -19,12 +18,10 @@ robots: nofollow
{% for item in site.data.proxylist.mirrors %}- <{{ item }}> <img src="{{ item }}images/online.svg" style="width: 1.2em; vertical-align: text-bottom;" onerror="this.outerHTML='ⓧ'"/>
{% endfor %}
# Git仓库列表
{% for item in site.data.proxylist.repos %}- <{{ item }}>
# Git列表
{% for item in site.data.proxylist.gits %}- <{{ item }}>
{% endfor %}
其他更多社区/个人类型实例托管的Git仓库列表参见[这里](/other_repo_list.html)
# 服务架构
```mermaid
graph LR;
@ -32,8 +29,7 @@ graph LR;
GH@{ shape: bow-rect, label: "GitHub" }
GL@{ shape: bow-rect, label: "GitLab" }
GE@{ shape: bow-rect, label: "Gitee" }
OG@{ shape: bow-rect, label: "And more..." }
OGP@{ shape: docs, label: "And more..." }
OG@{ shape: bow-rect, label: "Other..." }
CFP@{ shape: docs, label: "CloudFlare Pages" }
GHP@{ shape: docs, label: "GitHub Pages" }
GLP@{ shape: docs, label: "GitLab Pages" }
@ -42,13 +38,14 @@ graph LR;
GF@{ shape: lin-cyl, label: "Greenfield" }
Vercel@{ shape: docs, label: "Vercel" }
Netlify@{ shape: docs, label: "Netlify" }
SH@{ shape: docs, label: "statichost.eu" }
DA@{ shape: docs, label: "dAppling" }
CFW@{ label: "CloudFlare Workers" }
CFAI@{ shape: procs, label: "CloudFlare AI" }
CFD@{ shape: lin-cyl, label: "CloudFlare D1" }
Deno@{ shape: curv-trap, label: "Deno" }
Glitch@{ shape: curv-trap, label: "Glitch" }
Other@{ shape: curv-trap, label: "And more..." }
Other@{ shape: curv-trap, label: "Other..." }
subgraph Repo
GH
GL
@ -60,11 +57,11 @@ graph LR;
GHP
GLP
CFP
SH
FELH
DA
Vercel
Netlify
OGP
end
subgraph API[API Service]
@ -87,7 +84,7 @@ graph LR;
GH <-- Sync --> GL
GH -- Sync --> GE
GH -. Sync .-> OG
GH -- Deploy --> GHP & Netlify & FELH & DA & OGP
GH -- Deploy --> GHP & SH & Netlify & FELH & DA
GL -- Deploy --> CFP & Vercel & GLP
CFW -- Reverse Proxy --> GHP
Deno -- Reverse Proxy --> GHP

View File

@ -3,7 +3,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xml" href="/feed.xslt.xml"?>
<?xml-stylesheet type="text/css" href="/assets/css/feed.css"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
<channel>
<title>{{ site.title | xml_escape }}</title>

View File

@ -27,7 +27,7 @@ if (mykeyword) {
</script>
<script src="/assets/js/simple-jekyll-search.min.js"></script>
<script>
function _doSearch(json) {
getSearchJSON(function(json){
var sjs = SimpleJekyllSearch({
searchInput: sbox,
resultsContainer: document.getElementById('results-container'),
@ -37,22 +37,5 @@ function _doSearch(json) {
});
sjs.search(mykeyword);
document.getElementById('search-loading').style.display = "none";
}
getSearchJSON(function(json) {
if (typeof SimpleJekyllSearch !== 'undefined') {
_doSearch(json);
} else {
// PJAX 场景:外部脚本通过 pjax 库异步加载,需要等待加载完成
var _poll = 0;
var _waitSJS = setInterval(function() {
if (typeof SimpleJekyllSearch !== 'undefined') {
clearInterval(_waitSJS);
_doSearch(json);
} else if (++_poll > 100) {
clearInterval(_waitSJS);
document.getElementById('search-loading').style.display = "none";
}
}, 50);
}
});
</script>