操作步骤
- 准备
- 编译并上传程序
- 配置CLion的cmake和GDB
- 调试
- 参考资料
- 其他
New! 2020.02更新之后的版本不再需要远程打开gdbserver !(有大佬知道原因的话求解答)
CLion 更新日志
准备
- CLion;
- 一个通过cmake编译的project;
- gdb & gdbserver(可选) :安装在远程的目标服务器上,安装最新版的gdb即可(/path/to/installation/bin中可以看到gcore 、gdb 、gdb-add-index、gdbserver四个文件);
编译并上传程序
- 如果你的程序在服务器上,通过scp等命令,将程序从服务器下载到本地;
- 如果在本地,那么需要上传一份程序到服务器上,按照以下步骤配置CLion:
a. Tools -> Deployment -> +, 选择适用的文件传输协议,给新的服务器命名,然后进入以下设置:
b. 在第一个connection的相关设置中填写host,port,User name;
c. Authentication:选择password,然后在下面输入密码就可以了;如果你配置了ssh的config文件的话,就可以直接使用“OpenSSH config and authentication agent”, clion会自动根据config文件进行配置。
d. 接下来设置Mapping中的内容(Connection 旁边):Mapping是映射的意思,也就是建立服务器端的路径和本地路径的对应关系,在Local path中填入存放当前程序的文件夹,在Deployment path中填入服务器中的某一指定位置。
e. 上传程序:Tools -> Deployment -> Upload to …, 然后选择刚才添加的服务器。完成以上步骤之后你就可以看到在之前填写的Deployment目录下有一份和本地一样的程序;如果你发现你的选项是灰色的,那么请随便点击或着打开一个文件,然后再回到Deployment -> Upload to …
配置CLion的cmake和GDB
- Preference -> Build, Execution, Deployment -> Toolchains
- 选择刚才添加的服务器,如果Credentials显示Disconnectted,点击后面的设置,然后根据提示输入相应的host、User name和password即可;
- cmake:通常会自己连接服务器上的默认cmake,如果需要更换新的版本在后面输入相应的路径即可。
- make, C Complier, C++ Complier 类似,如果需要指定则选择Custom,然后输入make, gcc, g++的位置即可;
- GDB:和cmake相同。不过有时默认的gdb版本比较旧,可以选择自己重新安装的新的GDB;
调试
- 首先,在服务器上编译上传的程序;
- (可能不再需要的步骤)然后在服务器上输入以下命令以打开gdbserver:
gdbserver :2345 /path/th/executale/file argument1 argument2 argument3
PS:2345是gdbserver的监听端口,紧接着的是刚才编译生成的可执行程序,后面的argument是指该可执行程序的参数。
输出以下结果表示已启动监听:
Process /path/to/executable/file created; pid = 2792
Listening on port 2345
如果输出:
Can't bind address: Address already in use.
Exiting
随便更换一个监听端口即可;
3. 如同在本地调试一样,在需要debug的位置添加断点;
4. 设置可执行程序的参数:Run -> Edit Configuration,选择需要调试的target和executable,在Program arguments中输入程序的参数即可;
- 选择需要调试的可执行程序(Debugger)(默认好像是刚才添加的服务器的名字,记得切换成需要调试的程序,踩过的坑),然后点击右边的调试按钮。
没有切换的话,会出现以下错误:
com.jetbrains.cidr.execution.debugger.backend.gdb.GDBDriver$GDBCommandException: Remote communication error. Target disconnected.: Connection reset by peer.
Debugger disconnected
连接成功的话可以看到程序开始build,然后自动开始运行:
参考资料
- 官网介绍:https://www.jetbrains.com/help/clion/remote-gdb-server.html
其他
在CLion中使用terminal:
Tools -> Start SSH session -> Edit Credentials