最简单的方法就是让 docker 容器中的 xclient 应用直接使用主机上的 Xserver 就好了。
步骤上就两步
1、放开权限,允许本地连接
- xhost +local:
-
2、将 /tmp/.X11-unix 共享到容器中
- docker run -it --rm -v /tmp/.X11-unix:/tmp/.X11-unix ${docker_image}
-
当然,你也可以在放开权限时指定容器主机名/或者在运行容器时指定与主机相同的名称,这样会安全一些,只是步骤上会麻烦一点
- xhost +local:$(docker inspect --format='{{ .Config.Hostname }}' $containerId)
- docker start $containerId
-
或
- docker run -e DISPLAY=$DISPLAY -v /tmp/.X11-unix:/tmp/.X11-unix --hostname=$HOSTNAME -v $HOME/.Xauthority:/root/.Xauthority -it --rm ${docker_image}
-
X11 server 需要有一种途径来跟 X11 client 来进行沟通。 在网络上它们可以通过 TCP/IP Socket 来实现沟通,而在本机上它们通过一个 Unix-domain socket 来沟通。
Unix-domain socket 其实很 TCP/IP socket 很类似,只不过它指向的是一个文件路径,而且无需通过网卡进行转发,因此相对来说更安全,更更快些。
而 /tmp/.X11-unix 其实就是存放这些 Unix-domain Socket 的地方。
一般来说 /tmp/.X11-unix 下面只会有一个 Unix-domain Socket(因为一般只有一个 Xserver 在运行),但若系统同时运行多个 Xserver,也可能会有多个 Unix Domain Socket 出现的情况。
- ls -l /tmp/.X11-unix
-
- 总用量 0
- srwxrwxrwx 1 lujun9972 lujun9972 0 4月 24 09:18 X0
-
注意到 X0 前面的 s ,说明它是一个 socket 文件。我们可以使用 lsof -U 来查看有那些进程在使用这个 Unix-domain Socket
- lsof -U /tmp/.X11-unix/X0 |cut -f1 -d " " |uniq
-
- COMMAND
- systemd
- xinit
- Xorg
- awesome
- fcitx
- udiskie
- python2
- dbus-daem
- fcitx-dbu
- java
- gvfsd
- gvfsd-fus
- at-spi-bu
- dbus-daem
- at-spi2-r
- emacs
- firefox
- Web\x20Co
- gconfd-2
- Web\x20Co
- urxvt
- pulseaudi
-