AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 681398
Accepted
php_nub_qq
php_nub_qq
Asked: 2021-12-15 02:54:53 +0800 CST2021-12-15 02:54:53 +0800 CST 2021-12-15 02:54:53 +0800 CST

如何以另一个用户身份运行 X 应用程序(vscode)

  • 772

基本上我想要的是运行 vscode 而不授予它读取我的主目录的权限。

所以我创建了一个新用户并从https://code.visualstudio.com/#alt-downloadsvscode下载了.tar.gz文件

现在我正在尝试以我的code身份vscode登录,如下所示:

~$ su - vscode -c "/home/vscode/code-stable-x64-1638855856/VSCode-linux-x64/bin/code --verbose"
Password: 
[8347:1214/125108.021461:ERROR:browser_main_loop.cc(1402)] Unable to open X display.
The futex facility returned an unexpected error code.
/dev/fd/3: No such file or directory
Server response:

我也尝试使用ssh -Y vscode@localhost然后code从内部开始,这很有效,但我想尽可能避免使用 ssh。

debian x11
  • 2 2 个回答
  • 487 Views

2 个回答

  • Voted
  1. Best Answer
    Marcus Müller
    2021-12-15T08:57:21+08:002021-12-15T08:57:21+08:00

    你需要

    1. 正确设置$DISPLAY变量,
    2. 授予对~/.Xauthority文件的访问权限
    3. 在/tmp/.X11-unix目录中共享套接字

    请注意,一旦您与不同的客户端共享您的 X 服务器,它基本上与以您自己的用户身份运行程序相同,安全方面:客户端可以观察键盘、截屏、合成按键,而我不会如果 X11 协议中一些较少使用的功能(加载纹理?字体?)可能被滥用为远程文件阅读器,您会感到惊讶。不过,不是 X11 协议方面的专家。

    由于隔离非常弱,无论如何,您也可以在限制对主目录的访问方面不那么复杂:容器。

    Linux 有命名空间,docker、kubernetes、snap 等技术都依赖于它。您可以做的是以普通用户的身份启动一个进程,并为该进程提供用户和文件系统环境的完整视图 - 一个没有您的主目录的视图。

    Podman 是这些技术之一,它在 debian、IIRC 上可用。安装它应该尽可能简单:

    sudo apt install -y podman
    

    然后,您应该能够运行容器:

    podman run -it --rm debian:sid
    #       |   |   |    |
    #       +--------------- Run subcommand: run a container
    #           |   |    |
    #           +----------- interactive, i.e., assign a virtual terminal, 
    #               |    |   so you can see and type into an interactive session
    #               |    |
    #               +------- Remove the container after you're done - no data survives,
    #                    |   if it's only in the container. Of course, things on 
    #                    |   volumes specified using the -v source_path:destination
    #                    |   persist, since they are "outside".
    #                    |
    #                    +-- name:tag is the way to specify what
    #                        container you want to fetch in which version
    
    

    要运行图形化的东西,你需要允许上面提到的事情,并告诉 SELinux 你已经完成了你承诺的事情:

    podman run -e DISPLAY=$DISPLAY \
                -v /tmp/.X11-unix:/tmp/.X11-unix:Z \
                 -v ~/.Xauthority:/root/.Xauthority:Z \
                  --security-opt label=type:container_runtime_t \
                   -it --rm fedora:35
    #           ||||
    #           +---- -e INSIDE=OUTSIDE  set an env variable INSIDE inside the
    #            |||     container to the value OUTSIDE
    #            ||| 
    #            +--- -v SOURCE:DEST[:permissions]
    #             ||     SOURCE directory or file appears under DEST within
    #             ||     container; :Z means that the podman-running users'
    #             ||     permissions are translated to root permissions inside.
    #             ||     Here, mount the host's X11 socket directory at the same place
    #             ||
    #             +-- -v SOURCE:DEST[:permissions] again
    #              |     Here, mount the podman-running user's ~/.Xauthority
    #              |     as /root/.Xauthority owned by root.
    #              |     
    #              +- --rm -it: see above     
    [root@4da385540218 /]#
    

    看看你是如何突然在一个你自己启动的容器中成为 root 的——作为非 root!

    我们现在可以将 vscode 安装到这个容器中,~/sourcecode像/sourcecode在容器中一样共享您的文件夹,并将其用作 vscode 的用户数据目录:

    podman run -e DISPLAY=$DISPLAY \
               -v /tmp/.X11-unix:/tmp/.X11-unix:Z \
               -v ~/.Xauthority:/root/.Xauthority:Z \
               --security-opt label=type:container_runtime_t \
               -v ~/sourcecode:/sourcecode:Z \
               -it --rm fedora:35
    [root@4da385540218 /]#
     rpm --import https://packages.microsoft.com/keys/microsoft.asc
    [root@4da385540218 /]#
     echo -e "[code]\nname=Visual Studio Code\nbaseurl=https://packages.microsoft.com/yumrepos/vscode\nenabled=1\ngpgcheck=1\ngpgkey=https://packages.microsoft.com/keys/microsoft.asc" > /etc/yum.repos.d/vscode.repo
    [root@4da385540218 /]#
     dnf --refresh update -y
    [root@4da385540218 /]#
     dnf install -y code
    [root@4da385540218 /]#
     code --user-data-dir /sourcecode/ --no-sandbox
    
    • 1
  2. Duarte
    2022-03-26T03:42:07+08:002022-03-26T03:42:07+08:00

    你是怎么做这些步骤的?正确设置 $DISPLAY 变量,授予对 ~/.Xauthority 文件的访问权限,共享 /tmp/.X11-unix 目录中的套接字

    我是 ubuntu 新手,不知道这意味着什么或如何做到这一点。我安装了代码,昨天我能够打开它,今天我不能。当我输入代码 --verbose 时,它​​显示“无法打开 X 显示器。futex 工具返回了意外的错误代码。/dev/fd/3:没有这样的文件或目录”,这就是我在这里结束的方式。我在 ubuntu 20.04

    • 0

相关问题

  • GRUB 配置以识别同一 Linux 发行版的不同桌面环境(安装)

  • astyle 不会更改源文件格式

  • 接收有关全新 Debian 的电子邮件

  • Debian Stretch:libgs_plugin_systemd-updates.so 中的 gnome-software 段错误

  • 如何在拼音输入法中输入ü?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve