首页
/ 在Ubuntu系统中实现code-server 24/7持续运行方案

在Ubuntu系统中实现code-server 24/7持续运行方案

2025-04-29 23:52:06作者:毕习沙Eudora

背景介绍

code-server作为一款优秀的远程开发工具,允许用户通过浏览器访问VS Code环境。许多开发者在Ubuntu系统上部署code-server时,常常遇到一个典型问题:当关闭终端窗口后,服务就会自动终止。这种情况对于需要长期稳定运行的开发环境来说显然是不可接受的。

问题本质分析

在Linux系统中,当一个进程由终端启动时,默认情况下它会与该终端会话绑定。当终端关闭时,系统会发送SIGHUP信号给所有相关进程,导致这些进程被终止。这是Linux系统的默认行为,并非code-server特有的问题。

解决方案

1. 使用tmux工具

tmux是一个终端复用工具,可以创建持久化的会话,即使关闭终端窗口也不会影响其中运行的进程。

具体操作步骤:

  1. 首先安装tmux:sudo apt install tmux
  2. 创建新会话:tmux new -s code-server
  3. 在新会话中启动code-server:code-server
  4. 按下Ctrl+B,然后按D键分离会话
  5. 此时可以安全关闭终端,code-server会继续运行

如需重新连接会话查看状态: tmux attach -t code-server

2. 使用nohup命令

nohup是一个简单的解决方案,可以忽略SIGHUP信号。

使用方法: nohup code-server &

此命令会将输出重定向到nohup.out文件,服务会在后台持续运行。

3. 创建系统服务

对于生产环境,建议将code-server注册为系统服务,实现开机自启和自动管理。

创建服务文件: sudo nano /etc/systemd/system/code-server.service

添加以下内容:

[Unit]
Description=code-server
After=network.target

[Service]
User=your_username
ExecStart=/usr/bin/code-server
Restart=always

[Install]
WantedBy=multi-user.target

然后执行:

sudo systemctl daemon-reload
sudo systemctl enable code-server
sudo systemctl start code-server

方案对比

方案 复杂度 适合场景 稳定性 管理便利性
tmux 中等 临时使用 较好 一般
nohup 简单 快速测试 一般 较差
系统服务 较高 生产环境 优秀 优秀

最佳实践建议

对于个人开发者,建议从tmux方案开始尝试,它提供了良好的平衡性。对于团队或生产环境,强烈推荐使用系统服务方案,它能提供最稳定的运行环境和便捷的管理方式。

无论选择哪种方案,都建议定期检查日志,确保服务运行正常。对于系统服务方案,可以使用journalctl -u code-server -f命令实时查看日志。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
224
2.26 K
flutter_flutterflutter_flutter
暂无简介
Dart
526
116
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
JavaScript
210
286
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
frameworksframeworks
openvela 操作系统专为 AIoT 领域量身定制。服务框架:主要包含蓝牙、电话、图形、多媒体、应用框架、安全、系统服务框架。
CMake
795
12
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
984
582
pytorchpytorch
Ascend Extension for PyTorch
Python
67
97
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
567
94
GLM-4.6GLM-4.6
GLM-4.6在GLM-4.5基础上全面升级:200K超长上下文窗口支持复杂任务,代码性能大幅提升,前端页面生成更优。推理能力增强且支持工具调用,智能体表现更出色,写作风格更贴合人类偏好。八项公开基准测试显示其全面超越GLM-4.5,比肩DeepSeek-V3.1-Terminus等国内外领先模型。【此简介由AI生成】
Jinja
42
0