Docker容器运行GUI程序的配置方法
0.环境说明
Ubuntu 16.04
docker 1.35
1.Docker的“可视化”
Docker本身的工作模式是命令行的,因为主要的使用场景可能是做服务器后端方面的比较多。
但有时候我们会有在docker容器里运行一些图形界面的软件,或者要调用摄像头,输出图像等等一些需求,这个时候需要解决这个Docker “可视化”的问题。
(这里的“可视化”不是很容易搜到的可视化管理的方法)
2.解决方案1—启动容器时添加配置选项
这篇文章里介绍了Docker公司的程序员杰西·弗莱泽尔(Jessie Frazelle)展示的使用了图形界面的镜像的例子,Jessie也开源了她展示的docker 运行libreoffice软件的代码和使用方法。
2.1 原理简介
原文中讲的比较详细,原理并不复杂,我按照自己理解很浅显地讲一下。
原理上可以把docker镜像看做一台没配显示器的电脑,程序可以运行,但是没地方显示。
而linux目前的主流图像界面服务X11又支持 客户端/服务端(Client/Server)的工作模式
只要在容器启动的时候,将 『unix:端口』或『主机名:端口』共享给docker,docker 就可以通过端口找到显示输出的地方,和linux系统共用显示
2.2 具体操作(显示到本地显示器)
1)首先,在主系统里运行
$ sudo apt-get install x11-xserver-utils $ xhost +
这两句的作用是开放权限,允许所有用户,当然包括docker,访问X11 的显示接口
2)在启动docker容器时,添加选项如下:
-v /tmp/.X11-unix:/tmp/.X11-unix \ #共享本地unix端口 -e DISPLAY=unix$DISPLAY \ #修改环境变量DISPLAY -e GDK_SCALE \ #我觉得这两个是与显示效果相关的环境变量,没有细究 -e GDK_DPI_SCALE \
最终的启动命令就会长类似这样
$ docker run -d \ -v /etc/localtime:/etc/localtime:ro \ -v /tmp/.X11-unix:/tmp/.X11-unix \ -e DISPLAY=unix$DISPLAY \ -e GDK_SCALE \ -e GDK_DPI_SCALE \ --name libreoffice \ jess/libreoffice
这样启动后的容器,运行有图形界面的程序就可以自由显示,和在本地显示一样了。
这样操作已经十分方便了。需要注意的是,每次重新开机,需要在本机操作一次
xhost +
打开权限。应该有永久更改这个的办法,不过我觉得不算麻烦。
原文中还有在远程显示的配置方法,我没有试,就不多说了。
3.解决方案2—已经启动的容器修改系统参数
参考文章
有的时候,我们在已经启动的容器里做了一些事情,有了显示图像的需要,但从头新启动一个容器有点麻烦。
这时候可以用上面博客里讲的方法实现图形界面显示,也还算方便。
思路上也是把主机和docker看做服务器和客户端的关系,通过IP地址来映射显示。
3.1 具体操作
1)使用 ifconfig 查看主机和docker的IP地址
例如:主机的IP为 xxx
docker 的IP为YYY
2)docker 中
export DISPLAY= XXX #把环境变量映射到主机IP
3.)主机中
sudo gedit /etc/lightdm/lightdm.conf #增加一行 xserver-allow-tcp=true sudo systemctl restart lightdm xhost + #注意加号前应有空格
这样配置就完成了,这是第一次配置的操作.
以后每次重新开机时,还是要在主机里运行一下 xhost +,在docker里运行一下export DISPLAY= XXX 。
其实还是挺麻烦的。
最关键的是,这种方式用的是IP地址,在系统没联网时,网卡就没有分配的IP地址了,这种方法就行不通了。
4.怎样测试能否显示图像界面
第二篇参考文章中用了一个显示时钟的小程序xclock
不过我在Ubuntu16.04的环境里搜不到这个了,能安装的叫xarclock,功能一样
在docker中运行
sudo apt-get install xarclock #安装这个小程序 xarclock #运行,如果配置成功,会显示出一个小钟表动画
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Kubernetes之路 3 - 解决服务依赖
本系列文章记录了企业客户在应用Kubernetes时的一些常见问题 第一篇:Java应用资源限制的迷思 第二篇:利用LXCFS提升容器资源可见性 第三篇:解决服务依赖 在容器服务的客户群中,一个经常被问起的问题就是如何处理服务间依赖。 在应用中,一个组件依赖指定的中间件服务和业务服务。在传统的软件部署方式中,应用启动、停止都要依照特定的顺序完成。 当采用 Kubernetes/Docker Swarm等容器编排技术在分布式环境下部署应用时,一方面不同组件之间并行启动无法保证其启动顺序,另一方面在应用运行时,其所依赖的服务实现有可能发生失败和迁移。如何解决容器之间的服务依赖就是一个非常常见的问题。 方法1 - 应用端服务依赖检查 我们可以在应用的启动逻辑中添加服务依赖检查逻辑,如果应用依赖的服务不可访问就重试,当错误超过一定次数后就自动退出。Kub
- 下一篇
一键安装Docker图形化管理界面-Shipyard
欢迎关注大数据和人工智能技术文章发布的微信公众号:清研学堂,在这里你可以学到夜白(作者笔名)精心整理的笔记,让我们每天进步一点点,让优秀成为一种习惯! Shipyard是一款开源的图形化的Docker管理工具,记得以前安装很麻烦的,现在官方有了自动安装脚本,使用非常方便。复制、粘贴、使用,就这么简单。先不研究他是如何实现的,安装使用起来再说。 $curl -s https://shipyard-project.com/deploy | bash -s Deploying Shipyard-> Starting Database-> Starting Discovery-> Starting Cert Volume-> Starting Proxy-> Starting Swarm Manager-> Starting Swarm Agent-> Starting ControllerWaiting for Shipyard on 192.168.2.xxx:8080..Shipyard available at http://192.168.2...
相关文章
文章评论
共有0条评论来说两句吧...