事件起因
最近想用jetson nano做yolo目标检测,但是在我给jetson安装Pycharm后,发现一直无法使用Terminal,pycharm底部报错:
Cannot open Local Terminal
java.util.concurrent.ExecutionException: Failed to start [/bin/bash, --rcfile, /home/nano/pycharm-community-2019.1.4/plugins/terminal/jediterm-bash.in, -i] in /home/nano/PycharmProjects/untitled
See your idea.log (Help | Show Log in Finder) for the details.
起初不知道是什么原因导致的,试了很多博主的方法都不行,包括在settings里改terminal路径为cmd、重启n遍、重装别的pycharm版本,折腾了两天,在这里总结一下自己的历程,整合一个方法以防下次自己忘记。
报错原因
是因为Jetson nano为aarch64架构,而Pycharm中有一个pty4j的库默认是支持x86_64位系统的,导致jetson nano不兼容,无法加载本机pty执行器程序库,所以才导致了无法打开pycharm终端。原因是我自己琢磨的,可能有不对的地方,但便于我理解记忆。
确定原因是否相同
我们可以先确定是不是上面这个原因导致的问题,通过查看报错日志idea.log的方法来判断。
打开idea.log我知道的方法是
find ~/ -name idea.log # 先找到idea.log位置
cd /home/用户名/.PycharmCE2019.1/system/log # cd到你搜索到的目录下
gedit idea.log # 打开pycharm的日志
执行find命令后,会显示几行:find:’/***/***/***/’:权限不够
仔细看 其中一行就是报错日志的位置‘/home/用户名/.PycharmCE2019.1/system/log/idea.log’
用gedit命令打开log,会看到是几千行乱七八糟的日志信息,上面有系统在每一时刻做了什么事情。
为了方便观看,直接CTRL A,全选删除保存退出,留着这个终端不要退出。
打开pycharm,等2分钟,再关闭pycharm 然后打开刚才的终端,打开日志,CTRL F搜索关键字 Caused by或Error。若出现一下报错证明我的方法可行。
ERROR - com.pty4j.unix.PtyHelpers - Cannot load native pty executor library
Caused by: java.lang.UnsatisfiedLinkError: Unable to load library '/home/pycharm-community-2019.1/lib/pty4j-native/linux/x86/libpty.so':
解决方法
-
git clone https://github.com/JetBrains/pty4j
或 下载ZIP包 传到jetson nano中
链接:https://pan.baidu.com/s/1yDQjPdTaxogh6d3Slh_3FQ?pwd=ydcg
提取码:ydcg -
将pty4j库放在喜欢的目录,在pty4j/native目录下打开终端
cd pty4j/native
gcc -fPIC -c *.c
gcc -shared -o libpty.so *.o
cp libpty.so pycharm安装目录/lib/pty4j-native/linux/x86_64/
#这里可能有人的报错日志Caused by那一行上读取library的路径是x86,随机应变即可
- 重新打开pycharm即可
参考
https://github.com/JetBrains/pty4j/issues/82
https://github.com/JetBrains/pty4j
https://youtrack.jetbrains.com/issue/IDEA-217416
非常感谢!!