跳转到内容
彼岸论坛

小天管理

管理员
  • 内容数

    19567
  • 注册日期

  • 最后上线

  • 得奖次数

    5

小天管理 发表的所有内容

  1. 使用 Ballast 文件解决 Docker 容器磁盘占满无法启动的问题 背景 在容器开发工作中,售卖算力容器是一个很常见的需求,不管是用 Docker 容器还是 K8s Pod 交付。 其中有一个问题是:我们提供给用户的容器默认是没有限制 / 目录的,虽然说这些都是临时文件,真正需要持久化的文件我们可以提供分布式存储,然后挂载到用户容器的某个目录。 一个简单而有效的方式是使用 XFS 文件系统配合 --storage-opt 参数就能限制用户容器的 / 目录,也可以说是限制用户容器的系统盘大小。 问题 但是当用户长期使用一个容器,比如在容器里进行模型训练,会导致系统盘空间越来越小,当系统盘空间已经非常接近我们设置的大小时,例如限制系统盘大小为 20Gi ,用户已经使用了 19.9999Gi ,这时候当用户 Stop 了容器(关机),再次 Restart/Start 容器(开机)时很可能会失败。 报错信息如下: Error response from daemon: mkdir /localData/docker/overlay2/7adae703b531d3e114cd171999e5502fe685e13835569b6f1d9fb31ab812773b/merged: disk quota exceeded 这好像没什么好的解决办法,因为造成问题的原因是用户把容器当成了虚机来用,一般情况下我们也不会持久化用户容器的临时文件。 但目前确实遇到了这个问题,所以和朋友一番讨论后,想出来了一个思路。 实现思路 前段时间研究了一下 Golang 控制 GC 频率的方法,其中使用的是 ballast ,就像下面代码中: 初始化了一个生命周期贯穿整个 Go 应用的超大 Slice ,保证 GC 在 10G 的一倍时才被触发。 详情参考这篇文章 性能优化 | Go Ballast 让内存控制更加丝滑 package main import "runtime" func main() { ballast := make([]byte, 10*1024*1024*1024) // 10G // do something runtime.KeepAlive(ballast) } 所以脑洞大开,我们能不能也用 ballast 的思想来为容器提供一个 ballast ,当容器磁盘不足时,我们手动减少这个 “压舱石” 的大小,这样就能能保证容器关机后,再次重启时,不会因为磁盘不足,导致失败了。 当然这样的操作是基于一个前提的,就是: 无论如何都不应该删除用户容器里的任何东西,即使是日志或者垃圾文件。 所以使用一个人畜无害的压舱石,可能是比较优雅的方式。 坏处也很明显,就是用户可以删除这块压舱石,并且用户 df -h 看到的空间是和实际购买的不一样。 具体实现 用户开通容器时 当用户开通一个容器,我们会限制用户容器的系统盘大小,比如说默认 20Gi 的空间,但是通过程序开通容器时,我们使用 --storage-opt size 限制时会把系统盘大小设置为 20Gi + 5Gi ,5Gi 的文件作为一个 ballast (压舱石)存在于用户的容器中。 当用户使用了 19.9Gi (实际情况下要比这个数字更接近 20Gi ) 的空间后,df -h 显示如下内容: $ df -h Filesystem Size Used / 25Gi 24.9Gi 用户关机时 重点在 Stop 时,如果说 Used 已经很接近 Size 了,那么我们就调整 ballast 的大小,保证用户容器正确启动。 举个例子,当 Used 已经为 24.9Gi ,限制的大小为 25Gi ,我们 Stop 时,把 ballast 的大小减小 0.5Gi, 保证用户容器正确启动。 源码地址 ballast-docker-container 如果对你有帮助,请给我一个 Star ⭐️
  2. 从 4 月到现在,放弃了一切游戏、娱乐、外出,除了上班吃饭睡觉,就是肝自己的项目。 一路过来解决了很多问题,最近又遇到困难瓶颈,感觉肝不动了。 经常看到哪些肝一年、两年、几年的 v 友,真想知道大家的动力是什么, 什么信仰可以让你放弃一切,长期坚持专注的。 我最大的动力是感觉自己越来越老了, 时间越来越少,精力越来越不够了.... 我知道只要一个分心,就会走进岔路,回不来了, 不能分心,不能分神,这是最后的机会了...
  3. 我已经在回家的地铁上啦,大家下班没ヾ(❀╹◡╹)ノ゙❀~ 武汉真的有点堵!
  4. 所有广电 192G 的产品将于 2024 年 9 月 30 日(今日)晚 22 点,正式下架,替换为 24 元 120G 以及 34 元 120G+120 分钟,有需要的朋友可以考虑下单了😂 https://172.lot-ml.com/ProductEn/Index/3a283a0a00302f2f
  5. 最近几个月我的笔记本经常会出现这样的情况,两三天不关机之后,笔记本就会出现资源管理器卡死的问题:无法打开任务管理器,无法打开任何应用,任务栏的应用点击没反应,想要关机重启也关不了,只能电源键强制关机。 想知道各位大佬有碰到过这个问题吗?是怎么解决的,真滴烦呀
  6. 呃,第一只安卓机,在小米和谷歌之间做了好久考虑 生活地区:50 国内 / 50 海外 贪小米的 1T 影像套装 和 各种对国民级 app 的适配 ( eu 版 和 global 版是一样的吗?) 贪 GrapheneOS 对 pixel 的友好. 虽然有其他手机可以做主力机如果需要的时候。但是还是想选择一台给力的安卓机,想转安卓作为主力了。 在香港买小米会有什么不同吗?硬件上,例如 esim,软件上,rom ? 最好的方案是否先线专卖店下买小米,然后直接刷 ROM 呢? 请分享对小米 14 的爱恨情仇吧
  7. 干的时间长了越发现职场有很多很恶心的人,文中的他不全是同一个人,以本人后端开发的视角,举几个例子感受下: 《特点一:自己的问题,嘴硬不愿意承认》 case 1 测试测出问题,来找他问: “这个东西,是不是没问题了” “没问题了,测过了”, (他显然没测过) “现在有问题,问题是:xxxxxx” “不可能”....“哦 这是数据问题( xx 问题,xx 导致的...)” (因为我是同组后端,很清楚,他是为了阐述原因,还是为自己辩解。总之就是,想找个理由,来表示自己导致的这个 bug 是有非常合理的原因的) case 2 我发现他的代码有问题,跟他讲。 “怎么会有问题,肯定没问题呀”....“你说的是,在极端情况下是有点问题,你这样的好处是 xx ,我这样的好处是 xx”。 然后自己,偷偷改掉。 在外人听他说的好像没问题,实际上他的明显不对,还嘴硬什么呢,我们环境整体和平,根本就没人跟你计较谁的责任,只是发现了问题,改掉就行了,而已。 就这个错了不愿意认,总想再说点啥,好让自己舒服的接受。 别说为啥我闲的去看他代码,要不是出 bug 总需要我看 我才不管呢 《特点二:别人的问题,夸张放大来抬高自己》 有次,别人改了问题让我忙部署到测试环境,我顺手帮点一下,去了厕所,回来他测试环境挂了,然后直接在群里 @我,“你不要打包部署操作完,就放那不管了,起码看一下运行成功没啊” 结果问题是代码编译都不通过,但是我觉得这可以理解,不小心或者 idea 没有识别,就 push ,谁都有失误。 但是令我发火的是,他在群里 @,而且说这句话,对于后端人来讲,部署之后验证是否运行成功,这是最基本的行为和职位操守了吧,感觉到超级不被尊重。直接想反怼了,旁边的人拉着我,说一个组的,别这样。稍微平和一下,越想越气,tmd 原来旁边也是狗啊,我跟旁边的人说,这是帮你部署的,他在群里这样说,你不应该一言不发吧,我不能平白无故被怼吧,最后他群里说了句:我没验证,我的问题。 算了了。 然后我就想:你有本事,别让我逮着你失误犯低级错误的时候。 果不其然,过了几天,测试群里说服务器挂了,我一查,他提交了,未能编译通过的代码,我也打字:@他 你提交代码之前,都不编译检查一下吗? 最后我删了没发,我想得饶人处且饶人,打个工,没必要跟他针锋相对的,他这个情商,我不能跟他一般见识。晚饭和测试一起吃,他入职的早,讲到那个人说,我们测试组都知道他啥样,情商贼低,还巨能装。 《特点三:表里不一,个人利益至上》 开发工期紧张,一个人一个模块,先给调用者定义接口,然后再写实现。 中间的我的内容写完了,等他接口。但他忙不过来一直没定义接口给到我,说写不完了 他下周提测吧。 我先下班了,结果组长开会回来说,这周必须提测,还差多少了 他:写完了。 我:除了和他连调的都写完了。 然后认为我耽误了进度。 实际他没写完,或者是说只按照最简单的方式提供了接口,这样我需要帮他组装数据改很多代码了,但是他就说他写完了,在组长看来 他写完了,而我还没有搞明白和搞完。 《特点四:又菜又爱装》 这里 举几个技术场景吧 case 1 springbean 对象成员变量定义变量, 说没线程安全问题 case 2 spring 拦截器,根据 token 设置 userid 等信息放到 threadLocal 里,我说原生 threadLocal 多线程有问题,直接用阿里的 TransmittableThreadLocal,后续多线程中也不会有问题了。 “这样写问题也不大,那个我也用过,不咋好用” 真的想骂人,咋这么能装逼呢, 什么就不咋好用就是一个多肽而已 该咋用咋用,java 的两个 threadLocal 都不是推荐用的,用了等于给自己挖坑。 case 3 插入更新 1w 条记录,并优化性能。 他做成了,线程池 1 个线程处理 1000 条,导致了死锁。 他自己在那念叨,这不好解决呀,根本没办法控制,先不说批量更新插入这种方式合理吗,就说死锁。 我试探问他, “找到问题了吗” “找到了” “啥问题导致的” “就是多线程处理数据,造成了死锁” 我就想笑了,这不是废话吗,报错都打印了 “具体啥原因导致的” 他支支吾吾讲不清了, 说没办法解决 “因为 1w 条数据里面有很多数据,更新的 where 条件相同,导致两个事物同时更新同一条记录,持有锁的事物没有及时提交事物导致,把相同 where 条件的数据分到一个线程里大概就解决了” 他讲一堆没用的说,“只能是降低死锁概率,并不能彻底解决,可以先这么优化” ,只能说是真会装逼。 我又说“没必要这么先分组很复杂,可以换种方式直接捕获死锁异常,做个补偿机制就可以了,大概率都不会出现这种数据的” 他支支吾吾 说一些中立的话,其实这很显然不合理的,没有处理死锁情况属于浪费数据资源啊。,我又问这个死锁异常,是数据库抛的 还是 spring 抛的,他也搞不清了,就乱说。 ============================================== 我是一个直爽的人,就觉得这样的人很狗,我的认知是: 有问题改了就完了呗,又不丢人; 不懂得东西就大胆说这块不懂,我稍后看一下,很难以启齿吗? 最烦这种,不懂装懂的, 又巨狗的。 但是往往这种“狗”人,职场上却偏得老板喜欢。
  8. 🔗 Innicdata GUI:DuckDB 数据库的革命性操作体验 欢迎体验 Innicdata ,全球首个专为 DuckDB 数据库设计的图形用户界面。我们自豪地宣告,数据库管理的艺术已迈入新纪元。 🔑 Innicdata 的核心优势: 首创 GUI:Innicdata 是全球首个支持 DuckDB 的图形用户界面,引领数据库交互新潮流。 用户友好设计:直观的操作界面,让复杂的数据库任务变得简单易懂。 跨平台无缝体验:无论是 Windows 、macOS 还是 Linux ,Innicdata 都能提供一致的高效体验。 数据安全:采用行业标准的加密技术,确保数据的安全性和隐私性。 高级数据可视化:创新的数据展示方式,让数据分析结果更加直观明了。 集成开发环境( IDE ):集成的查询构建器、编辑器和调试工具,提升开发效率。 🚀 智能管理,专业之选: 一键接入:Innicdata AI 驱动数据库 GUI 工具,让您只需一键即可快速连接数据库,极大简化了操作流程。 智能交互:利用先进的 AI 技术,Innicdata 提供智能提示和自动完成功能,帮助您高效编写和执行 SQL 语句。 无缝操作:无论是数据查询、编辑还是管理,Innicdata 都能提供流畅、直观的操作体验,让数据库管理变得轻松愉快。 工作效率:优化的数据库连接和查询执行,显著提升数据处理速度和业务响应能力。 技术普及:降低技术门槛,让所有用户都能轻松管理 DuckDB 数据库。 🎯 特别推荐: DuckDB:Innicdata 全面支持 DuckDB 数据库,提供全兼容的数据库操作体验,无缝集成 DuckDB 的强大功能。 Parquet 支持:Innicdata 支持 Parquet 文件格式,优化数据存储和查询性能,支持高效的数据分析和处理。 🌐 立即加入 Innicdata 智能数据库管理的行列: 立即访问 Innicdata 官网 下载 Innicdata ,体验全球首个 DuckDB GUI 的独特魅力。 加入我们的社区,与全球数据专家共同探索数据的无限可能。 社交媒体: 知乎:innicdata Slack:加入 Slack Discord:加入 Discord 立即体验 Innicdata ,开启您的智能数据库管理之旅!
  9. 使用场景:主要是想在家丢掉笔记本,轻度家用,刷网页看视频和远程桌面之类的,运存要够大 系统:Windows 和 mac OS 价格范围:2K 内 牌子:排除小作坊 插孔:最好有 VGA 但纯 HDMI 也可 目前在看 nuc 小主机,推最多的好像是 8 ,看上去不错但感觉水深,准系统和无内存之类的不是很懂,求用过的大佬们指指路。
  10. 有三个二维码解析出来的数据,下面显示是 16 进制。有大神能看出来是用何种加密方式吗?开头是 0303 ,第 5 、6 位是相同内容的字节。这三个的原始内容数据应该很相近,但这个密文的差异很大,所以猜测这些数据是加密后的。 03 03 D2 57 D0 D0 3E 84 FE 20 FA E7 2D 94 77 4D 5F ED E9 B8 F9 DC 1C C7 1A D9 29 47 AD 25 4F 0B 92 F5 CD B4 66 2E B3 A9 3A 05 89 19 EA BF A1 82 EA 76 4A AB 9D C9 2B 12 0A D1 64 4A 0C 23 10 A6 EC 7A 1F E7 96 38 17 CF 76 0B 51 CF D0 F3 DC 77 AA 03 03 54 C5 E7 E7 09 B3 C9 17 CD D0 1B A2 59 63 71 C7 C4 15 12 87 D1 6F 24 55 52 C4 96 B4 48 08 C5 65 89 6D 2A 19 F0 C0 E8 03 C2 63 B4 1D 14 D8 AF 29 03 8B FF EC 33 55 62 58 B1 10 FC 31 48 E0 5C 50 76 60 91 86 0E DA 13 C3 FE 19 1E 3D 29 81 A1 03 03 7F B8 1F 1F F1 4B 31 EF 35 28 EF 5E A1 9B 89 23 20 E0 63 2A DC 27 B7 8C CC 68 FE 74 1C 5B CE 49 ED 14 AF 70 EE BC 3E B1 89 7D 47 B2 80 14 33 37 77 D3 48 FA 63 AE 89 68 92 0E 67 D9 A3 E9 9B A4 5C 55 44 22 E2 33 C8 C8 33 34 11 66 9A 29
  11. 屏幕被猫咬了一个洞。 MacBook 有 ac ,预约维修,一般是现场维修还是返厂呢,需要备份资料吗 希望各位有经验的 v 友帮忙解答下
  12. 以前只是觉得叮咚卖菜像在卖那啥,按克卖,太小家子气了 昨天买了他家的非转基因豆腐,发现包装上明确写着, 非转基因大豆含量 >30%,这尼玛的是欺负我们智商不到 150 吗?
  13. 你们用那个版本用的比较多
  14. 之前的几个 macOS 版本上都没有这个问题。
  15. 已经加了三四个招商银行客户经理的微信了。。。。
  16. 除了给每个联系人发 A 微信的名片外, 还有其他更便捷的操作吗?
  17. 前不久找了一个远程工作 周一:开始给个网站,看一下产品、熟悉一下,而且也要感想和怎么做的构思(类似一种考验) 周二、周三、周四、给个功能试着干了一周(试用的考验) 周五提交作品,群里的合作的同事没说问题,都说挺好。 晚上负责人又说跟他们预想的不一样,火就上来了,最后说,国庆这几天再修改一下,结果 ok ,再谈薪资。。。。然后想了想算了,就回绝了。(最后也结算了几天的钱) 我是第一次接触远程工作,当时感觉就是远程的伙伴 工作 很容易自闭、活在显示屏的世界里干活,时间久了,疑神疑鬼,一点都不友善。 但是昨天又听到有个朋友公司裁员,又有点感觉自己脑子抽了。在想是不是当时自己忍一忍就算了。至少算一个小收入 过都过去了,就讲出来,看看有道友远程工作的分享的吗?
  18. 我先来吧,清空了亏损 20%以上的所有基金😂
  19. 求推荐 windows 平台的安卓模拟器,主要是安装一些安装的应用 app
  20. 大约从 7 年前自建变得越来越困难,我就开始使用 本地-->机场-->Vultr 小鸡的方式在科学上网。PC 使用的是 V2ray cli ,安卓用的 Kitsunebi ,手写自定义配置。但最近这个方式越来越不好用了,最主要的就是 Vultr 的 IP 风险等级非常高。AI Boom 以来各大网站都在加强反爬,现在 Vultr 的 IP 甚至直接无法访问 Reddit ,而同样因为 AI ,英文搜索出来的博客等网站被内容农场充斥(反而被 V 友们嫌弃落后的日本互联网幸存,现在依然有许多高质量且频繁更新的博客),所以 Reddit 之类的 social media 反而成了高质量信息源,因此最近不得不越来越多地直接使用机场出口,Vultr 每月的$5 都浪费了。于是我今天在 V2EX 和 hostloc 搜了搜,但自己从碎片信息研究越研究越乱,Nekobox ,Hysteria2 ,trojan ,sagernet ,wireproxy ,xray 等等等等越来越搞不懂了,希望有人能指点一下。 我现在主要是两方面的问题: 1 、落地如何选择?我大概想到 4 种 - 放弃中转方案,机场直接落地。缺点:审计(主要是 BT ,禁 P2P 我理解,但走 HTTP 的 web source 也不行)、IP 共用多、IP 跳 - 维持现状 Vultr 小鸡。能解决上面列的缺点(有人说 Vultr 禁 BT ,但我用了快 8 年了从没有任何问题。我非法 BT 用的不多,却也用过 Vultr JP 下日本动画,并没有收到任何警告)。问题是它的 IP 虽然固定,风险等级实在高,而且它的价格放到机场里能升一个 Tier ,或者加个备用,体验都会好很多,感觉这$5 每月实在浪费。 - Warp+。在 V2EX 和 hostloc 都看到不少人说这个。缺点:wireguard 是 UDP ,机场可能不支持,限速,以及使用 V2ray 等 UDP over TCP 方案导致性能不好。 - Seedbox 等送的 VPN ,一般基于 OpenVPN 。毕竟是送的属于是不用白不用,而且支持 BT 。 2 、客户端 - 自建小鸡最成熟,我自己也最熟悉,继续我现在的方案或用 Clash Relay 都行。 - Wireguard ( Warp 用的协议) Nekobox 和 sagernet ,wireproxy 等都能较简单地支持,Nekobox 还支持手机,总体来说还是比较简单的。 - OpenVPN 就难了,我没找到任何关于这个的。我之前自己有弄过,但手机不知道该怎么弄。 - 最关键的问题:怎么分流?比如说我偶尔想在手机上用 Seedbox 送的 VPN 下个小种子,有办法给 BT 专门分流吗?这些送的 VPN IP 都很差,我肯定是不会长期用的。Warp 不能解锁的流媒体,有办法分流到机场去吗? TG ,推特等风控严的,有办法固定好 IP 吗? 我现在感觉好像直接机场是不是已经是最好的了?机场的 IP 虽然会变,但固定国家问题应该不大吧?而且机场 IP 风险等级可比我现在的 Vultr 小鸡好太多了,风控这东西也是个黑盒子,自建的风险等级高和机场的 IP 变动+共用,不好说哪个影响大。BT 又该怎么办?我 BT 走代理主要是从 web source 走 HTTPS 协议下,不需要 BT 协议,也不需要和 tracker 联系,有没有什么办法走机场?这些问题我自己真的是越想越糊涂,希望有人能指点一下。
  21. 有些帖子的确需要匿名。比如刚才发了一些对最近股市和经济措施的消极看法。但是好像不适合发。 不知道大伙有没有这样的需求。我觉得价格匿名可能更好一些。可以多扣除一些铜币什么的。
  22. 原理如名,目前很多电视台都会在自己的网站上有直播,我使用 WebView 加载直播的网页 URL ,找到 video 标签并自动帮你全屏。 apk 适配了触摸和遥控器按键交互。 由于使用的是官网的 URL ,频道源非常稳定。 缺点:载入频道稍长(没有直接打开直播源那么快,低性能机器上可能不流畅,无法选择清晰度等) Github: https://github.com/hxh19950701/WebViewTvLive
  23. 熊市思维: 上涨和下跌调整, 是因果 牛市思维: 上涨和进一步更猛烈的上涨,是因果 被股市教育出来的思维无法立即切换,你们默默切换就好,不用说出来 一颗石子刚刚投入水面,更大的波澜正在等着被激发,老股民吓他自己无可厚非, 新股民还是离他们远点
  24. 因为工作需要,每天会有大量来电,现在我是用的小米的小爱通话,AI 读出预定文本后,并不会自动挂断,然后来电人就会一直和我的小爱同学聊天,有没有替代的软件,可以实现自动挂断的呢。
×
×
  • 创建新的...