bash
#拉取镜像
sudo docker pull osrf/ros:foxy-desktop
#需要在镜像中安装好环境:
apt update
apt-get install -y openssh-server
apt-get install -y vim
apt-get install -y tmux
#设置配置文件
vim /etc/ssh/sshd_config
#文件修改内容
Port 22
PermitRootLogin yes
PasswordAuthentication yes
#重启ssh服务
service ssh restart
#查看容器名称
docker ps
#映射容器端口22到服务器端口37
sudo docker run -d -p 37:22 --name my_ros2_ssh ros2_ssh tail -f /dev/null
#例子:
#sudo docker run -d -p 37:22 --name my_container_name image_name tail -f 空设备文件
#其中, 使用 tail -f /dev/null 命令作为容器的主进程,它会阻塞并保持容器运行状态。/dev/null 是一个空设备文件,tail -f 命令会持续追踪该文件,实际上不会有任何输出。
#设置服务器上端口防火墙
sudo ufw status #查看状态
sudo ufw allow 37/tcp #允许使用37端口号
#设置容器的用户名和密码
adduser <username>
#将 `<username>` 替换为您希望设置的用户名。
#系统会提示您设置密码和其他相关信息。请根据提示输入密码并完成用户创建过程
#进入容器my_ros2_ssh
sudo docker exec -it my_ros2_ssh /bin/bash
#运行以下命令将用户添加到 sudo 组(将 "freja" 替换为你的用户名):
usermod -aG sudo freja
#避免远程登录freja后无法使用sudo权限,这一行不一定有用。。。不行就docker登录,在root中直接使用sudo指令。然后ssh登录,使用一些不需要sudo的指令。
配置好的容器保存为新的镜像
bash
docker save -o <output-file-name>.tar <image-name>
其中:
<output-file-name>
是你要保存的输出文件的名称(包括路径),使用.tar
扩展名,例如myimage.tar
。<image-name>
是要保存的镜像的名称或 ID。
例如,要保存名为 myimage
的镜像到 myimage.tar
文件中,可以运行以下命令:
bash
docker save -o myimage.tar myimage
ssh登录
bash
ssh -p 37 freja@xx.x.x.x
ssh -p 服务器被映射端口 容器用户名@<服务器地址>
VS Code 中遇到 "cannot open source file" 错误
尽管文件实际上存在,可能是因为编译器无法找到包含文件的路径。
要解决这个问题,你可以在 VS Code 中配置正确的包含路径。以下是一些可能的解决方法:
使用 c_cpp_properties.json 文件:在你的工作区中,可以创建一个名为 .vscode 的文件夹,并在其中创建一个名为 c_cpp_properties.json 的文件。在该文件中,添加以下内容
bash
{
"configurations": [
{
"name": "Linux",
"includePath": [
"${workspaceFolder}/**",
"/opt/ros/foxy/include" // 添加 ROS 2 的 include 路径
],
"defines": [],
"compilerPath": "/usr/bin/gcc",
"cStandard": "gnu17",
"cppStandard": "gnu++14",
"intelliSenseMode": "gcc-x64"
}
],
"version": 4
}
确保将 /opt/ros/foxy/include
替换为你所使用的 ROS 2 版本的正确路径。