使用guacamole进行WEB远程桌面连接

news2024/11/15 17:42:10

Apache Guacamole 是一个无客户端的远程桌面网关。它支持标准协议,如 VNC、RDP 和 SSH,甚至还支持k8s、telnet连接。它可以在任何有网络的地方连接上你的服务器和Windows主机。可以同时连接多个终端,并且能够无缝切换。本文采用docker进行部署

部署教程

安装docker

首先需要安装Docker,使用官方一键安装脚本部署或者在线安装,已安装的直接忽略

yum install docker-ce
systemctl start docker.service 
systemctl enable docker.service 

拉取Guacamole服务器、Guacamole客户端和MySQL的Docker镜像:

docker pull guacamole/guacamole
docker pull guacamole/guacd
docker pull mysql/mysql-server
docker image ls
[root@k8master1 ~]# docker image ls
REPOSITORY                                                                     TAG       IMAGE ID       CREATED         SIZE
guacamole/guacamole                                                            latest    36d1e135bac7   4 hours ago     496MB
guacamole/guacd                                                                latest    fca0b87cc016   27 hours ago    149MB
mysql/mysql-server                                                             latest    1d9c2219ff69   9 months ago    496MB

部署mysql

运行docker容器

docker run -p 3306:3306 --name mysqltest -e MYSQL_ROOT_PASSWORD=123456 -d mysql/mysql-server

Guacamole程序不会自动初始化数据库,运行MySQL之后需要手动初始化数据库,而Guacamole提供了数据库文件,只需要生成导入就可以了。

docker run --rm guacamole/guacamole /opt/guacamole/bin/initdb.sh --mysql > initdb.sql

重命名并将initdb.sql移动到MySQL容器中,后续就能通过这个生成表:

docker cp initdb.sql mysqltest:/guac_db.sql

在MySQL的Docker容器中打开bash终端:

docker exec -it mysqltest bash

使用密码登录。如下所示:

mysql -u root -p123456

创建数据库,以及创建一个新的数据库和用户

CREATE DATABASE guacamole_db;
CREATE USER ‘guacamole_user’@’%’ IDENTIFIED BY ‘guacamole_user_password’;
GRANT SELECT,INSERT,UPDATE,DELETE ON guacamole_db.* TO ‘guacamole_user’@’%’;
FLUSH PRIVILEGES;

最后,输入quit退出即可
在bash终端中,使用初始化脚本为新数据库创建数据表:

cat guac_db.sql | mysql -u root -p guacamole_db

到这里,数据库的操作其实都完成了,但是我们还是小心为上。再验证数据表是否已成功添加。如果guacamole数据库中不存在新建的表,请再次确认之前的步骤均已正确执行。

连接数据库

docker exec -it mysqltest bash
mysql -u root -p123456

选择数据库

USE guacamole_db;

查看所有表

SHOW TABLES;

如果正确无误的话,你看到的应该和我的差不多。

mysql> SHOW TABLES;
+---------------------------------------+
| Tables_in_guacamole_db                |
+---------------------------------------+
| guacamole_connection                  |
| guacamole_connection_attribute        |
| guacamole_connection_group            |
| guacamole_connection_group_attribute  |
| guacamole_connection_group_permission |
| guacamole_connection_history          |
| guacamole_connection_parameter        |
| guacamole_connection_permission       |
| guacamole_entity                      |
| guacamole_sharing_profile             |
| guacamole_sharing_profile_attribute   |
| guacamole_sharing_profile_parameter   |
| guacamole_sharing_profile_permission  |
| guacamole_system_permission           |
| guacamole_user                        |
| guacamole_user_attribute              |
| guacamole_user_group                  |
| guacamole_user_group_attribute        |
| guacamole_user_group_member           |
| guacamole_user_group_permission       |
| guacamole_user_history                |
| guacamole_user_password_history       |
| guacamole_user_permission             |
+---------------------------------------+
23 rows in set (0.00 sec)

在Docker中启动guacd:

docker run --name myguacd -d guacamole/guacd

连接容器,以便Guacamole验证存储在MySQL数据库中的凭证:

docker run --name myguacamole --link myguacd:guacd --link mysqltest:mysql -e MYSQL_DATABASE=guacamole_db -e MYSQL_USER=guacamole_user -e MYSQL_PASSWORD=guacamole_user_password -d -p 0.0.0.0:9090:8080 guacamole/guacamole

因为需要三个容器联动,保险起见,我们还是再检查一下
可通过以下命令查看所有正在运行的Docker容器:

[root@k8master1 ~]# docker ps
CONTAINER ID   IMAGE                 COMMAND                  CREATED       STATUS                 PORTS                                                        NAMES
7b9b079cd966   guacamole/guacamole   "/opt/guacamole/bin/…"   2 hours ago   Up 2 hours             0.0.0.0:9090->8080/tcp                                       myguacamole
22376ea97d95   guacamole/guacd       "/bin/sh -c '/opt/gu…"   2 hours ago   Up 2 hours (healthy)   4822/tcp                                                     myguacd
b5fa8ca1002b   mysql/mysql-server    "/entrypoint.sh mysq…"   3 hours ago   Up 3 hours (healthy)   0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060-33061/tcp   mysqltest
[root@k8master1 ~]#

可以看到myguacamole、myguacd和mysqltest等三个容器在后台运行中

请在浏览器中访问localhost:8080/guacamole/

默认的登录账户是guacadmin,默认登录密码guacadmin。登录后应尽快修改登录账户及密码。当然,如果你不是配置在本地,那你就把localhost换成对应的ip地址即可。
在这里插入图片描述
成功登录后,选择settings->connections->new connection
在这里插入图片描述
新建一个连接,采用ssh协议
在这里插入图片描述
在这里插入图片描述
配置完成后,选择返回home页面
在这里插入图片描述
这是就可以通过浏览器访问需要访问的主机了
在这里插入图片描述

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

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

相关文章

4.9 多协议标记交换MPLS

思维导图: 前言: **4.9 多协议标记交换MPLS笔记** 1. **定义与背景**: - MPLS (多协议标记交换) 是一种由 IETF 开发的新协议。 - “多协议”意味着 MPLS 的上层可以使用多种协议。 - 该协议综合了多家公司的技术,如 C…

LiveGBS流媒体平台GB/T28181常见问题-国标平台通道数为0无法播放的时候如何抓包分析windows抓包和Linux抓包

LiveGBS通道数为0无法播放的时候如何抓包分析windows抓包和Linux抓包 1、第一步:抓包工具准备1.1、Linux1.2、windows 2、第二步:找到设备出口ip3、第三步:执行命令抓设备出口ip3.1 Linux3.2 Windwos 4、第四步:触发相关页面操作4…

比例伺服阀放大器厂家

比例阀放大器具有以下优点: 高精度:比例阀放大器能够根据输入信号的微小变化实时调整输出信号,从而实现对液压系统的精确控制。快速响应:比例阀放大器能够快速响应输入信号的变化,并迅速调整输出信号,以满…

【标准化封装 SOT系列 】 D SOT-323 SOT-363

〇、关键词 SC70 。 一、D部分 SOT-323 SOT-363 这个应该叫SC-70可能更合适,典型特征 pin 间距 0.65mm ; body size 2.0mm1.25mm 这一节很像SOT-23,即A部分,因此也是最容易被混淆的。 二、SC70-3 / -5/ -6 鉴于此,封装最好给…

Oracle 19c OCM讲义课程:应用SQL执行计划基线的案例

使用SQL执行计划基线可以保证SQL的性能不下降,但实际生产中默认没有开启,这里是姚远老师在给OCM的学员授课中关于SQL执行计划基线的一个案例,大家可以借鉴一下。 关于号主,姚远: Oracle ACE(Oracle和MyS…

eNSP-OSPF协议其他区域不与骨干区域相连解决方法1

OSPF多进程路由重分布 AR1 [ar1]int g0/0/0 [ar1-GigabitEthernet0/0/0]ip add 192.168.1.1 24 [ar1-GigabitEthernet0/0/0]quit [ar1]ospf [ar1-ospf-1]area 0 [ar1-ospf-1-area-0.0.0.0]net 192.168.1.0 0.0.0.255 [ar1-ospf-1-area-0.0.0.0]quitAR2 [ar2]int g0/0/0 [ar2…

C++ 类和对象(1)

大纲 初步认识类和对象 c语言是面向过程的 关注的是过程 分析出求问题的步骤 通过调用函数逐步解决 c是基于面向对象的 关注的是对象 将一件事情拆分成不同的对象 靠对象之间的交互完成 举个栗子 把大象关进冰箱。 面向过程的分析过程: 第一步:把冰…

优思学院|六西格玛的发展历程是怎样的?

在商业世界的星空中,有一颗璀璨的星星,它的名字叫做六西格玛。这颗星星不是一夜之间闪耀登场的,而是在商界的无尽深夜中,逐渐积累了耀眼的光芒。今天,我就来为大家介绍一下六西格玛的发展历程吧。 西格玛是啥&#xff…

nginx+apach+数据恢复+apk小练习hunan

这份练习来自项师兄,我们湖南警官的新一代大佬向专家,我就向师兄讨要了检材一份,然后自己练习一下在csdn写一下我的刷题经历,如有错误,还请指正,另外可以看向师兄的微信公众号 2023某省电子取证比武wp“ 参加比赛侥幸拿下第一,发一发复盘wp,大佬勿喷,如有错误请指出,…

R语言:因子分析 factor analysis

文章目录 因子分析数据集处理步骤主成分法做因子分析最大似然法做因子分析 因子分析 因子分析的用途与主成分分析类似,它也是一种降维方法。由于因子往往比主成分更易得到解释,故因子分析比主成分分析更容易成功,从而有更广泛的应用。 从方法…

Mac文件对比同步工具 Beyond Compare 4.4.7

Beyond Compare 4 是一款强大的文件和文件夹比较工具。它提供了一个直观的界面,使您可以快速比较和同步文件和文件夹。 Beyond Compare 4 具有许多有用的功能,包括比较和合并文件、文件夹和压缩文件,以及同步文件和文件夹。它支持各种类型的文…

万圣节海外网红营销:助力品牌赢得消费者的心

万圣节,源自古代凯尔特文化,如今已成为一个全球性的节庆。它不仅是一个传统的庆祝活动,还是商业和品牌推广的黄金机会。在当今数字时代,社交媒体和网红文化已经成为品牌推广的重要渠道。万圣节为品牌提供了一个独特的机会&#xf…

点进来看看要如何在Telegram上找到目标群组

Telegram作为目前除了WhatsApp之外,在苹果应用商店市场第二高下载量的社交媒体平台是我们出海企业不可以错过的资源。而且就在日前海外科技媒体TechCrunch爆料称,Telegram正与腾讯展开合作,有望将Telegram打造为一个类似微信的“超级应用生态…

java 使用poi读取excel内浮动图片

注意&#xff1a;仅读取到xls中的浮动图片&#xff0c;嵌入图片此方法读取不到 1、引入poi依赖 <dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>3.17</version></dependency><depen…

C++11包装器

文章目录 1.当前程序的问题2.包装器的引入2.1包装器的定义2.2包装器的使用2.3包装器的出现对于2.1问题的解决 3.包装器的应用3.1C98写法3.2C11写法count()的用法下标运算符operator[ ]lambda表达式的另一种用法C11写法 1.当前程序的问题 template<class T, class K> K u…

MSC应用新进展

2023年9月23日&#xff0c;第四届中国干细胞与再生医学协同创新平台大会正式发布了我国首个人源干细胞国家标准《生物样本库多能干细胞管理技术规范》(GB/T42466-2023)&#xff0c;标志着我国在干细胞样本库管理上有了标准技术支撑&#xff0c;对于推动我国干细胞研究和应用的规…

React之Redux详解

一、Redux 1、是什么 React是用于构建用户界面的&#xff0c;帮助我们解决渲染DOM的过程 而在整个应用中会存在很多个组件&#xff0c;每个组件的state是由自身进行管理&#xff0c;包括组件定义自身的state、组件之间的通信通过props传递、使用Context实现数据共享 如果让…

【QT开发笔记-基础篇】| 第四章 事件QEvent | 4.8 绘图事件

本节对应的视频讲解&#xff1a;B_站_链_接 【QT开发笔记-基础篇】 第4章 事件 4.8 绘图事件(1) 本章要实现的整体效果如下&#xff1a; QEvent::Paint ​ 当窗口/控件需要重绘时&#xff0c;触发该事件&#xff0c;它对应的子类是 QPaintEvent 本节通过一个向 QLabel 上绘制…

“揭秘!如何通过京东商品详情接口轻松获取海量精准商品信息!“

京东商品详情接口可以通过HTTP GET请求获取商品详情信息。 请求参数包括num_iid&#xff0c;表示JD商品ID。 请求示例&#xff1a; GET /jd/item_get/?num_iid10335871600 HTTP/1.1 Host: api-vx.Taobaoapi2014.cn Connection: close Accept-Encoding: gzip 点击获取…

决策树深度探索: 从基础构建到机器学习应用

机器学习 第六课 决策树 概述决策树的基本概念决策树的应用决策树的基本构建节点 (Node)分支 (Branch)决策树的构造过程 信息增益熵 (Entropy)条件熵 (Conditional Entropy)信息增益 (Information Gain) 信息熵计算计算数据集的熵计算在给定属性条件下的熵计算信增益 (Informat…