掘金 后端 ( ) • 2024-04-18 14:01

第一步 VsCode 连接ssh

  1. 下载安装VsCode(Visual Studio Code),首次安装会提示你安装Chinese(Simplified)中文简体,安装完后重新打开就是汉化界面了。
  2. 在左边侧边栏找到扩展选项,然后安装Remote Development插件,里面包含了Remote SSHWSLDev ContainersRemote - Tunnels四个插件。

    image.png

  3. 安装后你的左边侧边栏就会出现远程资源管理器了,然后切换到远程(隧道/SSH),鼠标移到下面的SSH,就会出现一个+号了,点击一下+号。

    image.png

  4. 提示需要输入ssh命令。输入示例:ssh [email protected] 即可。root是服务器用户名,xxx.xxx.xxx.xxx是远程ip地址。输入完后回车

    image.png

  5. 回到刚刚到界面,点击图片刷新一下,就可以看到你刚刚输入的ip地址了。右键这个ip,选择在当前窗口中连接即可。

    image.png

  6. 后面会让你输入密码,每次打开都要输入。可以参考一下附录ssh免密配置,强烈建议去配置一下,大概几分钟可以搞定,后续会方便很多。

第二步,启动容器服务

  1. 下面以trt2023复赛为例。在服务器终端,先clone一下你的代码,然后进入你的代码目录。
  2. 创建并后台启动docker容器:
docker run --gpus all \
  --name trt2023 \
  -d \
  --ipc=host \
  --ulimit memlock=-1 \
  --restart=always \
  --ulimit stack=67108864 \
  -v ${PWD}:/root/workspace/trt2023 \
  [镜像名称] sleep 8640000

第三步,VsCode连接容器

  1. VsCode侧边栏选择远程资源管理器,然后下拉框选择开发容器,点击一下刷新(如果没配置ssh免密,就需要输入一下密码)。
    <p class="img-center"><img alt="image.png" isbindedload="true" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/425be9d27cbc45a7ba93ed7d635e8082~tplv-k3u1fbpfcp-zoom-1.image" width="718" /></p>
    </li>
    <li>选中刚刚到容器,选择<code>在当前窗口中附加</code>即可。
    <p class="img-center"><img alt="image.png" isbindedload="true" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/ee5104ab4df34a4695dca942f70ff34a~tplv-k3u1fbpfcp-zoom-1.image" width="706" /></p>
    </li>
    <li>然后打开你刚刚映射的目录<code>/root/workspace/trt2023</code>即可。</li>
    <li>安装一下<code>Python</code>插件,即可开始享受愉快的编码调试过程了。</li>
    

其他

ssh免密登录配置
  1. 本机生成ssh key,一路回车即可。若本机已经生成过了,则可以忽略。
ssh-keygen
  1. 复制本机公钥。
  • for Linux/Mac
cat ~/.ssh/id_rsa.pub
  • for Windows。去文件管理器,一般在C:\user\xxxx\.ssh目录下,如果看不到.ssh目录,则可能需要打开隐藏文件显示。然后用记事本打开id_rsa.pub文件,copy里面的内容即可。
  1. 连接到远程服务器(注意是连服务器,不是连服务器的容器)。然后做以下配置。
  • 创建.ssh目录,如果目录已经存在则可以忽略。
mkdir ~/.ssh
  • 看看authorized_keys文件是否存在(不存在可以用touch ~/.ssh/authorized_keys命令手动创建一个),并且观察其权限是否ok。
ls -lh ~/.ssh/authorized_keys
  • 输出下面这个说明是ok的,-rw说明是root用户可读可写,组用户和宾客用户都不行。
-rw------- 1 root root
  • 如果你实在不确定是不是ok,暴力一下,直接重新给他授权即可。
chmod 600 ~/.ssh/authorized_keys
  1. 将你之前复制的公钥粘贴到刚刚到授权文件里面。可以用下面的命令一键完成。
echo "你的公钥内容xxxx" >> ~/.ssh/authorized_keys
  1. 到这一步基本是ok了,如果不ok,则需要检查一下ssh配置。
  • 编辑ssh配置
vim /etc/ssh/sshd_config
  • 修改前
#StrictModes yes
#AuthorizedKeysFile .ssh/authorized_keys
PermitRootLogin prohibit-password
  • 修改后
StrictModes no
AuthorizedKeysFile .ssh/authorized_keys
PermitRootLogin yes