Ввод IP-адреса в командную строку

Ввод IP-адреса в командную строку

У меня есть следующий запутанный метод для инъекции IP-адреса на экземпляре ec2 в командную строку. Он работает, но имеет некоторые очевидные проблемы, и я ищу хороший способ их решить:

TOKEN=`curl -X PUT "http://169.254.169.254/latest/api/token" -H "X-aws-ec2-metadata-token-ttl-seconds: 21600"`
IP=`curl -H "X-aws-ec2-metadata-token: \$TOKEN" -v http://169.254.169.254/latest/meta-data/local-ipv4`

if [ "$color_prompt" = yes ]; then
    PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@$IP-\H\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ '
else
    PS1='$IP${debian_chroot:+($debian_chroot)}\u@$IP-\H:\w\$ '
fi

У моего метода есть несколько проблем, которые я хочу решить:

  1. При загрузке или входе в bash генерируется множество нежелательных сообщений:
Last login: Thu Dec 17 16:57:37 2020 from 22.123.17.122
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100    56  100    56    0     0  11200      0 --:--:-- --:--:-- --:--:-- 11200
* Expire in 0 ms for 6 (transfer 0x560383dabf90)
*   Trying 169.254.169.254...
* TCP_NODELAY set
* Expire in 200 ms for 4 (transfer 0x560383dabf90)
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0* Connected to 169.254.169.254 (169.254.169.254) port 80 (#0)
> GET /latest/meta-data/local-ipv4 HTTP/1.1
> Host: 169.254.169.254
> User-Agent: curl/7.64.0
> Accept: */*
> X-aws-ec2-metadata-token: AQAAAEjtIasdfadfasdf5ksdjkjkkasdfe947xQ==
>
* HTTP 1.0, assume close after body
< HTTP/1.0 200 OK
< Accept-Ranges: bytes
< Content-Length: 12
< Content-Type: text/plain
< Date: Thu, 17 Dec 2020 22:52:25 GMT
< Last-Modified: Tue, 15 Dec 2020 14:11:17 GMT
< X-Aws-Ec2-Metadata-Token-Ttl-Seconds: 21600
< Connection: close
< Server: EC2ws
<
{ [12 bytes data]
100    12  100    12    0     0   2400      0 --:--:-- --:--:-- --:--:--  2400
* Closing connection 0
  1. Другая проблема в том, что это запускается каждый раз, когда я вхожу в bash или перезагружаю bash. Я хотел бы найти способ обойти это, если IP-адрес уже известен.

решение1

Вы специально запросили подробный вывод от curl во второй командной строке, которая составляет большую часть вывода. Вам следует удалить -v. Затем, чтобы отключить индикатор прогресса, используйте -s(в обеих командах). Это должно оставить вас без вывода, если только не возникнет ошибка.

Было бы лучше, если бы вы запустили это при запуске и записали полученный IP-адрес в файл, а затем просто прочитали содержимое этого файла в своем профиле bash. (Это предполагает, что IP-адрес не изменится во время работы экземпляра, чего, насколько мне известно, не происходит.)

Рассмотрим локальный сценарий запуска, подобный этому:

#!/usr/bin/env bash
TOKEN=`curl -s -X PUT -H "X-aws-ec2-metadata-token-ttl-seconds: 21600" http://169.254.169.254/latest/api/token`
curl -s -H "X-aws-ec2-metadata-token: \$TOKEN" -o /tmp/local-ipv4 http://169.254.169.254/latest/meta-data/local-ipv4

Теперь вы можете прочитать это в своем профиле bash:

IP=$(cat /tmp/local-ipv4)

Связанный контент