【原创脚本】一键安装可以使用浏览器访问的Linux桌面环境

今天,我们来介绍一下我自己写的一个一键shell脚本。使用此脚本,您可以在您的Linux服务器上一键搭建一个可以随时随地用浏览器访问的Linux桌面环境,让您便捷地管理服务器。

本文及脚本程序作者为香菇肥牛,原文链接为https://qing.su/article/oneclick-desktop.html, 转载需注明原文链接。谢谢!

Github项目地址https://github.com/Har-Kuun/OneClickDesktop/ 欢迎大家星星叉叉

1, 脚本特色

  • 从源码编译安装Guacamole服务器
  • 配置Guacamole Web APP
  • 安装Tomcat 9, XRDP/TigerVNC, XFCE4桌面环境,火狐浏览器
  • 一键安装配置Let’s Encrypt安全证书,开启OCSP装订
  • 安装Nginx反代Tomcat
  • 安装完毕后,您可以使用任意浏览器访问远程桌面,无需再使用VNC/RDP客户端

 

2, 安装系统需求

目前,本程序仅支持在Ubuntu 18.04/20.04 LTS以及Debian 10的64位操作系统上运行。您的服务器或者VPS最好是全新安装的系统,不带LAMP/LEMP等组件或cPanel/DirectAdmin/宝塔等用户面板。

本程序支持Ubuntu 18.04/20.04 LTS, Debian 10, 以及CentOS 7/8 64位操作系统上运行。您的服务器或者VPS最好是全新安装的系统。如果您想要和宝塔或者其他面板共存,那么安装时请选择不安装Nginx反代,然后用您的面板来对服务器的http://IP_addr:8080/guacamole这个地址反代。

您的服务器需要有外网IP地址。在安装之前,您需要解析一个域名(可以用三级域名或者一个免费域名)到您的服务器上。如果您使用Debian或者Ubuntu系统,安装桌面环境需要至少1 GB的内存,推荐1.5 GB内存或以上。如果您使用CentOS系统,安装桌面环境需要至少1.5 GB内存,推荐2 GB内存或以上。

 

3, 安装教程

您可以使用sudo权限用户或root用户(不建议)登录服务器SSH,然后执行下面的命令即可。

英文版:

1
wget https://raw.githubusercontent.com/Har-Kuun/OneClickDesktop/master/OneClickDesktop.sh && sudo bash OneClickDesktop.sh

中文版:

1
wget https://raw.githubusercontent.com/Har-Kuun/OneClickDesktop/master/OneClickDesktop_zh-CN.sh && sudo bash OneClickDesktop_zh-CN.sh

程序将自动安装需要的各部分组件,并引导您选择RDP/VNC方式,设置用户名,密码以及域名。

如果安装过程中有报错,您可以检查同目录下的OneClickDesktop.log日志文件。同时建议您在这里留言汇报一下错误信息,或者在Github上提交issue, 这样我就可以即时更新脚本,修复问题。

 

4, 安装示例

安装好后,我们可以可以直接从浏览器里访问服务器上搭建的桌面程序,如下图。

 

综上,使用OneClickDesktop一键脚本,您可以自由方便地在Linux服务器上搭建随时随地用浏览器即可访问的桌面环境,让您便捷地管理您的Linux服务器,无需再使用繁琐的命令行。如果您喜欢此脚本,欢迎给Github项目https://github.com/Har-Kuun/OneClickDesktop/加星星加叉叉,或者把本文分享给朋友们。如果您有任何疑问,也欢迎在这里留言。

本文及脚本程序作者为香菇肥牛,原文链接为https://qing.su/article/oneclick-desktop.html, 转载需注明原文链接。谢谢!

注1:添加中文支持

1, 重新配置系统locales

1
sudo dpkg-reconfigure locales

2, 安装亚洲语言包

1
2
sudo apt-get install language-pack-ja language-pack-zh* language-pack-ko
sudo apt-get install japan* chinese* korean*

3, 安装亚洲语言字体

1
sudo apt-get install fonts-arphic-ukai fonts-arphic-uming fonts-ipafont-mincho fonts-ipafont-gothic fonts-unfonts-core

64 thoughts on “【原创脚本】一键安装可以使用浏览器访问的Linux桌面环境”

    • 可以使用IP地址:8080/guacamole的方式访问页面。
      方便的话可以把日志文件发送给我,帮你看一下。一般情况下,SSL证书安装失败都是因为解析没生效。

      Reply
      • 大佬,我已经安卓了无数次了,各种换系统重装,但一直是无法启动高性能 Web 服务器和反向代理服务器。SSL证书也安装失败,只能IP:8080/guacamole登陆,但是特别卡,还过一回就掉线。。。。。。。直接崩溃,我QQ加你了,能帮我研究下吗?

        Reply
  1. 安装好的guacamole,除了能通过浏览器访问这台机器的图形化界面。
    应该也可以配置去访问其他远程Windows系统吧?
    因为guacamole本身就是有这个功能的。

    Reply
  2. 安装好了guacamole之后,电脑访问鼠标无法移动,一直在左上角,但是手机访问却可以移动,求解

    Reply
      • 已经好了,确定是反代配置的问题和chrome的问题,没有证书chrome判定为不安全网页,屏蔽部分权限,需要在chrome://flags/#unsafely-treat-insecure-origin-as-secure里面添加访问域名强制解禁权限,或者通过ip地址直接访问一切正常,毕竟我反代只写了一行

        Reply
  3. Screen Size 默认 1280px X 800px
    貌似没有我的 1366px X 768px 大
    左右两边都有黑框
    在那修改 让它 显示和我的一样大 ?

    Reply
    • 这个是在/etc/systemd/system/vncserver@.service这个文件里面设置的哈。修改之后,执行

      1
      2
      systemctl daemon-reload
      systemctl restart vncserver@1.service
      Reply
    • 编辑文件/etc/tomcat9/server.xml, 可以把8080改成别的端口,然后

      1
      systemctl restart tomcat9

      我没用过宝塔,你可以去他们官方论坛里面问一下

      Reply
  4. 请问怎么把ipv6地址 改成ipv4的地址,自动绑定了 VPS的ipv6地址 然后8080/guacamole 访问不了

    Reply
  5. 大佬,出于安全考虑,我把xrdp默认的3389端口改掉了,现在网页登录Guacamole后,连接不上服务器了,需要改哪个地方? 找了半天,没找到Tomcat 9的配置文件。

    Reply
  6. 大佬你好,按你的教程成功搭建了,但是發現手機瀏覽器打開,登入Guacamole沒有問題,但是登入xorg系統時鍵盤沒彈出來,打字打不了,換了3個手機瀏覽器都不行(Opera,Firefox,oneplus系統自帶的瀏覽器),請問有什麽解決方案嗎?謝謝!

    Reply
      • 謝謝大佬! 我遇到另一個問題,就是按github建議把/etc/xrdp/xrdp.ini的port3389改掉之後,登入Guacamole沒有問題,但是連接不了xorg系統,看到上面nic大留言說tomcat9解決,但是我找不到對應需要修改的哪裏,請教一下大佬能不能補個修改端口(比如3389,8080)小教程?謝謝

        Reply
        • 3389端口是在/etc/guacamole/user-mapping.xml这里改的。
          8080是在/etc/tomcat9/server.xml里面改的。
          改完之后要重启对应的组件。

          Reply
          • 謝謝大佬! 在hostloc看到大佬說修改8080设置了nginx反代需要修改nginx,但是我vim /etc/nginx/nginx.conf之後沒看見有端口,請問是否也有另一處需要修改?謝謝

  7. 不好意思大佬,我另外發現每次reboot後都要登出再登入才能啓動pulseaudio聼聲音,請問是正常的嗎?謝謝!

    Reply
    • 这是pulseaudio在新版本系统上的bug,是正常现象。如果需要自动启动,可以把那两行命令写进systemd,或者放进一个shell里面放在桌面上,每次重启之后运行一下即可。

      Reply
      • 謝謝大佬,另外剛剛發現一鍵的源碼裏面mirror是使用上一版本guacamole1.2.0,後續會支援更新1.3.0 / 增加MySQL后台功能嗎?

        Reply
    • 需要提供日志看一下。一般来说都是防火墙或者端口被阻断等原因。如果你用的是CentOS系统,Selinux也是常见的导致服务器无法正常运行的因素之一。

      Reply
  8. 本连接因为Guacamole服务器出现了内部错误而被终止。如果问题持续,请通知您的系统管理员,或检查您的系统日志。

    Reply

Leave a Comment