- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在尝试使用/proc/{pid}/fd/0 向 minecraft 服务器 jar 发送命令,但服务器不执行该命令。
要复制我正在尝试做的事情,您可以在基于 Debian 的机器上执行此操作(也可能是其他 Linux 发行版)。
我用什么来测试这个:
第一个控制台:
$ java -jar minecraft_server.jar nogui
响应:[ ... 服务器启动并等待输入]
say hi
响应:[19:52:23] [服务器线程/信息]:[服务器] 嗨
第二个控制台:
现在,当我切换到第二个控制台时,服务器仍在第一个控制台中运行,我写道:
echo "say hi2" >> /proc/$(pidof java)/fd/0
在我切换回第一个控制台之前,一切看起来都很好。我可以看到文本“say hi2”,但服务器尚未识别它。我可以在第一个控制台中再次编写另一个命令,就好像从第二个控制台输入的文本根本不存在一样。
这是为什么?更重要的是,如何以正确的方式使用/proc/{pid}/fd/0 将命令发送到 java jar 文件?
我不知道这是否是我不知道的某种 Java 事物,我是否可以在执行服务器时使用一些标志或其他东西,或者问题是否出在服务器 jar 本身上。 .
我知道您可以使用 screen、tail -f 或某种服务器包装器来完成此操作,但这不是我想要的。我想以某种方式使用此方法发送命令。
最佳答案
这不是 Java 的事情。您正在尝试的根本不可行。
这样测试:
控制台 1:
$ cat
这基本上会在您点击“返回”后立即回显您在其上键入的任何内容。
控制台 2:找到您的 cat
命令的进程号。假设它是 NNN。做:
$ echo Something > /proc/NNN/fd/0
切换回控制台 1。您会在控制台输出中看到“Something”,但没有回显。
为什么?做
$ ls -l /proc/NNN/fd
你可能会明白。所有三个描述符,0 代表 stdin
,1 代表 stdout
和 2 代表 stderr
实际上是符号链接(symbolic link),并且都指向同一个伪终端从属( pts) 设备,这是与您的第一个终端关联的 pts。
所以基本上,当你写入它时,你实际上写入了控制台输出,而不是它的输入。如果您从该文件中读取,您可能会窃取一些本应进入第一个控制台中的进程的输入(您正在争夺此输入)。这就是字符设备的工作原理。
/proc 的文档说:
/proc/[pid]/fd/
This is a subdirectory containing one entry for each file which the process has open, named by its file descriptor, and which is a symbolic link to the actual file. Thus, 0 is standard input, 1 standard output, 2 standard error, and so on.
所以这些不是进程打开的实际文件描述符。它们只是指向文件(或在本例中为字符设备)的链接,其名称表明它们在给定进程中附加到哪个描述符。它们的主要职责是告诉您进程是否已重定向其文件描述符或是否打开了任何新文件描述符,以及它们指向哪些资源。
但是如果您想要一种替代方法,您可以使用 fifo
- 命名管道。
通过以下操作创建一个 fifo:
$ mkfifo myfifo
运行你的java程序:
$ java -jar minecraft_server.jar nogui < myfifo
打开另一个控制台。写
$ cat > myfifo
现在开始输入内容。切换到第一个控制台。您会看到您的服务器正在执行您的命令。
不过,请注意您的文件结尾。多个进程可以写入同一个 fifo
,但一旦最后一个进程关闭它,您的服务器将在其标准输入上收到 EOF。
关于java - 使用标准输入通过/proc/{pid}/fd/0 向 java -jar 发送命令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26765035/
manpage of reboot()说 Behavior inside PID namespaces Since Linux 3.4, if reboot() is called from a PI
我今天第一次在 Nvidia jetson Xavier 中安装和配置并使用了电视, 但重启后我遇到了这个问题: teamviewerd.service: 启动后无法打开 PID 文件/var/run
我在我的服务器上安装了 hhvm,在我重新启动服务器之前它一直运行良好。在 hhvm 的日志中,我看到了这个错误: Unable to read pid file /var/run/hhvm/pid
我正在尝试为我的应用程序精简,但随后无法生成 pid: $ thin -C /var/www/project_path/current/config/myproject.testing.yml sta
我正在从我的私有(private) git 存储库安装应用程序。我安装了所有依赖项并且我正在使用 Capistrano。我能够在我的本地计算机上成功运行应用程序。我正在使用 rails -v 3.2.
我已按照 DigitalOcean 指南中的步骤进行操作 here和 here使用 nginx 和 Unicorn 设置 Sinatra 服务器。我在倒数第二步: start the Unicorn
我在 C 程序中连续进行了 3 个 fork 。 1.它会以相同的顺序执行吗? (我的猜测是肯定的)。 2. 如果我做 pgrep myexecutable从 shell 中,它会按照启动的顺序给出进
我尝试通过FT_Prog更改FTDI芯片(R232R)中的PID。它可以工作,但之后我发现 Windows 7 自动重新安装 USB 设备的驱动程序,而不是 FTDI 设备。所以我想将PID改回默认值
第一次在这里发表 简单情况:在 PUTTY 中,我必须创建一个名为 admin.pid 的文件,当用户启动我正在创建的“应用程序”时,它会在其中存储 PID。我怎样才能做到这一点?谢谢 最佳答案 使用
我设法为每个单独的进程输出正确的进程 ID 顺序,但我的问题是我无法显示子进程的 PID。 我的程序能够打印 parent 的 PID 和孙子的 PID。我确实看到了 child 的 PID,但它显示
我正在从事一个项目,其中有许多 PID,我必须找出其中哪些是僵尸进程,然后终止它们的父进程以终止初始僵尸进程。我不确定是否有任何方法可以找出给定 PID 的 PPID 是什么。任何帮助将不胜感激。 最
我正在使用 htop,所以看看哪些进程占用了大量内存,以便我可以杀死它们。我有很多 tmux session 和很多类似的过程。如何检查 PID 所在的 tmux Pane ,以便确定我正在杀死我想杀
我正在通过运行跟踪应用程序: strace -f -y -qq -z -etrace=execve,... -o app.trace ./app 有没有办法确定哪个进程产生了哪个 child_proc
在我使用 exec 之后docker 容器内的命令我可以使用 exec inspect 获取 PID .问题是这个 ID 不是容器本地的,而是系统 PID。所以我会得到类似 22620 的东西,而 d
我有一个我开发的用于启动 Java 程序的 System V 初始化脚本。由于某种原因,无论何时创建 PID 文件,它都包含多个 PID 而不是一个。 下面是启动服务并写入PID文件的相关代码: da
我有一个变量 pidfile,它存储进程的 PID。 如何使用 Ruby 以编程方式终止 pidfile 中的 pid,假设我只知道文件名,而不是其中的实际 PID。 最佳答案 Process.kil
我读入了Beej's fork() primer当我调用 pid = fork(); 时,父进程获取子进程的 pid,而在子进程内部 pid = 0。 现在,由于子进程开始执行 在 fork() 语句
我正在尝试从另一个 Python 脚本运行一个 Python 脚本,并获取它的 pid 以便稍后可以终止它。 我尝试使用参数 shell=True' 的 subprocess.Popen(),但是pi
我有一个用 Cygwin 生成的进程shell 脚本,我无法用 kill 杀死它命令。即使与 Cygwin kill与 -f选项,我收到此消息: kill: couldn't open pid 123
我尝试在我的模型中为阀门构建一个 PID Controller ,我计划进行一些过程识别,获得系统对阶跃脉冲的响应和系统的传递函数,然后我可以设计 PID Controller 。但我不确定是否有用于
我是一名优秀的程序员,十分优秀!