在 Claude Code 中以 MCP 接入 Codex

Codex CLI 的命令行交互较为原始,沙箱环境存在不少 bug,执行命令时也受到诸多限制。相比之下,Claude Code 的设计更加完善,支持 MCP、Plugin、Skill、Agent 等多种自定义扩展形式。将 Codex 作为 MCP 服务器接入 Claude Code,可以获得更友好的用户体验和更强大的功能集成。 为什么选择 MCP 方式而非直接使用 Codex CLI Codex CLI 的局限性 命令行交互原始:缺乏现代化的交互体验,错误提示不够清晰 沙箱环境 bug 多:执行复杂任务时容易遇到环境问题 命令执行受限:某些操作在沙箱中无法正常执行,自由度较低 Claude Code 的优势 设计完善:提供更流畅的代码编辑和 AI 交互体验 扩展性强:支持 MCP、Plugin、Skill、Agent 等多种扩展方式 工具集成:可以无缝整合多种工具和服务 用户体验友好:界面直观,错误处理更完善 通过 MCP 方式,Codex 可以作为 Claude Code 的一个工具被调用,既保留了 Codex 的能力,又享受了 Claude Code 的完善生态。 前置要求 已安装 Claude Code CLI(可通过 claude -v 验证) 已安装 Codex CLI,并能在终端调用 codex 命令 配置步骤 一条命令完成添加(用户作用域) claude mcp add codex -s user -- codex -m gpt-5.1-codex-max -c model_reasoning_effort="high" mcp-server 参数说明: -s user:将服务器写入用户全局配置,所有项目可用且不会改动仓库文件 --:分隔 Claude MCP 参数与实际服务器启动命令 codex -m gpt-5.1-codex-max:指定要暴露的 Codex 模型 -c model_reasoning_effort="high":为 Codex 进程设置高推理强度 mcp-server:启动 Codex 的 MCP 服务器模式 验证配置是否生效 # 列出所有 MCP 服务器 claude mcp list # 查看 codex 服务器详情 claude mcp get codex 若能看到 type: stdio 且状态为 running/available,说明已成功接入。 在 Claude Code 中使用 打开 Claude Code,在对话中输入 /mcp 命令 选择 codex 服务器 直接在对话中调用 Codex 暴露的工具;如需指定模型,可在提示中写明 gpt-5.1-codex-max 现在你可以在 Claude Code 的完善环境中使用 Codex 的能力,同时享受更好的交互体验和工具集成。 常见问题 找不到 claude 命令:确保已安装 Claude Code CLI 并已加入系统 PATH 找不到 codex 命令:先安装 Codex CLI(参考 Codex 官方安装说明),或检查 shell PATH 配置 想移除服务器:使用 claude mcp remove codex 命令 切换配置作用域:如需改用项目级配置,先删除用户级配置,再按需添加项目级配置

2025/12/14
articleCard.readMore

Claude Code 插件与 Hook 开发完整教程

Claude Code 提供了强大的插件系统,允许你通过自定义命令、代理、Hook、Skills 和 MCP 服务器来扩展功能。本文将完整介绍如何从零开始开发 Claude Code 插件和 Hook,包括创建插件、配置 Hook、发布到 Marketplace 等全流程。 为什么需要插件系统 Claude Code 的插件系统提供了多种扩展方式: Commands(命令):创建自定义斜杠命令,快速执行常用操作 Agents(代理):定义专门的子代理来处理特定任务 Skills(技能):扩展 Claude 的能力,让模型自主调用 Hooks(钩子):在特定事件发生时自动执行脚本 MCP Servers:集成外部工具和服务 通过插件系统,你可以: 自动化工作流:在文件写入后自动格式化、运行测试 增强安全性:拦截危险操作、验证命令 集成工具:连接数据库、API、通知系统等 团队协作:在项目级别配置插件,确保团队使用一致的工具 快速开始:创建第一个插件 让我们通过创建一个简单的问候插件来熟悉插件系统。 前置要求 已安装 Claude Code(可通过 claude -v 验证) 基本的命令行操作知识 步骤 1:创建 Marketplace 结构 mkdir test-marketplace cd test-marketplace 步骤 2:创建插件目录 mkdir my-first-plugin cd my-first-plugin 步骤 3:创建插件清单文件 插件清单文件 .claude-plugin/plugin.json 描述了插件的基本信息: mkdir .claude-plugin cat > .claude-plugin/plugin.json << 'EOF' { "name": "my-first-plugin", "description": "一个简单的问候插件,用于学习基础知识", "version": "1.0.0", "author": { "name": "Your Name" } } EOF 步骤 4:添加自定义命令 在 commands/ 目录下创建命令文件: mkdir commands cat > commands/hello.md << 'EOF' --- description: 用个性化的消息问候用户 --- # Hello Command 热情地问候用户,并询问今天能如何帮助他们。让问候更加个性化和鼓励性。 EOF 步骤 5:创建 Marketplace 清单 返回上级目录,创建 Marketplace 配置文件: cd .. mkdir .claude-plugin cat > .claude-plugin/marketplace.json << 'EOF' { "name": "test-marketplace", "owner": { "name": "Test User" }, "plugins": [ { "name": "my-first-plugin", "source": "./my-first-plugin", "description": "我的第一个测试插件" } ] } EOF 步骤 6:安装和测试 # 从父目录启动 Claude Code cd .. claude # 在 Claude Code 中添加测试 Marketplace /plugin marketplace add ./test-marketplace # 安装你的插件 /plugin install my-first-plugin@test-marketplace 选择 “Install now”,然后需要重启 Claude Code 才能使用新插件。 # 尝试你的新命令 /hello 你会看到 Claude 使用你的问候命令!运行 /help 可以查看新命令是否已列出。 插件结构详解 一个完整的插件可以包含以下组件: my-plugin/ ├── .claude-plugin/ │ └── plugin.json # 插件元数据(必需) ├── commands/ # 自定义斜杠命令(可选) │ └── hello.md ├── agents/ # 自定义代理(可选) │ └── helper.md ├── skills/ # Agent Skills(可选) │ └── my-skill/ │ └── SKILL.md ├── hooks/ # 事件处理器(可选) │ └── hooks.json └── .mcp.json # MCP 服务器配置(可选) 插件清单(plugin.json) 这是插件的核心配置文件,必须包含: { "name": "plugin-name", "description": "插件描述", "version": "1.0.0", "author": { "name": "作者名称" } } Commands(命令) Commands 是自定义的斜杠命令,通过 Markdown 文件定义。文件内容会被发送给 Claude 作为指令。 示例:代码格式化命令 --- description: 自动格式化当前项目的代码 --- # Format Command 格式化当前项目中的所有代码文件。使用项目配置的格式化工具(如 Prettier、Black 等)。 确保遵循项目的代码风格指南。 Agents(代理) Agents 是专门的子代理,用于处理特定类型的任务。 示例:代码审查代理 --- description: 专业的代码审查助手 --- # Code Review Agent 你是一个专业的代码审查助手。你的任务是: 1. 仔细审查代码的质量、可读性和最佳实践 2. 识别潜在的安全漏洞和性能问题 3. 提供建设性的反馈和改进建议 4. 确保代码符合项目的编码标准 Skills(技能) Skills 是模型可以自主调用的能力扩展。创建 skills/ 目录,每个技能是一个包含 SKILL.md 的子目录。 示例:Git 操作技能 # Git Operations Skill 这个技能允许 Claude 执行常见的 Git 操作,如提交、推送、创建分支等。 Claude 可以在需要版本控制操作时自动使用此技能。 Hook 开发详解 Hook 是插件系统中最强大的功能之一,允许你在特定事件发生时自动执行脚本。 Hook 配置位置 Hook 可以在以下位置配置: ~/.claude/settings.json - 用户级设置 .claude/settings.json - 项目级设置 .claude/settings.local.json - 本地项目设置(不提交) 插件中的 hooks/hooks.json - 插件提供的 Hook Hook 事件类型 PreToolUse 在工具调用之前执行,可以拦截、修改或自动批准操作。 { "hooks": { "PreToolUse": [ { "matcher": "Write|Edit", "hooks": [ { "type": "command", "command": "$CLAUDE_PROJECT_DIR/.claude/hooks/validate-write.sh" } ] } ] } } PostToolUse 在工具成功执行后立即运行,常用于自动格式化、运行测试等。 { "hooks": { "PostToolUse": [ { "matcher": "Write|Edit", "hooks": [ { "type": "command", "command": "$CLAUDE_PROJECT_DIR/.claude/hooks/format-code.sh" } ] } ] } } Notification 当 Claude Code 发送通知时触发,可以用于桌面通知、日志记录等。 { "hooks": { "Notification": [ { "matcher": "permission_prompt", "hooks": [ { "type": "command", "command": "/path/to/notification.sh" } ] } ] } } UserPromptSubmit 在用户提交提示之前执行,可以添加上下文、验证提示等。 { "hooks": { "UserPromptSubmit": [ { "hooks": [ { "type": "command", "command": "$CLAUDE_PROJECT_DIR/.claude/hooks/add-context.sh" } ] } ] } } SessionStart / SessionEnd 在会话开始或结束时执行,用于环境设置、清理任务等。 Hook 输入和输出 Hook 通过 stdin 接收 JSON 数据,包含会话信息和事件特定数据: { "session_id": "abc123", "transcript_path": "/path/to/transcript.jsonl", "cwd": "/current/working/directory", "permission_mode": "default", "hook_event_name": "PostToolUse", "tool_name": "Write", "tool_input": { "file_path": "/path/to/file.txt", "content": "file content" }, "tool_response": { "filePath": "/path/to/file.txt", "success": true } } Hook 输出控制 Hook 可以通过退出码和 JSON 输出来控制行为: 简单方式:退出码 0:成功,stdout 在详细模式下显示 2:阻止操作,stderr 作为错误消息返回给 Claude 其他:非阻塞错误,stderr 在详细模式下显示 高级方式:JSON 输出 { "decision": "block", "reason": "解释为什么阻止操作", "hookSpecificOutput": { "hookEventName": "PreToolUse", "permissionDecision": "deny", "permissionDecisionReason": "此操作被安全策略阻止" } } 实战案例:通知插件开发 让我们参考 ritmex-marketplace 来创建一个完整的通知插件。 项目结构 ritmex-marketplace/ ├── .claude-plugin/ │ └── marketplace.json # Marketplace 配置 ├── claude-code-notification/ # 通知插件 │ ├── .claude-plugin/ │ │ └── plugin.json # 插件清单 │ ├── hooks/ │ │ └── hooks.json # Hook 配置 │ └── scripts/ │ └── notification.sh # 通知脚本 └── README.md Marketplace 配置 .claude-plugin/marketplace.json: { "name": "ritmex-marketplace", "owner": { "name": "discountry" }, "plugins": [ { "name": "claude-code-notification", "source": "./claude-code-notification", "description": "在 macOS 上显示 Claude Code 通知" } ] } 插件清单 claude-code-notification/.claude-plugin/plugin.json: { "name": "claude-code-notification", "description": "当 Claude Code 触发 Notification hook 时显示 macOS 通知", "version": "1.0.0", "author": { "name": "discountry" } } Hook 配置 claude-code-notification/hooks/hooks.json: { "description": "自动显示 macOS 通知", "hooks": { "Notification": [ { "matcher": "*", "hooks": [ { "type": "command", "command": "${CLAUDE_PLUGIN_ROOT}/scripts/notification.sh", "timeout": 30 } ] } ] } } 通知脚本 claude-code-notification/scripts/notification.sh: #!/bin/bash # 读取 JSON 输入 INPUT=$(cat) MESSAGE=$(echo "$INPUT" | jq -r '.message // "Claude Code Notification"') NOTIFICATION_TYPE=$(echo "$INPUT" | jq -r '.notification_type // ""') TRANSCRIPT_PATH=$(echo "$INPUT" | jq -r '.transcript_path // ""') # 设置通知标题 TITLE="${CLAUDE_NOTIFY_TITLE:-Claude Code}" # 根据通知类型设置点击行为 if [ "$NOTIFICATION_TYPE" = "permission_prompt" ]; then # 权限提示:点击时聚焦到终端 if command -v terminal-notifier &> /dev/null; then terminal-notifier \ -title "$TITLE" \ -message "$MESSAGE" \ -activate "com.warp.Warp" \ -sender "com.warp.Warp" 2>/dev/null || \ terminal-notifier \ -title "$TITLE" \ -message "$MESSAGE" \ -activate "com.apple.Terminal" \ -sender "com.apple.Terminal" else # 使用 osascript 作为后备 osascript -e "display notification \"$MESSAGE\" with title \"$TITLE\"" fi elif [ -n "$TRANSCRIPT_PATH" ]; then # 有 transcript 路径:点击时打开文件 if command -v terminal-notifier &> /dev/null; then terminal-notifier \ -title "$TITLE" \ -message "$MESSAGE" \ -open "$TRANSCRIPT_PATH" else osascript -e "display notification \"$MESSAGE\" with title \"$TITLE\"" fi else # 普通通知 if command -v terminal-notifier &> /dev/null; then terminal-notifier -title "$TITLE" -message "$MESSAGE" else osascript -e "display notification \"$MESSAGE\" with title \"$TITLE\"" fi fi exit 0 安装和使用 # 添加 Marketplace /plugin marketplace add discountry/ritmex-marketplace # 安装插件 /plugin install claude-code-notification@ritmex-marketplace # 验证安装 /plugin 高级 Hook 示例 示例 1:自动代码格式化 在文件写入后自动运行格式化工具: { "hooks": { "PostToolUse": [ { "matcher": "Write|Edit", "hooks": [ { "type": "command", "command": "$CLAUDE_PROJECT_DIR/.claude/hooks/format.sh", "timeout": 30 } ] } ] } } format.sh: #!/bin/bash INPUT=$(cat) FILE_PATH=$(echo "$INPUT" | jq -r '.tool_response.filePath // .tool_input.file_path // ""') if [ -z "$FILE_PATH" ]; then exit 0 fi # 根据文件类型选择格式化工具 case "$FILE_PATH" in *.js|*.jsx|*.ts|*.tsx|*.json) if command -v prettier &> /dev/null; then prettier --write "$FILE_PATH" 2>/dev/null fi ;; *.py) if command -v black &> /dev/null; then black "$FILE_PATH" 2>/dev/null fi ;; *.go) if command -v gofmt &> /dev/null; then gofmt -w "$FILE_PATH" 2>/dev/null fi ;; esac exit 0 示例 2:命令验证 拦截危险命令并建议更安全的替代方案: #!/usr/bin/env python3 import json import re import sys VALIDATION_RULES = [ ( r"\bgrep\b(?!.*\|)", "建议使用 'rg' (ripgrep) 替代 'grep',性能更好且功能更强大", ), ( r"\bfind\s+\S+\s+-name\b", "建议使用 'rg --files | rg pattern' 替代 'find -name',性能更好", ), ( r"rm\s+-rf\s+/", "危险操作:删除根目录!请确认这是你想要的。", ), ] try: input_data = json.load(sys.stdin) except json.JSONDecodeError as e: print(f"错误: 无效的 JSON 输入: {e}", file=sys.stderr) sys.exit(1) tool_name = input_data.get("tool_name", "") tool_input = input_data.get("tool_input", {}) command = tool_input.get("command", "") if tool_name != "Bash" or not command: sys.exit(0) issues = [] for pattern, message in VALIDATION_RULES: if re.search(pattern, command): issues.append(message) if issues: for message in issues: print(f"• {message}", file=sys.stderr) sys.exit(2) # 阻止命令执行 sys.exit(0) 示例 3:智能停止判断 使用 LLM 判断 Claude 是否应该继续工作: { "hooks": { "Stop": [ { "hooks": [ { "type": "prompt", "prompt": "评估 Claude 是否应该停止工作。上下文: $ARGUMENTS\n\n分析对话并判断:\n1. 用户请求的所有任务是否已完成\n2. 是否有需要解决的错误\n3. 是否需要后续工作\n\n返回 JSON: {\"decision\": \"approve\" 或 \"block\", \"reason\": \"你的解释\"}", "timeout": 30 } ] } ] } } 发布和分发插件 创建 GitHub Marketplace 创建仓库结构: mkdir my-marketplace cd my-marketplace mkdir .claude-plugin # 创建 marketplace.json # 添加插件目录 推送到 GitHub: git init git add . git commit -m "Initial marketplace" git remote add origin https://github.com/your-org/my-marketplace.git git push -u origin main 用户安装: /plugin marketplace add your-org/my-marketplace /plugin install plugin-name@my-marketplace 团队配置 在项目的 .claude/settings.json 中配置自动安装: { "extraKnownMarketplaces": { "my-marketplace": { "source": { "source": "github", "repo": "your-org/my-marketplace" } } }, "enabledPlugins": { "plugin-name@my-marketplace": true } } 团队成员信任仓库文件夹后,插件会自动安装。 最佳实践 安全性 验证输入:永远不要盲目信任输入数据 引用变量:使用 "$VAR" 而不是 $VAR 阻止路径遍历:检查文件路径中的 .. 使用绝对路径:为脚本指定完整路径 跳过敏感文件:避免处理 .env、.git/、密钥等 性能 设置超时:为长时间运行的脚本设置合理的超时 并行执行:多个匹配的 Hook 会并行运行 去重:相同的 Hook 命令会自动去重 调试 使用调试模式:claude --debug 查看详细执行信息 测试命令:先手动运行 Hook 命令确保正常工作 检查配置:使用 /hooks 查看已注册的 Hook 总结 Claude Code 的插件系统提供了强大的扩展能力: Commands:快速创建自定义命令 Agents:定义专门的子代理 Skills:扩展模型能力 Hooks:自动化工作流和增强安全性 MCP Servers:集成外部工具 通过插件系统,你可以: 自动化重复任务 增强开发安全性 集成团队工具 提升开发效率 参考资源: Claude Code 官方文档 ritmex-marketplace 示例 Plugin 参考文档 Hook 参考文档 开始创建你的第一个插件,让 Claude Code 更加强大!

2025/12/14
articleCard.readMore

如何在手机上优雅地 Vibe Coding

在手机上写代码的核心思路是: 计算在远程,手机只负责输入与查看结果。 方案一:在 VPS 上运行 Codex / Claude Code 等 CLI 然后手机用 Termius(或任意 iOS SSH App)连接 流程非常简单: 在 VPS 上安装 Node(18+)与 Coding CLI: curl -fsSL https://deb.nodesource.com/setup_20.x | sudo -E bash - sudo apt install -y nodejs 安装 Codex 或其他 CLI: npm install -g @openai/codex 在 VPS 上运行 CLI: codex 手机端用 Termius 等 SSH App 登录 VPS。 进入终端后就能直接使用 CLI,在手机上写代码、跑 agent。 特点: 环境永远在线 手机就是纯终端 随时随地 vibe coding 方案二:使用 Happy,把家里电脑的 Coding CLI 映射到手机 (官方 Quick Start 工作方式) Happy 的作用是: 把你家里电脑正在运行的 coding CLI,安全地连接到你的手机上。 不需要公网 IP,也不需要 SSH。 流程: 在家里电脑安装 Node(18+)与 Happy: npm install -g happy-coder 在电脑执行认证: happy --auth 电脑会显示一个二维码 / 代码。 打开手机上的 Happy(App 或 Web)扫描绑定。 绑定后,你就能: 在手机上访问电脑的 coding CLI 操作完全在手机界面完成 电脑执行、手机查看结果 特点: 复用家里电脑的性能与环境 手机端操作舒服 无需 SSH、无需对外暴露电脑 总结 手机优雅 vibe coding 的最简单实践就是: 要稳定、常在线 → VPS + SSH 运行 Codex 等 CLI 要高性能、用自己电脑 → Happy 远程连接本地 CLI 两种方式都足够轻量,也都能让手机实现完整 coding 体验。

2025/12/10
articleCard.readMore

买房时,我们到底在买什么?——中国住宅真实寿命研究报告

过去三十年,房地产是中国家庭资产配置的绝对核心。在长期单边上涨的市场环境下,房产被视为唯一的低风险高收益资产,吸纳了居民部门绝大多数的储蓄与未来现金流。 随着宏观经济进入调整期,资产价格预期的逆转迫使市场参与者重新评估其持有成本与潜在风险。当剥离了高增长时代的金融溢价后,一个长期被忽视的结构性风险暴露无遗: 购房者通过背负长达 30 年的刚性债务,试图锁定 70 年的土地使用权。然而,作为权益载体的钢筋混凝土建筑,其统计学意义上的物理寿命,往往无法覆盖完整的产权周期,甚至难以跑赢按揭贷款的偿付周期。这种债务久期与资产寿命的倒挂,构成了普通家庭资产负债表上最大的隐患。 1. 核心矛盾:设计标准 vs. 统计现实 关于房屋寿命,存在两个截然不同的概念: 设计使用年限(理论值):指在正常设计、施工、使用和维护下,房屋结构能满足安全使用的年限。 根据《建筑结构可靠度设计统一标准》(GB 50068-2001)和《民用建筑设计通则》(JGJ 37-1987),普通居住房屋的结构设计使用年限为 50年。 重要建筑(如高层地标)可达 100年。 实际服役寿命(统计值):指房屋从建成到被拆除的实际时间。 根据剑桥大学 Zhou 等人 2019 年发表于《Sustainability》的研究,通过对 1978-2017 年中国城市住宅存量的生存分析,得出中国城市住宅建筑的平均寿命约为 34.1年。 这一数据验证了住建部原副部长仇保兴在 2010 年提出的观点:“我国建筑的平均寿命只能维持 25-30年。” 2. 寿命折损原因分析 中国住宅“短命”并非单一结构质量问题,而是复合因素的结果: 非物理性折损(拆迁与更新):这是导致平均寿命偏低的主因。在城市化快速推进阶段,许多房屋结构尚未老化,但因土地价值重估、城市规划变更或容积率调整而被提前拆除。 建造质量的历史包袱:上世纪 80-90 年代建造的早期商品房或房改房,受限于当时的建材标准(如预制板结构)和施工监管,耐久性确实不足,导致目前面临集中淘汰。 维护体系缺失:相比于建设阶段的巨额投入,国内住宅在交付后的维护投入长期不足。缺乏系统的修缮导致建筑老化速度加快,“年久失修”成为拆除的合理化理由。 3. 一线城市的特殊性:上海与北广深 对于一线城市(北上广深),情况较全国平均水平略有不同。 质量更优,寿命略长:一线城市执行更严格的建筑规范和监管。2024 年关于上海民用建筑全生命周期碳排放的研究指出,上海民用建筑的平均寿命约为 40年。这高于全国 34.1 年的平均水平。 更新压力依然存在:尽管建筑质量较好,但一线城市土地稀缺,旧城改造和城市更新的动力更强。许多位于核心地段的低密度老旧小区(如 6 层砖混楼),往往因无法匹配当前的土地经济价值而被拆除重建。 对于一线城市购房者,30-40年 是一个基于历史数据的合理预期区间。特别是 2000 年之前建造的住宅,面临着更高的物理老化风险或拆迁不确定性。 4. 国际横向对比 将视野扩大到全球,中国住宅的寿命处于什么水平? 国家/地区 住宅平均寿命 (估算/统计) 主要特征 中国 25 - 35 年 受城市更新和早期质量影响大,实际寿命远低于设计寿命。 日本 25 - 35 年 尽管建筑技术先进,但因资产折旧制度和对新房的偏好,市场倾向于“拆旧建新”,经济寿命短。 美国 61 - 74 年 存量房市场成熟,木结构房屋维护体系完善。 英国 75 - 132 年 极端案例。大量维多利亚时期砖石建筑仍在使用,社会习惯于修缮而非拆除。 西欧 70 - 100 年 普遍拥有较长的建筑服役周期。 数据来源:Sustainability (MDPI), ResearchGate, China Economic Review, 英国 BS 7543 标准。 5. 结语:最大的赌场往往不需要门票 在二级市场,无论是股票还是加密货币,成熟的投资者都会反复告诫新人一条铁律:远离合约,拒绝高杠杆。因为在波动的市场中,加杠杆等同于将命运交付给概率,稍有不慎便是爆仓归零。 然而,极具讽刺意味的是,在面对“买房”这一人生最大宗交易时,绝大多数以“稳健”自居的普通家庭,却毫不犹豫地选择了拉满杠杆、押上全部身家,进行一次长达 30 年的单边做多。 这不仅是一次满仓梭哈,更是一场针对劣质资产的豪赌。我们用透支未来 30 年现金流的代价,去锁定一个统计寿命可能仅有 34 年、且并不具备神圣不可侵犯之私有产权属性的耗材。当按揭贷款的周期几乎等同于建筑物本身的物理生命周期时,这在金融逻辑上已经构成了一种极其危险的“久期错配”。 在这个局中,人口老龄化是灰犀牛,建筑短命是黑天鹅,而产权的不确定性则是始终悬在头顶的达摩克利斯之剑。 当下越来越多的年轻人选择不婚、不育、不买房,被主流舆论诟病为“躺平”或“缺乏责任感”。但若从投资风控的角度审视,这或许是新生代作为市场参与者,在直觉上察觉到了赔率的失衡——当一张期货合约的底层资产在不断折旧,且交割规则由庄家单方面解释时,拒绝开仓,才是唯一的理性避险。

2025/12/10
articleCard.readMore

在 512MB 微型 VPS 上创建虚拟内存并安装 Codex

在 512MB 甚至 256MB 这种微型 VPS 上跑现代工具(比如 bun add、npm install、Codex CLI)时,很容易遭遇内核 OOM(Out of Memory)直接把进程干掉: /usr/bin/env: ‘node’: No such file or directory Out of memory: Killed process ... 此类问题一般由两点引起: 系统没有 Node.js 没有启用 swap,内存耗尽即被 OOM 干掉 以下内容提供清晰可靠的处理流程: (1)释放磁盘空间 →(2)创建并启用 1GB swap →(3)安装 Node.js 20(NodeSource)→(4)安装 Codex CLI 最后附带完整一键脚本。 1. 查看当前内存与 swap 状态 free -h swapon --show 典型输出(Swap 为 0B): Swap: 0B 0B 0B 必须先启用 swap 才能稳定运行安装工具。 2. 释放磁盘空间(若 / 已满) 检查磁盘: df -h 若使用率100%,需要先清理: sudo truncate -s 0 /var/log/sing-box/access.log 2>/dev/null || true sudo truncate -s 0 /var/log/btmp.1 2>/dev/null || true sudo apt-get clean 再次确认: df -h 3. 创建并启用 1GB swapfile 删除旧 swapfile(如果有) sudo swapoff /swapfile 2>/dev/null || true sudo rm -f /swapfile 2>/dev/null || true 创建新 swapfile sudo fallocate -l 1G /swapfile sudo chmod 600 /swapfile sudo mkswap /swapfile sudo swapon /swapfile 检查 swap 是否生效 swapon --show free -h 应看到类似: Swap: /swapfile file 1G 0B 1G 4. 开机自动挂载 swap echo '/swapfile none swap sw 0 0' | sudo tee -a /etc/fstab 5. 安装 Node.js 20(NodeSource 官方源) Codex CLI 基于 Node.js,因此必须先安装 Node.js。 使用 NodeSource 可获得最新稳定版本。 curl -fsSL https://deb.nodesource.com/setup_20.x | sudo -E bash - sudo apt install -y nodejs 确认版本: node -v 6. 安装 Codex CLI sudo npm install -g @openai/codex 确认安装成功: which codex codex --help 若能正常输出帮助信息,则安装完成。 一键脚本:创建 swap + 安装 Node.js20 + 安装 Codex 保存为 setup_codex.sh: #!/usr/bin/env bash set -e SWAP_SIZE="1G" echo ">>> 清理日志与 APT 缓存" sudo truncate -s 0 /var/log/sing-box/access.log 2>/dev/null || true sudo truncate -s 0 /var/log/btmp.1 2>/dev/null || true sudo apt-get clean || true echo ">>> 删除旧 swapfile(如有)" sudo swapoff /swapfile 2>/dev/null || true sudo rm -f /swapfile 2>/dev/null || true echo ">>> 创建新的 swapfile (${SWAP_SIZE})" sudo fallocate -l "${SWAP_SIZE}" /swapfile sudo chmod 600 /swapfile sudo mkswap /swapfile sudo swapon /swapfile echo ">>> 写入 /etc/fstab(如果缺失)" FSTAB_LINE="/swapfile none swap sw 0 0" if ! grep -q "^/swapfile " /etc/fstab 2>/dev/null; then echo "${FSTAB_LINE}" | sudo tee -a /etc/fstab >/dev/null fi echo ">>> 安装 Node.js 20(NodeSource)" curl -fsSL https://deb.nodesource.com/setup_20.x | sudo -E bash - sudo apt install -y nodejs echo ">>> Node 版本:" node -v echo ">>> 安装 Codex CLI" sudo npm install -g @openai/codex echo ">>> Codex CLI 已安装" which codex || true codex --help || true echo ">>> 完成" free -h swapon --show 运行: chmod +x setup_codex.sh ./setup_codex.sh 微型 VPS 上运行 Codex CLI 至此即可稳定运行,不再遇到 OOM Killed 或 node 不存在的问题。 如需我为你的服务器环境进一步优化配置,也可继续发我 df -h、free -h、top 等输出。

2025/12/10
articleCard.readMore

设计灵感网站推荐合集

在进行网站设计、界面 UI/UX 创作或品牌营销页开发时,拥有一个优质的灵感库至关重要。下面我整理了一批极具参考价值的设计展示网站,涵盖一页式 (One-Page) 设计、Landing Page 范例、动画与微交互动效、作品集、创意图库等多个维度。无论你是「小恐龙 KOL tweet 模板」「社区互动页」「区块链/AI 项目官网」等场景,都能从中找到有助于提炼风格、调色板、布局结构或动画节奏的参考。 1. siteInspire 这是一个专门展示优质网页设计的网站,其定位是「展示网络上最好的设计 + 才能」。:contentReference[oaicite:0]{index=0} 推荐理由: 涵盖了视觉、界面、交互佳作,适合做整体版式、配色与排版灵感采集。 策展质量高,适合快速 « 浏览 + 收藏 »。 使用建议:在构思品牌主页或大型项目官网(如你在 crypto/AI 生态中的各类主题页面)时,可先浏览 siteInspire ,锁定主视觉风格,再延伸开发。 2. Awwwards 这是一个全球知名的网页设计奖项平台,聚焦展示开发者、设计师、网页机构的高水准作品。:contentReference[oaicite:1]{index=1} 推荐理由: 包含「Site of the Day」「Nominees」「Winners」等分类,可看到当下最新最前沿的网页互动、动画技术、案例趋势。 拥有按技术、类别筛选(如 React 、WebGL 、3D 、Scroll 等)功能。 使用建议:如果你想让「小恐龙 & 蟹王」那种角色动画在网页中有炫酷交互,或想做一个区块链项目页带微交互、3D 效果,这里是寻找技术灵感的极佳来源。 3. CSS Design Awards 另一个高质量的网站奖项平台,强调 UI、UX 与创新三个维度。:contentReference[oaicite:2]{index=2} 推荐理由: 每个获奖作品都会标注 UI 、UX 、Innovation 评分,便于理解为何被评为佳作。 可看到许多细节设计(排版、色彩、微动效)值得借鉴。 使用建议:适用于你在制作 newsletter、Landing Page、社群宣传页 (如 Wind Runner SBT、YieldBasis allocation letter) 时,用于参考「优秀互动+体验」的结构。 4. One Page Love 专注于单页网站(One-Page)设计的灵感库。:contentReference[oaicite:3]{index=3} 推荐理由: 集合了大量单页网站案例、模板与资源,非常适合快速部署或构思一页式页面。 模板、资源链接丰富,可作为启动项目参考。 使用建议:如果你准备做一个「小恐龙 快报 #1」那种一页式宣传页,或者 crypto 空投活动页面、SBT 活动页面,这里可以先选一个布局,再调整品牌角色(小恐龙/蟹王等)、色彩、图像场景。 5. Landing.love (你提供的 Landing.love 链接)这个站点专注于 Landing Page 设计灵感。 推荐理由: 虽不像其他奖项平台那样广为熟知,但专注在 Landing Page 范畴,可直接找到转化型页面结构的参考。 使用建议:当你需要一个「注册/领取/参与」型页面时,此站可帮助你快速选定 Hero 区、 CTA 按钮位置、视觉聚焦等结构方案。 6. Landingfolio 专门为 Landing Page 提供灵感、模板与组件库。:contentReference[oaicite:4]{index=4} 推荐理由: 不仅有案例,还有可复用的组件(Tailwind、Webflow、Figma)和模板。 分类细致(如 SaaS、产品、AI、加密、企业等)且资源丰富。 使用建议:适合当你做「Kite AI Wind Runner SBT 宣页」或「Sentient Library 活动页」等具备 CTA 、注册流程、限时优惠结构的页面时使用。你甚至可以直接借用组件+模板,加快开发流程。 7. Wall of Portfolios 聚焦作品集类网页展示的灵感集合。 推荐理由: 当你需要做个人/团队 portfolio 页(例如你自己做 Web3 工具、AI 代理系统的展示页)时,这是一个不错的参考库。 使用建议:建议浏览那些由设计师、创意工作室打造的「作品展示页」结构,借鉴 项目模块布局、案例 Thumbnail 布局、动画切换方式,再结合你品牌吉祥物“小恐龙”等角色元素。 8. UI UX Showcase 专注于 UI/UX 与设计资源展示的站点。:contentReference[oaicite:5]{index=5} 推荐理由: 除了网页设计,还有设计资源、AI 工具推荐,非常适合追求 UX 细节与工具效率的你。 使用建议:你可以用它来找到微动效、界面组件、流程设计灵感。当你做「小恐龙 & Monkey 驾驶 Zama Car」那种场景动画/界面演示页时,借鉴 UI /UX 细节会更加出彩。 9. Httpster 一个手工精选、不追大奖但追设计态度的网页设计展示网。:contentReference[oaicite:6]{index=6} 推荐理由: 风格偏向极简、排版大胆、实验性强,很适合从中挖掘另类布局或打破常规的设计思路。 使用建议:当你想让页面更具特色、更有“创意视觉冲击”时(比如 “Sentient Library” 场景页、或 “Cysic Mining Site” 互动页),在 Httpster 找灵感会很合适。 10. Designspiration 一个广泛的视觉灵感平台,涵盖色彩、图像、排版、插画等。 推荐理由: 虽不专门针对网页,但在找色彩组合、插画风格、品牌配色 palette 时非常有用。 使用建议:你可将其用于“小恐龙 + 蟹王 + 熊猫 + 小猪”角色画面中的配色参考,或寻找背景插画风格、叙事图像组合,再在网页中加以延伸。 11. Abduzeedo 一个创意设计博客与视觉灵感分享平台。 推荐理由: 包含设计师访谈、教程、灵感汇总。适合你在品牌视觉、角色插画、小恐龙场景扩展中寻找更丰富的来源。 使用建议:当你做“御花园 Portaltobitcoin 茶话会”那种叙事场景时,可借助 Abduzeedo 查找插画风格、排版摆设、空间构图等灵感。 12. GSAP Showcase 由 GSAP(GreenSock Animation Platform)官方维护的动画网页精选合集。:contentReference[oaicite:8]{index=8} 推荐理由: 专注于动效、微交互、滚动触发、SVG 动画等高级交互形式。 若你网页中有「小恐龙 grid 交易在迪拜」「小恐龙 & 猴子 驾驶 Zama Car」这样的动态叙事场景,这类示例极具参考价值。 使用建议:建议浏览其 Showcase 中发现哪种动画触发方式(如 ScrollTrigger、MorphSVG、Inertia)适合你的场景,再在项目中复用或改造。 13. Behance 由 Behance 提供的全球创意作品集平台。 推荐理由: 设计师、插画师、动效师、网页开发者大量作品集中地,适合探索「概念页」「完整项目展示」的视觉叙事方式。 使用建议:你可以搜索关键词如 “web design crypto”, “landing page illustration”, “UI/UX animation”,看看别人如何将角色、叙事、品牌融合到网页设计中,从中提炼灵感再落地至你的 Web3/AI 生态页面。 14. Dribbble 由 Dribbble 提供的设计师作品分享平台。 推荐理由: 微交互、界面细节、动效 Preview 图常见;适合快速捕捉「一个按钮 hover 动画」「One-Page 滑动效果」这类设计元素。 使用建议:当你在做页面细节(如 “小恐龙 & 猴子 驾驶 Zama Car”的按钮/切换/视觉反馈)时,Dribbble 是查找 UI 元素动效的绝佳场所,可供快速 slice 与复用。 📌 总结 如果你需要 整体版式+版面灵感:推荐 siteInspire、Httpster、Designspiration。 想看 获奖/前沿交互效果:推荐 Awwwards、CSS Design Awards、GSAP Showcase。 需要 一页式或 Landing Page 结构参考:推荐 One Page Love、Landing.love、Landingfolio。 做 作品集/品牌展示页:推荐 Wall of Portfolios、Behance、Dribbble。 想丰富 插画/视觉风格/配色:推荐 Abduzeedo、Designspiration。 想搜寻 UI/UX 组件/动效资源:推荐 UI UX Showcase、Dribbble。 在你下一次打造「小恐龙 KOL tweet 模板」「社区互动页」「AI 代理支付系统的Landing Page」的时候,不妨按照以下流程使用这些资源: 先从整体风格库(如 siteInspire、Httpster)中选出一个视觉方向。 再去 Landing/One-Page 站点(如 Landingfolio、One Page Love)锁定结构布局。 从交互/动画库(如 GSAP Showcase、Awwwards)选取可复用的动效方案。 最后去插画/视觉/组件站点(如 Designspiration、UI UX Showcase)提取角色、配色、按钮、组件样式。 汇总后结合你品牌中“小恐龙、小猪、蟹王、熊猫”等角色与 ARB/Zama/Sentient/Billions Logo 元素,融入场景叙事,再做 Tailwind CSS/React/Vite 或 Webflow 落地。 希望这份集合对你接下来的网页设计与品牌传播创作有所帮助!如果你想我帮你从其中任意一个站点摘出 10 个精选案例(比如「区块链项目专用Landing Page」)并生成 Figma 链接或 Tailwind 组件,也可以告诉我,我可以继续帮你整理。

2025/11/21
articleCard.readMore

灵感菇——ChromeAI增强插件

链接直达:灵感菇AI助手 更新Chrome到最新版本 Chrome浏览器地址栏输入 chrome://flags/#prompt-api-for-gemini-nano 修改为 Enabled 前往Chrome应用商店 https://chromewebstore.google.com/detail/mjbnaihbmfffiboanaecmeipafliekkn 下载安装后在右上角插件设置固定灵感菇插件 点击打开插件设置页面,触发Chrome内置AI模型加载 加载完毕后刷新 X 等网站即可看到AI增强功能

2025/11/1
articleCard.readMore

使用 Warp 拯救 VPS 解锁 ChatGPT/Gemini/Netflix/Google验证码

用了很久的 VPS 突然打不开 Gemini 了,虽然是日本 IP 但是显示服务尚未在当前地区开放。 真实物理IP/静态住宅IP是比较贵的,那么有没有一种办法可以解除这些限制呢? 今天学习到了可以使用 Cloudflare 提供的免费 Warp 服务,为 VPS 服务器本身添加代理网络出口,达到解锁目的。 具体使用到的是warp-yg一键安装脚本。 bash <(curl -Ls https://raw.githubusercontent.com/yonggekkk/warp-yg/main/CFwarp.sh) 根据命令行的提示操作即可。

2025/9/5
articleCard.readMore

在末法时代里爬行

2002年,《波士顿环球报》揭露波士顿1500名神父中,有249名涉嫌性侵儿童。其中恶名昭著的吉欧根神父,面临130项性侵指控。 该调查过程于2015年被改编为电影《聚焦》(Spotlight)。 同年7月26日,中国互联网出现署名“释正义”的举报帖《少林寺方丈释永信这只大老虎,谁来监督》,指控释永信拥有双重户籍、强奸尼僧释延果、包养情妇,并与哈尔滨女子关丽丽、尼僧释延洁各育有一名私生女,并提供了相关证据。 2015年11月,河南调查组公布初步结果:释永信无私生子女,方丈资格“程序合法合规”;其余被举报问题仍在依法调查中。 释永信(原名刘应成),1965年9月6日生,八字乙巳 甲申 癸亥。2025年恰逢其转入戊寅大运,命理上讲,叫做「伤官见官」,主诉讼牢狱之灾。 2025年7月27日,少林寺管理处官方通报:释永信涉嫌刑事犯罪,挪用侵占项目资金及寺院资产;严重违反佛教戒律,长期与多名女性保持不正当关系并育有私生子。 7月28日,中国佛教协会公告,同意注销释永信戒牒。 佛教典籍载:佛法流传世间共一万二千年,分正法一千年、像法一千年、末法一万年。 佛陀涅槃前三月,于《法灭尽经》中预言末世景象: “吾涅槃后,法欲灭时,五逆浊世,魔道兴盛。 佛陀早已预言将有魔道假扮僧人,败坏佛法,行龌龊之事。 同时预言:末法时代,纵有真修行者舍己为人,亦会遭假僧诽谤驱逐。 以佛灭度年(公元前543年)为基准,2025年已入末法时代69年。 每只蚂蚁 都有眼睛鼻子 它美不美丽 偏差有没有一毫厘 有何关系 每一个人 伤心了就哭泣 饿了就要吃 相差大不过天地 有何刺激 有太多太多魔力 太少道理 太多太多游戏 只是为了好奇 一个一个偶像 都不外如此 沉迷过的偶像 一个个消失 谁曾伤天害理 谁又是上帝 我们在等待 什么奇迹 最后剩下自己 舍不得挑剔 最后对着自己 也不大看得起 谁给我全世界 我都会怀疑 心花怒放 却开到荼蘼

2025/8/25
articleCard.readMore

Hysteria2 拯救 AWS lightsail 极速科学上网

以前我使用的上网冲浪方案都是 v2ray Websocket(WS)+TLS+CDN 的方式,这种方式的好处是安全性高,保护服务器不被 ban 但前几天日本和新加坡的线路直接卡成💩 多年没有研究上网冲浪姿势的我,只好重新拿起课本 经过一番学习之后,我了解到了宝藏协议 Hysteria2 Hysteria2 底层使用的是 UDP 协议,即使 TCP ping 服务器有 200-300ms 的延迟 使用 UDP 也能将延迟干到 50ms 左右 网速更是可以快到运营商想来ban你的UDP流量 Youtube 8K 视频也能做到秒开不卡顿 使用 AWS Lightsail 的好处是 我可以很放心地把一些需要长期保存和稳定运行的服务都跑在上面 也可以安心地存放一些 API Key 和密钥之类的 网上大把的野鸡运营商的服务器,我是什么都不敢保存的 安装教程 Hysteria2 官网 贴心地提供了一键安装脚本 # 安装 bash <(curl -fsSL https://get.hy2.sh/) # 删除 bash <(curl -fsSL https://get.hy2.sh/) --remove 编辑配置 vim /etc/hysteria/config.yaml 配置内容 listen: :443 # 服务端口,可以换成别的 acme: domains: - hysteria.example.com # 你的域名 email: admin@example.com # 你的邮箱 type: dns dns: name: cloudflare config: cloudflare_api_token: vRDNxxxxxxxxxxxxxxx # Cloudflare API Key auth: type: password password: 123456789 # 密码 masquerade: type: proxy proxy: url: https://bing.com/ rewriteHost: true 启动服务 systemctl enable --now hysteria-server.service # 查看状态 systemctl status hysteria-server.service # 查看日志 journalctl --no-pager -e -u hysteria-server.service 到这一步就大功告成了! 当然 Hysteria 也不是没有缺点,UDP的速度快是快,但很容易丢包和断流,不过对于90%使用场景是看网页刷视频的朋友,极速的体验还是非常舒服的。

2025/6/12
articleCard.readMore