资讯专栏INFORMATION COLUMN

Apache Guacamole

社区管理员 / 1085人阅读

Apache Guacamole是一个基于web的远程终端支持ssh,vnc,rdp等协议

架构图如下

官网地址:http://guacamole.apache.org

image.png

从图中可看出分为guacamole服务和guacd服务,guacd服务负责连接远程的vpc,rdp,ssh等服务器

安装部署

这里使用k8s部署,注意本安装仅用于测试使用,由于mysql没做持久化重启之后数据会丢失

部署guacamole
cat <<EOF | kubectl apply -f -
apiVersion: apps/v1
kind: Deployment
metadata:
  name: guacamole
spec:
  selector:
    matchLabels:
      app: guacamole
  template:
    metadata:
      labels:
        app: guacamole
    spec:
      containers:
      - env:
        - name: GUACD_HOSTNAME # guacd地址
          value: guacamole-guacd
        - name: MYSQL_DATABASE # mysql数据库
          value: guacamole
        - name: MYSQL_HOSTNAME # mysql地址
          value: guacamole-mysql
        - name: MYSQL_PASSWORD # mysql密码
          value: root
        - name: MYSQL_USER # mysql用户
          value: root
        image: guacamole/guacamole:latest # 这里使用了最新版
        name: guacamole
        ports:
        - containerPort: 8080
          name: 8080tcp02
          protocol: TCP
        resources: {}
---
apiVersion: v1
kind: Service
metadata:
  name: guacamole
spec:
  ports:
  - port: 8080
    protocol: TCP
    targetPort: 8080
  selector:
    app: guacamole
  type: NodePort # 使用nodeport进行访问,也可以用ingress
EOF
部署guacd
cat <<EOF | kubectl apply -f -
apiVersion: apps/v1
kind: Deployment
metadata:
  name: guacamole-guacd
spec:
  selector:
    matchLabels:
      app: guacamole-guacd
  template:
    metadata:
      labels:
        app: guacamole-guacd
    spec:
      containers:
      - name: guacamole-guacd
        image: guacamole/guacd:latest
        resources: {}
        ports:
        - containerPort: 4822
---
apiVersion: v1
kind: Service
metadata:
  name: guacamole-guacd
spec:
  selector:
    app: guacamole-guacd
  ports:
  - port: 4822
    targetPort: 4822
EOF
部署mysql

mysql可以使用已经有的,且以下资源未做持久化重启之后数据会丢失不要用于生产!!!

cat <<EOF | kubectl apply -f -
apiVersion: apps/v1
kind: Deployment
metadata:
  name: guacamole-mysql
spec:
  selector:
    matchLabels:
      app: guacamole-mysql
  template:
    metadata:
      labels:
        app: guacamole-mysql
    spec:
      containers:
      - name: guacamole-mysql
        image: mysql:latest
        env:
        - name: MYSQL_ROOT_PASSWORD
          value: root
        resources: {}
        ports:
        - containerPort: 3306
---
apiVersion: v1
kind: Service
metadata:
  name: guacamole-mysql
spec:
  selector:
    app: guacamole-mysql
  ports:
  - port: 3306
    targetPort: 3306
EOF
初始化mysql
  1. 将guacamole的Entrypoint改为sleep 1h以方便进入容器

  2. 容器里执行/opt/guacamole/bin/initdb.sh --mysql > initdb.sql 导出mysql的表结构

  3. apt update && apt install mysql-client安装mysql客户端

  4. mysql -h guacamole-mysql -uroot -proot登录mysql数据库

    • 如果出现 ERROR 2059 (HY000): Authentication plugin ‘caching_sha2_password’ cannot be loaded 错误则需要在guacamole-mysql容器里登录数据库执行
      ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root';

  5. create database guacamole; 创建数据库

  6. use guacamole; 进入数据库, source initdb.sql导入表结构

登录
  • 因为是nodeport所有可以使用 <nodePort>/guacamole

  • 默认账号密码为guacadmin/guacadmin

添加链接

image.png

进入配置界面配置根据目标主机的情况填写

image.png

这个时候首页就出现了可以连接的机器,点击即可连接此机器

image.png

Ctrl + Alt + Shift 可以打开控制面板,复制文件也可以直接拖进去


文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/127876.html

相关文章

  • HTML教学讲义

    摘要:元素完整的元素列表元素由开始标签作为开始,结束标签作为结束。结束标签由尖括号斜杠标签名构成。属性由两部分构成,属性名和属性值属性值左右用双引号包含起来,并由等号与属性名相连。 以下内容如有不准确之处,欢迎指正 什么是HTML HTML是超文本标记语言 Hyper Text Markup Language HTML不是编程语言,而是标记语言 HTML最初的作用是用来展示文档 HTM...

    wapeyang 评论0 收藏0
  • Web Terminal 【远程登录】

    摘要:现有主机实例已有登录功能通过形式连接到目标主机,但是性能不高,速度慢,有延迟,用户体验差。提供基于远程管理协议和图像的展示能力。密码登录密钥登录使用说明目前已经发布洛杉矶华盛顿伦敦,将逐步从海外灰度到国内。现有主机实例已有【登录】功能通过VNC形式连接到目标主机,但是性能不高,速度慢,有延迟,用户体验差。需要增加一种Web Terminal方式可以登录主机实例,背后架构不同于VNC,使用ss...

    ernest.wang 评论0 收藏0

发表评论

0条评论

社区管理员

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<