96 lines
3.6 KiB
JSON
96 lines
3.6 KiB
JSON
{
|
||
"name": "Sandbox Dev Container",
|
||
"forwardPorts": [4730, 4731], // vscode://settings/remote.localPortHost -> 默认只监听 localhost
|
||
"portsAttributes": {
|
||
"4730": { "label": "开发服务器端口", "onAutoForward": "notify" },
|
||
"4731": { "label": "预览服务器端口", "onAutoForward": "notify" }
|
||
},
|
||
"build": {
|
||
"dockerfile": "Dockerfile",
|
||
"args": {
|
||
"TZ": "${localEnv:TZ:Asia/Shanghai}"
|
||
}
|
||
},
|
||
"runArgs": [
|
||
// -----
|
||
// "--network=host",
|
||
// "--add-host=myservice.local:127.0.0.1",
|
||
// -----
|
||
// "--env-file",
|
||
// ".devcontainer/.env",
|
||
// -----
|
||
"--cap-add=NET_ADMIN",
|
||
"--cap-add=NET_RAW"
|
||
],
|
||
"customizations": {
|
||
"vscode": {
|
||
"extensions": [
|
||
// AI
|
||
"anthropic.claude-code",
|
||
"google.gemini-cli-vscode-ide-companion",
|
||
"kilocode.kilo-code",
|
||
"alibaba-cloud.tongyi-lingma",
|
||
|
||
// >>>>>
|
||
"vue.volar",
|
||
"lokalise.i18n-ally",
|
||
"eamodio.gitlens",
|
||
"vitest.explorer",
|
||
// <<<<<
|
||
|
||
// 代码质量 / 格式化 / Lint
|
||
"editorconfig.editorconfig",
|
||
"dbaeumer.vscode-eslint",
|
||
"stylelint.vscode-stylelint",
|
||
"oxc.oxc-vscode",
|
||
"esbenp.prettier-vscode"
|
||
],
|
||
"settings": {
|
||
"editor.formatOnSave": true,
|
||
"editor.defaultFormatter": "esbenp.prettier-vscode",
|
||
"editor.codeActionsOnSave": {
|
||
"source.fixAll.eslint": "explicit"
|
||
},
|
||
"terminal.integrated.defaultProfile.linux": "zsh",
|
||
"terminal.integrated.profiles.linux": {
|
||
"bash": { "path": "bash", "icon": "terminal-bash" },
|
||
"zsh": { "path": "zsh", "icon": "terminal-debian" }
|
||
},
|
||
|
||
// https://stackoverflow.com/questions/75708866/vscode-dev-container-fails-to-load-ms-vscode-js-debug-extension-correctly
|
||
// https://davidwesst.com/blog/missing-bootloader-in-vscode-devcontainer/
|
||
/**
|
||
* autoAttachFilter 存在问题:会在 NODE_OPTIONS 中注入 bootloader.js 的 --require 参数,
|
||
* 并错误地重复拼接 --max-old-space-size,形成类似:
|
||
* NODE_OPTIONS= --require /home/.../bootloader.js --max-old-space-size=4096--max-old-space-size=4096
|
||
* 导致启动时报错:
|
||
* Error: illegal value for flag --max-old-space-size=4096--max-old-space-size=4096 of type size_t
|
||
* 将其设置为 "disabled" 以规避该问题。
|
||
*/
|
||
"debug.javascript.autoAttachFilter": "disabled"
|
||
}
|
||
}
|
||
},
|
||
|
||
"containerEnv": {
|
||
// "CLAUDE_CONFIG_DIR": "/home/usr_vscode/.claude",
|
||
"ANTHROPIC_AUTH_TOKEN": "${localEnv:ANTHROPIC_AUTH_TOKEN}",
|
||
"ANTHROPIC_BASE_URL": "${localEnv:ANTHROPIC_BASE_URL}",
|
||
"GEMINI_API_KEY": "${localEnv:GEMINI_API_KEY}",
|
||
"GOOGLE_GEMINI_BASE_URL": "${localEnv:GOOGLE_GEMINI_BASE_URL}",
|
||
"NODE_OPTIONS": "--max-old-space-size=4096"
|
||
},
|
||
"remoteUser": "usr_vscode",
|
||
"mounts": [
|
||
// "source=dev-container-bashhistory-${devcontainerId},target=/commandhistory,type=volume"
|
||
"source=${localWorkspaceFolderBasename}-node_modules,target=${containerWorkspaceFolder}/node_modules,type=volume"
|
||
],
|
||
"postCreateCommand": "sudo chown usr_vscode node_modules", // 容器创建后执行 https://code.visualstudio.com/remote/advancedcontainers/improve-performance
|
||
"postStartCommand": "pnpm -v", // 每次容器启动时执行
|
||
// "postAttachCommand": "pnpm config get store-dir", // 连接到容器后执行
|
||
// "updateRemoteUserUID": true,
|
||
// "waitFor": "postStartCommand"
|
||
"workspaceMount": "source=${localWorkspaceFolder},target=/workspace,type=bind,consistency=delegated",
|
||
"workspaceFolder": "/workspace"
|
||
}
|