VSCode 阅读 Linux 代码怎么才不卡顿?这样做才能快的飞起!

注:本文结合作者自身操作在转载的基础上略有改动,红色字体为补充部分

86e24b18f893d644553ed1dc92e985f3.png

Linux 内核代码用什么编辑器?

分享过怎么学习 Linux 内核代码的思路,当时顺便提了一点,奇伢是用 vscode 看内核代码。有同学对此提出了疑问:

  1. vscode 看 Linux 代码不卡吗?

  2. vscode 符号跳转怎么老有问题?

  3. windows 开发 Linux 项目好麻烦,总是要手动同步代码?

其实,上面提出的三点疑问,合理配置 vscode 是可以完美解决的。今天就以 Linux 内核源码为例,分享一下超大项目源码的源码开发阅读的姿势。

我们经常遇到两个问题:

  1. 本地电脑存在瓶颈,单机性能有限,毕竟资金紧缺?

  2. 一般电脑安装的都是 windows 或者 mac 图形支撑好的系统,而开发的项目又必须是 Linux 上编译运行?

如果本机直接用 vscode ,势必会遇到上面的问题。比如 Linux 代码量巨大,本机性能是 hold 不住,编辑器建立内存的索引非常庞大,既要吃内存又要吃 CPU 。对于编译,那就更麻烦了,涉及到手动的同步。

我们经常怎么解决它?

  1. 纵向优化电脑,给自己电脑加个内存条,换个 cpu ,这个思路是可以的,但是它永远存在性能瓶颈。这还真不是钱的问题;

  2. 对于平台依赖,以前的实践是 windows 下编辑,然后用 scp 或者其他同步工具,把代码同步到另外一台 Linux 下去编译,很麻烦;

怎么才能彻底解决它?

奇伢的最佳实践:vscode 远程开发,利用多机性能;

怎么做才能解决单机的瓶颈和平台依赖?

解决单机瓶颈的思路非常简单,那就是分布式、多机部署。

我的使用姿势是本机打开一个 vscode ,但是代码放在远程主机,远程主机是一台性能强劲的 Linux 服务器,速度杠杠的。

这样的好处就是把资源消耗的压力分摊到远程主机,本机的消耗非常少,再大的项目也非常稳定。

第二个好处就是平台的无缝切换,即使你使用的是 windows 机器,也能非常丝滑的进行 Linux 项目的开发,代码编辑,项目编译无感切换。

远程主机是一台 32 核 128 G SSD 盘 的服务器,跑个 Linux 源代码的解析那还不是绰绰有余。

有童鞋问,这服务器哪里来?

答:你不是在上班嘛。公司的。

并且这种开发方式能够让你的电脑不用再焦虑,把纵向优化的思路转变成横向的扩展之后,你的瓶颈将不复存在。你的本机只做一个界面即可。

效果展示:

7dce9000483bc1de95bac061dab528e5.png

怎么配置 vscode 远程开发?

讲了那么多,我们接下来看看怎么实践。怎么配置这个呢?下面以 Linux 源码为例,手把手教你配置。

准备 Linux 主机

这是我们的远程主机,性能怎么好怎么来。当然,如果只是为了跨平台,其实可以是虚拟机。

远程主机安装 global 工具

注意,是在远程主机上安装哦,为了更好,更快的解析我们的符号表。下面是 ubuntu 的命令

apt install global

注(作者经历):如果读者使用的是centos系统,则参考如下方式安装:

1、尝试使用yum install 方式安装global工具,失败,果断放弃

2、下载global源代码手动编译安装

 2.1 global工具下载地址:https://ftp.gnu.org/pub/gnu/global/global-6.6.tar.gz

 2.2  解压缩到指定目录:tar -zxvf /home/global-6.6.tar.gz -C ./

 2.3  安装编译global时所依赖的库: yum install *ncurses*

 2.4  cd到你解压后的global工具目录进行编译安装

./configure --with-sqlite3   # gtags可以使用Sqlite3作为数据库, 在编译时需要加这个参数
make -j4
make install

安装完global工具之后,确认两个二进制文件,global, gtags, 一般在 /usr/bin/ 目录下(如果不在这个目录下,可使用which命令再次确认存放目录)。有这两个文件,就说明 OK 。

Linux 源码下载

这个自行去 Github 或者其他镜像网站上下载即可。

Github 地址:https://github.com/torvalds/linux.git

镜像网站(作者使用的此方式,下载版本为3.10版本):https://mirrors.edge.kernel.org/pub/linux/kernel/v3.x/linux-3.10.tar.gz

下载之后,解压放到远程的目录即可。

vscode 安装 Remote-SSH 插件

现在有主机,有代码了,怎么才能让 vscode 具备连接远程主机的能力呢?

vscode 远程连接主机主要是依赖于微软提供的插件 Remote-SSH。

9e3551b4148b52731fc2f419e4eb2735.png

 安装完插件之后,vscode 就具备了连接远程主机的能力。在左下角有个符号 >< ,点击它就能选择连接哪个远程主机。连接上了之后,会重新开一个窗口,左下角也会显示。

注:连接命令:ssh root@192.168.100.101 -p 22

3dafd2675c6bc6d8872f5778679a5da9.png

连接成功之后手动导入远程主机源代码目录,点击打开文件夹输入远程源代码目录点击确定即可

 46b319ee7bf3a72ef90d85da4af954ed.png

这里顺便提一下,微软一共发布了三款远程连接的插件:

  1. Remote - Containers

  2. Remote - SSH

  3. Remote - WSL

名字上也很容易区分,就是支持连接容器,SSH主机,WSL子系统。

安装 C/C++ GNU Global 插件

好,现在万事俱备了。下一步就是把符号解析的事情准备好,你就能享受快速的源代码阅读体验了。

首先我们连接上远程主机,注意:这个时候会重新打开一个窗口,而不是在本地安装。

ed60fc3f3448b283c1c29bf1a048a8a8.png

当然,C/C++ 插件(C/C++ Themes)也最好安装一下。

划重点:一定要先连接上主机,然后再安装 GNU Global 插件哦。一定是在远程主机上安装。

vscode 配置 global 路径

vscode 的配置(ssh)里,输入以下配置:

在 vscode 的 settings.json 配置里,指定 global 的相关路径。

    "gnuGlobal.globalExecutable": "/usr/local/bin/global",
    "gnuGlobal.gtagsExecutable": "/usr/local/bin/gtags",
    // 指明生成的符号表存放在哪个位置
    "gnuGlobal.objDirPrefix": "/mnt/.global"

注意:"gnuGlobal.objDirPrefix" 的路径必须要手动创建好,如果不存在,会导致后续 Rebuild 的失败。

测试是否成功执行远程主机上的 Gtags

好啦,现在插件安装完成了。测试一下安装配置的是否正确。shift + command + P 把命令面板掉出来,执行 Global: Show GNU Global Version 命令,看是否能成功显示版本。在右下角显示版本号,那么就说明一切就绪:

global (GNU GLOBAL) 6.6.4

最后一击,生成符号表

shift + command + P 把命令面板调出来,执行 Global: Rebuild Gtags Database 命令。等待右下角的通知,如果显示:

Build tag files successfully

那么就说明符号表解析完成了。符号表生成成功会在 "gnuGlobal.objDirPrefix" 的路径里生成三个文件:


root@ubuntu20:/mnt/opensource/linux-3.10# ll -lh /mnt/.global/mnt/opensource/linux-3.10/
total 395M
drwxr-xr-x 2 root root 4.0K Feb 14 19:06 ./
drwxr-xr-x 3 root root 4.0K Feb 14 18:33 ../
-rw-r--r-- 1 root root 7.6M Feb 14 19:06 GPATH
-rw-r--r-- 1 root root 278M Feb 14 19:06 GRTAGS
-rw-r--r-- 1 root root 109M Feb 14 19:06 GTAGS

好了,上面的搞完,就可以愉快的使用 vscode 看源码了,速度非常快。

43770b292fa75fe548dca1e1eddf2173.png

好啦,现在你可以尽情享受 Linux 代码的阅读开发了,既能享受图形界面的便捷,又能无缝的进行 Linux 的开发。而且不用在受限于本机电脑的资源瓶颈,具有无限的扩展空间。

4bc6b4835449f078168f02e7689cfc2b.png

总结

52970beb404414d8a271de9490312e95.png

  1. 单机总是存在瓶颈,纵向优化它总有极限,并且价格不菲;

  2. 既要图形界面的便捷?又要无缝切换 Linux 开发模式?远程开发是个不错的体验;

  3. vscode 使用插件来实现远程开发,本机电脑作为一个界面,符号解析放在远程主机,真正做到横向扩展,理论上性能无上限

  4. Linux 源代码的解析放到远程主机,vscode 远程连接,源代码的阅读流畅丝滑,开发体验完美

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于VSCode前端代码卡顿的问题,可以尝试以下解决方法: 1. 关闭不必要的扩展:VSCode的扩展可能会消耗大量资源,尤其是对于较老或低配置的计算机。因此,可以尝试禁用或删除不必要的扩展,并仅保留对你工作流程有用的扩展。 2. 调整设置:在VSCode的设置中,可以尝试进行一些调整以提高性能。例如,可以将"editor.autoIndent"设置为false来禁用自动缩进功能,或将"editor.detectIndentation"设置为false来禁用自动检测缩进功能。 3. 使用更轻量级的主题:某些主题可能会消耗更多资源,导致卡顿。尝试使用较轻量级的主题,如默认的VSCode主题或其他简约主题,以提高性能。 4. 增加内存限制:VSCode默认的内存限制可能不足以处理大型项目。可以通过在VSCode的设置中增加"maxMemory"限制来提高内存限制,例如:" "javascript.updateImportsOnFileMove.enabled": false "。 5. 更新VSCode版本:确保你正在使用最新版本的VSCode,因为新版本通常包含性能改进和bug修复。 6. 关闭不必要的面板和标签:如果你有许多面板和标签打开并且不需要使用它们,可以将它们关闭,以减少资源的消耗。 7. 使用更高性能的计算机:如果你的计算机配置较低,升级硬件可能是提高性能的有效方法。考虑升级内存、处理器或存储设备等硬件组件,以提供更好的性能。 如果以上方法都无法解决问题,那可能是因为项目本身较大或复杂,超出了VSCode的处理能力。可以尝试使用其他更适合大型项目的IDE或编辑器。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值