ubuntu20.04安装+ros-noetic安装+内网穿透frp

刷机后的系统安装

  • ubuntu20.04安装
  • 安装ros-noetic
  • 安装各种必要的插件
  • 安装vscode
  • 内网穿透连接实验室主机
    • 配置frpc和frps文件
    • 运行
    • 完成自动化部署
    • 免密登录
      • linux的免密登录
      • windows上的免密登录

内网穿透的参考链接:如何优雅地访问远程主机?SSH与frp内网穿透配置教程

ubuntu20.04安装

选择镜像网站:

https://mirrors.tuna.tsinghua.edu.cn/

下载20.04的iso

在vmware中创建新的虚拟机

自定义->下一步
请添加图片描述找自己的影响文件的下载目录

下一步:

设置用户名密码,个性化的全名
请添加图片描述设置名称和存放位置:
请添加图片描述下一步,再下一步,按照有推荐一直下一步,到这里:
请添加图片描述内存设置最好在120G左右(为后续做slam留足空间),放在机械硬盘里面就可以,再下一步

最后完成。

创建好以后可以移出各种外设,包括打印机,软盘,DVD,DVD2等等

安装ros-noetic

首先先修改源的位置,为了git clone的更快

请添加图片描述点开以后在这里:
请添加图片描述在这里选择other,选择阿里云的镜像网站就可以了

安装各种必要的插件

在终端中依次输入:

# 为 apt 添加ROS软件源
sudo sh -c '. /etc/lsb-release && echo "deb http://mirrors.ustc.edu.cn/ros/ubuntu/ `lsb_release -cs` main" > /etc/apt/sources.list.d/ros-latest.list'# 为ROS软件源添加密钥
sudo apt-key adv --keyserver 'hkp://keyserver.ubuntu.com:80' --recv-key C1CF6E31E6BADE8868B172B4F42ED6FBAB17C654# 更新一下软件源,把ros-noetic的包添加进去
sudo apt update# 安装ros-noetic
sudo apt install ros-noetic-desktop-full# 安装ros-noetic的各种插件
sudo apt install python3-roslaunch python3-rostopic python3-rosnode python3-catkin python3-catkin-tools python3-wstool python3-vcstool# 下面两条安装gtsam
# 安装gtsam的网站:https://gtsam.org/get_started/
sudo add-apt-repository ppa:borglab/gtsam-release-4.0# not necessary since Bionic
sudo apt update  
sudo apt install libgtsam-dev libgtsam-unstable-dev# 这个指令可有可没有
git config --global core.editor vim# 配置pip
sudo apt install python3-pip

最后可以安装zsh

安装zsh的过程:

sudo apt install zsh
sudo apt install git
git clone https://github.com/ohmyzsh/ohmyzsh.git
# 找到oh-my-zsh/tools
# 进入该目录,找到setup.sh
# 运行:
sh ./setup.sh

就结束

同时,将

source /opt/ros/noetic/setup.sh

指令放在~/.bashrc文件的最末尾

如果使用zsh,则将:

source /opt/ros/noetic/setup.zsh

上述指令放在~/.zshrc文件中

检查一下,在.zshrc文件中应该有这几个部分

source /opt/ros/noetic/setup.zsh
source /home/gzc/livox_driver_ws/devel/setup.zsh
# 这里是为了和bashrc文件中的环境一样
export PATH=~/.local/bin:$PATH
# 如果有小车的话,需要有小车的ip
export ROS_MASTER_URL=http://localhost:11311

键盘控制小车运动的功能包:teleop_twist_keyboard(只知道名字,还未实践)

rosrun teleop_twist_keyboard teleop_twist_keyboard.py

安装vscode

网站:https://code.visualstudio.com/

下载:

下载好之后,放进Ubuntu中,双击点开,安装

安装简体中文插件

安装C++插件

创建一个c++文件:1.cpp

随后运行,选择/usr/bin/gcc目录下的c++

ctrl+shift+p唤醒命令窗口

内网穿透连接实验室主机

本机:笔记本电脑

远程机:实验室的虚拟机

服务器:阿里云默认linux服务器

注册一个阿里云的服务器,在github上下载0.38.0的frp的代码,网址:

https://github.com/fatedier/frp/releases?page=3

请添加图片描述先开放服务器端linux的端口号,配置如下:
请添加图片描述下载好以后,进行文件的修改:

linux中:编辑/etc/hosts文件,在文件末尾加上

ssh-server + 公网地址

在windows中,编辑文件C:\Windows\System32\drivers\etc\hosts文件,在文件末尾加上

ssh-server + 公网地址

随后,本机(现在操纵的笔记本电脑)ssh到服务器端,即:

ssh root@ssh-server

实验室的虚拟机,也ssh到服务器端,由此,通道已经打通;

配置frpc和frps文件

请添加图片描述frps.ini文件不需要修改

frpc.ini文件需要修改:

[common]
# 这里的ip地址要改成服务器的ip地址,端口号不变
server_addr = xx.xx.xx.xx
server_port = 7000[ssh]
type = tcp
local_ip = 127.0.0.1
local_port = 22
remote_port = 6000

运行

在服务器端:

找到frps可执行文件在的位置,进入到那个目录,使用以下指令:

cd frps
./frps -c ./frps.ini

如果frps没有执行权限,则在frps的目录下,使用:

chmod +x frps

运行成功后:

请添加图片描述客户端(实验室的虚拟机):

cd frpc
./frpc -c ./frpc.ini

运行成功配图:

请添加图片描述
配置成功,现在就可以使用vscode远程登陆主机了,运行指令:

ssh -p 6000 gzc@ssh-server

输入实验室虚拟机的密码即可登录

完成自动化部署

使用service插件

在服务器端,将下面的代码放在lib/systemd/system/frps.service中

[Unit]
Description=Frp Server Service
After=network.target[Service]
Type=simple
# 这里修改为服务器的主机名
User=root
Restart=on-failure
RestartSec=5s
# 这里修改路径为安装frps可执行文件以及frps.ini文件的路径
ExecStart=/usr/bin/frps -c /etc/frp/frps.ini
LimitNOFILE=1048576[Install]
WantedBy=multi-user.target

使用下面的指令:

systemctl daemon-reload
systemctl enable frps
systemctl start frps
systemctl status frps

使用上述指令后,就得到了下面的提示:
请添加图片描述
看到active(running) 就代表启动成功了

在客户端,与服务器端的修改是一样的,不过要使用frpc.service(客户端的)文件

免密登录

需求:本机(笔记本)可以远程访问服务器,免密登录,且免密登录实验室的虚拟机

linux的免密登录

本机的配置:(windows)

首先,在设置 -> 添加可选功能 ->openssh的服务端安装好(用外网)

找到C:\Users\gzc目录下,使用cmd命令:

sshkey-keygen

现在单机.ssh文件夹,可以找到id_rsa.pub公钥

请添加图片描述复制这个公钥,进入虚拟机,在虚拟机的~/.ssh文件夹中,输入以下命令:

# 添加authorized_keys文件
sudo vim authorized_keys

将复制的公钥放在这个文件中,保存,这样就配好了ssh的免密登录(实验室的虚拟机)

公网上的服务器与实验室的虚拟机是一样的配置

windows上的免密登录

如果我现在想要用笔记本登录实验室的windows主机,这样就复杂一些:

将上面复制的公钥粘贴在C:\Users\gzc11 \ .ssh\authorized_keys这个文件中,同时,要设置一下:

C:\ProgramData\ssh文件夹中的配置:

修改的部分在第34,38,51行,同时,将最后两行注释掉了

# This is the sshd server system-wide configuration file.  See
# sshd_config(5) for more information.# The strategy used for options in the default sshd_config shipped with
# OpenSSH is to specify options with their default value where
# possible, but leave them commented.  Uncommented options override the
# default value.#Port 22
#AddressFamily any
#ListenAddress 0.0.0.0
#ListenAddress ::#HostKey __PROGRAMDATA__/ssh/ssh_host_rsa_key
#HostKey __PROGRAMDATA__/ssh/ssh_host_dsa_key
#HostKey __PROGRAMDATA__/ssh/ssh_host_ecdsa_key
#HostKey __PROGRAMDATA__/ssh/ssh_host_ed25519_key# Ciphers and keying
#RekeyLimit default none# Logging
#SyslogFacility AUTH
#LogLevel INFO# Authentication:#LoginGraceTime 2m
#PermitRootLogin prohibit-password
#StrictModes yes
#MaxAuthTries 6
#MaxSessions 10PubkeyAuthentication yes# The default is to check both .ssh/authorized_keys and .ssh/authorized_keys2
# but this is overridden so installations will only check .ssh/authorized_keys
AuthorizedKeysFile	.ssh/authorized_keys#AuthorizedPrincipalsFile none# For this to work you will also need host keys in %programData%/ssh/ssh_known_hosts
#HostbasedAuthentication no
# Change to yes if you don't trust ~/.ssh/known_hosts for
# HostbasedAuthentication
#IgnoreUserKnownHosts no
# Don't read the user's ~/.rhosts and ~/.shosts files
#IgnoreRhosts yes# To disable tunneled clear text passwords, change to no here!
PasswordAuthentication yes
#PermitEmptyPasswords no#AllowAgentForwarding yes
#AllowTcpForwarding yes
#GatewayPorts no
#PermitTTY yes
#PrintMotd yes
#PrintLastLog yes
#TCPKeepAlive yes
#UseLogin no
#PermitUserEnvironment no
#ClientAliveInterval 0
#ClientAliveCountMax 3
#UseDNS no
#PidFile /var/run/sshd.pid
#MaxStartups 10:30:100
#PermitTunnel no
#ChrootDirectory none
#VersionAddendum none# no default banner path
#Banner none# override default of no subsystems
Subsystem	sftp	sftp-server.exe# Example of overriding settings on a per-user basis
#Match User anoncvs
#	AllowTcpForwarding no
#	PermitTTY no
#	ForceCommand cvs server# Match Group administrators
#        AuthorizedKeysFile __PROGRAMDATA__/ssh/administrators_authorized_keys

第三步:重启ssh服务

找到计算机管理界面->服务,找到openssh-Server,重启一下即可
请添加图片描述
内网穿透参考链接:如何优雅地访问远程主机?SSH与frp内网穿透配置教程

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/819036.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Bootstrap 5 保姆级教程(一):容器 网格系统

一、容器 1.1 固定宽度&#xff08;.container&#xff09; .container 类用于固定宽度并支持响应式布局的容器。 以下实例中&#xff0c;我们可以尝试调整浏览器窗口的大小来查看容器宽度在不同屏幕中等变化&#xff1a; <!doctype html> <html lang"en&quo…

【C语言回顾】分支和循环

前言1. if 分支进阶1.1 嵌套 if1.2 悬空 else 2. switch 语句3. while 循环4. for 循环5. goto语句结语 上期回顾: 【C语言回顾】数据类型和变量相关 前言 各位小伙伴&#xff0c;大家好&#xff01;话不多说&#xff0c;我们直接进入正题。 以下是C语言分支和循环的总结。 1…

ARM看门狗定时器

作用 在S3C2440A中&#xff0c;看门狗定时器的作用是当由于噪声和系统错误引起的故障干扰时恢复控制器的工作。 也就是说&#xff0c;系统内部的看门狗定时器需要在指定时间内向一个特殊的寄存器内写入一个数值&#xff0c;俗称喂狗。 如果喂狗的时间过了&#xff0c;那么看门…

修改Ubuntu的镜像源为华为镜像源

修改Ubuntu的镜像源为华为镜像源 1、首先使用以下命令备份现有的镜像源&#xff1a; cd /etc/apt sudo cp sources.list sources.list.bak 2、使用以下命令打开镜像源文件&#xff1a; sudo vim /etc/apt/sources.list 3、在vim插入模式下使用以下内容替换掉原镜像源…

STM32H7上实现AD5758驱动

目录 概述 1 下载ADI 5758 Demo 2 AD5758驱动的移植 2.1 使用STM32CubeMX创建工程 2.2 接口函数实现 2.2.1 驱动接口列表 2.2.2 函数实现 2.2.3 修正ad5758驱动 3 AD5758应用程序 3.1 编写测试程序 3.1.1 配置参数结构 3.1.2 配置参数函数 3.1.3 读取参数函数 3.…

时隔一年,再次讨论下AutoGPT-安装篇

AutoGPT是23年3月份推出的&#xff0c;距今已经1年多的时间了。刚推出时&#xff0c;我们还只能通过命令行使用AutoGPT的能力&#xff0c;但现在&#xff0c;我们不仅可以基于AutoGPT创建自己的Agent&#xff0c;我们还可以通过Web页面与我们创建的Agent进行聊天。这次的AutoGP…

设计模式——观察者模式17

观察者模式指多个对象间存在一对多的依赖关系&#xff0c;当一个对象的状态发生改变时&#xff0c;所有依赖于它的对象都得到通知并被自动更新。这种模式有时又称作发布-订阅模式。 中介者模式是N对N的双向关系。观察者模式是1对N的单向关系。 设计模式&#xff0c;一定要敲代码…

电机驱动-理论学习-Fast计算

Fast计算 cordic方法原理详解代码实现 德州仪器IQmath算法讲解代码实现 欧洲黑客大会FastMath实现原理代码实现 电机运算通常在有限资源MCU上进行计算&#xff0c;对实时性有极高要求。然而&#xff0c;电机驱动又有大量的计算。所以&#xff0c;对运算速度也有较为严格要求。所…

腾讯EdgeOne产品测评体验—金字塔般的网络安全守护神

作为一名对网络安全和性能优化充满热情的用户&#xff0c;我决定体验腾讯云下一代 CDN 服务 - EdgeOne。这款引以为傲的全方位服务如数来到&#xff0c;从域名解析、动静态智能加速到四层加速及DDoS/CC/Web/Bot 防护&#xff0c;一应俱全。随着时代风云变幻&#xff0c;日均数千…

SpringCloud整合ElasticSearch搜索使用

环境说明 ORM&#xff1a;easy-es 2.0.0(opens new window) ElasticSearch&#xff1a;7.14.0 pigx&#xff1a;5.2 请保持环境如上&#xff0c;ElasticSearch 兼容性较差无法保证其他版本正常整合执行。快速开始 ① 安装 ElasticSearch docker run --name es714 -p 9200:920…

高级数据结构与算法习题(7)

一、单选题 1、When solving a problem with input size N by divide and conquer, if at each stage the problem is divided into 8 sub-problems of equal size N/3, and the conquer step takes O(N2logN) to form the solution from the sub-solutions, then the overall…

Linux调试器之gdb

前言 我们前面介绍了几个基本的环境开发工具。例如通过yum我们可以安装和卸载软件、通过vim我们可以写代码、通过gcc和g我们可以编译代码成可执行程序。但是如何在Linux下调试代码呢&#xff1f;我们并未介绍&#xff0c;本期我们将来介绍最后一个工具 --- 调试器gdb。 本期内…

云原生周刊:CNCF 2023 年度调查报告 | 2024.4.15

开源项目推荐 highlight 该项目是一个开源全栈监控平台。其功能包括错误监控、会话重放、日志记录、分布式跟踪等。 Helm Compose Helm Compose 是一个 helm 插件&#xff0c;用于在单个配置文件中管理一个或多个图表的多个版本。 HAMi 异构 AI 计算虚拟化中间件&#xf…

HttpComponentsClientHttpRequestFactory

HttpComponentsClientHttpRequestFactory 文章目录 HttpComponentsClientHttpRequestFactory介绍**配置 PoolingHttpClientConnectionManager 时&#xff0c;可以使用如下的方法来设置最大连接数&#xff1a;****defaultMaxPerRoute**示例RestTemplate的负载均衡策略是什么&…

字节面试:领域、子域、核心域、通用域和支撑域怎么划分?

领域驱动设计&#xff08;DDD&#xff09;里面有一堆专业术语&#xff0c;比如领域、子域、核心域、通用域、支撑域等等&#xff0c;听着是不是觉得挺吓人&#xff1f;别怕&#xff0c;我来带你轻松搞懂它们。 ​《Leetcode算法刷题宝典》一位阿里P8大佬总结的刷题笔记。 《大厂…

DAY13|239. 滑动窗口最大值、347.前K个高频元素

239. 滑动窗口最大值、347.前 K 个高频元素 239. 滑动窗口最大值347.前 K 个高频元素 239. 滑动窗口最大值 难度有些大啊… 其实队列没有必要维护窗口里的所有元素&#xff0c;只需要维护有可能成为窗口里最大值的元素就可以了&#xff0c;同时保证队列里的元素数值是由大到小…

基于U-Net的图像分割算法介绍

U-Net是一种用于图像分割的深度学习架构,其设计初衷是用于生物医学图像分割,尤其是医学影像中的细胞分割任务。U-Net结构独特,具有编码器-解码器结构,能够有效地捕捉图像中的局部和全局信息,并在像素级别上进行精确的分割。 相关论文: U-Net: Convolutional Networks for…

STM32 CAN的验收筛选器

STM32 CAN的验收筛选器 简介 CAN外设的验收筛选器&#xff0c;一共有28个筛选器组&#xff0c;每个筛选器组有2个寄存器&#xff0c; CAN1和CAN2共用的筛选器的。 在 CAN 协议中&#xff0c;消息的标识符与节点地址无关&#xff0c;但与消息内容有关。因此&#xff0c;发送节…

密码学基础 -- 走进RSA(2)(放弃数学原理版)

目录 1.概述 2. RSA测试 2.1 加解密实验 2.2 签名验签测试 3. RSA原理简介 4.小结 1.概述 从上面密码学基础 -- 走进RSA(1)(放弃数学原理版)-CSDN博客我们知道了非对称算法的密钥对使用时机&#xff0c;那么接下里我们继续讲解RSA&#xff0c;我们分别从RSA加解密、签名验…