TTY 터미널에 터미널 명령을 보내는 방법


8

실행 된 명령을 TTY 터미널에 보내는 방법을 찾고 있습니다. 예를 들어, 우리는 내가 열라고하자 그놈 터미널 및 윈도우 I 형에 sudo aptitude update && sudo aptitude upgrade.

TTY7 GUI 환경에서 작업하지 않고 TTY 터미널로 어떻게 보낼 수 있습니까?

답변:


7

직접하지는 않지만 tmux와 같은 터미널 멀티플렉서를 중간에 사용하는 것이 좋습니다.

터미널에서 식별자와 함께 start tmux 명령을 수신해야합니다.

tmux new-session -s MYSES

다음을 사용하여 명령을 보내십시오.

tmux send-keys -t MYSES "sudo aptitude update && sudo aptitude upgrade"$'\n'

byobu를 사용하면 이것도 효과가 있습니다! 이미 이름을 모르는 세션이 실행 중이면 -t MYSES를 삭제할 수 있습니다. Thnx!
ExploWare

10

이것은 도움이되는 프로그램입니다 :

#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <sys/ioctl.h>
#include <string.h>
#include <unistd.h>

void print_help(char *prog_name) {
        printf("Usage: %s [-n] DEVNAME COMMAND\n", prog_name);
        printf("Usage: '-n' is an optional argument if you want to push a new line at the end of the text\n");
        printf("Usage: Will require 'sudo' to run if the executable is not setuid root\n");
        exit(1);
}

int main (int argc, char *argv[]) {
    char *cmd, *nl = "\n";
    int i, fd;
    int devno, commandno, newline;
    int mem_len;
    devno = 1; commandno = 2; newline = 0;
    if (argc < 3) {
        print_help(argv[0]);
    }
    if (argc > 3 && argv[1][0] == '-' && argv[1][1] == 'n') {
        devno = 2; commandno = 3; newline=1;
    } else if (argc > 3 && argv[1][0] == '-' && argv[1][1] != 'n') {
        printf("Invalid Option\n");
        print_help(argv[0]);
    }
    fd = open(argv[devno],O_RDWR);
    if(fd == -1) {
        perror("open DEVICE");
        exit(1);
    }
    mem_len = 0;
    for ( i = commandno; i < argc; i++ ) {
        mem_len += strlen(argv[i]) + 2;
        if ( i > commandno ) {
            cmd = (char *)realloc((void *)cmd, mem_len);
        } else { //i == commandno
            cmd = (char *)malloc(mem_len);
        }

        strcat(cmd, argv[i]);
        strcat(cmd, " ");
    }
  if (newline == 0)
        usleep(225000);
    for (i = 0; cmd[i]; i++)
        ioctl (fd, TIOCSTI, cmd+i);
    if (newline == 1)
        ioctl (fd, TIOCSTI, nl);
    close(fd);
    free((void *)cmd);
    exit (0);
}

위 코드를 일부 C 파일 (예 : ttyecho.c)에 복사하십시오. C 파일을 작성한 디렉토리에서 다음 명령을 실행하여 코드를 컴파일하십시오.

make ttyecho

이 파일을 홈 디렉토리 아래의 bin 디렉토리로 복사하십시오. 디렉토리가 없으면 작성하십시오. 이 사용자 정의 바이너리 / 실행 파일을이 bin 디렉토리에 보관하는 것이 좋습니다.

tty 명령을 제어하고 실행하려는 다른 터미널을 시작하거나 열려있는 다른 터미널로 전환하십시오. 아래에서 샘플 출력을 볼 수 있습니다.

@~$ tty

/ dev / pts / 5

지금의 명령을 실행 은 / dev / 점 / 5 , 지배 / 원래 터미널에서 다음 명령을 실행합니다.

sudo ttyecho -n /dev/pts/5 ls

ls 명령이 / dev / pts / 5 에서 실행되는 것을 볼 수 있습니다. -n 옵션은 명령 방금 삽입 한 실행하지 가도록 (듯이), 명령 후 개행 문자를 보내 ttyecho 있습니다. 이 유틸리티는 실제로 다른 터미널로 데이터를 전송하는 데 사용될 수 있습니다. 예를 들어, / dev / pts / 5 에서 vim을 연 다음 제어 터미널에서 다음 명령을 실행하여 vim이 / dev / pts / 5 에서 종료되도록 할 수 있습니다 .

sudo ttyecho -n /dev/pts/5 :q

항상 sudo를 사용하지 않고 명령을 쉽게 스크립팅 할 수있게하려면 다음 명령을 사용하여이 실행 파일의 소유자 / 권한을 변경하십시오.

sudo chown root:root ttyecho
sudo chmod u+s ttyecho

주의 : setuid 비트를 설정하면 보안 위험이 발생할 수 있습니다.

출처 : http://www.humbug.in/2010/utility-to-send-commands-or-data-to-other-terminals-ttypts/

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.