我在 php 中遇到 tmux/screen 问题。
当我尝试启动 screen session 时,没有任何反应。
当我尝试启动 tmux session 时,它只有在我提供 www-data shell 访问权限时才有效,即使这样也没有添加任何窗口:(
我想要实现的目标:
我想为我在虚拟机上运行的一些进程编写一个网络界面。
为此,我编写了一些脚本(因为我在 linux debian 机器上,所以在 bash 中)。
这些脚本需要做一些事情:
- 启动一个新的 tmux 窗口(以及 session ,如果它尚不存在)
- 查看 tmux 窗口是否正在运行/事件
- 停止进程(自动关闭窗口)
并手动(在终端中)执行这些脚本的行为符合预期。
现在 web 界面将启动这些脚本(因此它们通过 php 中的 exec 函数执行)。
因为它们是通过 php 运行的,所以它们以用户 www-data 的身份运行,所以我无法访问由 www-data 创建的 tmux session 。
所以我在启动窗口/ session 时有一些建议:
我有一个命名 session
tmux new-session -s $SessionName
因为它是从 php 启动的,所以需要分离启动
tmux new-session -d -s $SessionName
我希望能够以 super 用户身份访问 session --> 我必须定义一个套接字位置
tmux -S $SocketLocationPath new-session -d -s $SessionName
所以我的命令最后看起来像这样:
tmux -S /tmp/pairedsession.socket new-session -d -s "ProcessGroup1"
此命令的问题:
在没有 shell 访问的情况下,此命令返回无法连接到服务器(这很奇怪,因为新 session 通常应该启动服务器)
具有 shell 访问权限(出于安全原因我不喜欢这种方式)但是 session 的创建完全按照我的意愿
但还是存在一些问题:
正如我之前所说,我想创建一些窗口来处理进程
命令看起来像这样:
tmux -S $SocketLocationPath new-window -t "$SessionName" -n "$WindowName" "$cmd"
这只适用于全局进程(如 htop)或 php 目录中的进程(如其他脚本)
我想做的是在它自己的工作目录中执行一个进程,该目录不一定在 php 目录中 --> 我如何更改它
我尝试过的
- 将 2>&1 添加到每个调试命令 --> 没有帮助
- 创建没有 SocketLocation 的 session
- 从 screen 切换到 tmux,因为它的语法更简单
让 www-data 访问 shell
sudo chsh -s/bin/sh www-data
在 php 中使用 shell_exec、passthrough 和 exec 函数
- 使用带 -dmS 选项的 screen
可能的解决方案
- 授予 www-data shell 访问权限(安全风险?)或者可能限制对 tmux 的访问,但是如何?
- 禁用 phps 设置以仅执行 php 目录中的文件(安全风险?)
- 给我添加一些无需 shell 也能工作的未知 tmux 选项 :D
更改一些 php 设置以仅允许某些目录或者这是否值得?
做一些完全不同的事情???
另一个奇怪的事情:当通过 php 启动 tmux session 时,终端没有用户也没有位置
通常它看起来像 user@machinename$ ...
对于 php,它看起来就像 $ ... 仅此而已
我希望有人能帮助我,因为我只是不喜欢这些凌乱的解决方法:/
提前致谢 - super 模糊
最佳答案
经过一番挣扎,在 googleguy@freenode#php 的帮助下,我终于战胜了它。
事实证明,PHP 7.1(在我的例子中)根本没有这样的问题。
我成功执行了这个序列:
shell_exec("tmux new-session -s session_name -d");
shell_exec("tmux send -t session_name gedit ENTER");
戳我它对你不起作用
关于PHP tmux 和 screen 行为不正确(没有启动,没有新 session ,没有新窗口),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30714276/