Can I alias a subcommand? (shortening the output of `docker ps`)

后端 未结 3 747
别那么骄傲
别那么骄傲 2020-11-27 20:52

The docker command has a ps sub-command that emits very long lines:

$ docker ps -a
CONTAINER ID        IMAGE                                


        
相关标签:
3条回答
  • 2020-11-27 20:57

    You can wrap docker in a function that checks for the specific subcommand and passes everything else through. (The below will actually work with not just zsh, but any POSIX-compliant shell -- a category to which zsh doesn't quite belong).

    docker() {
      case $1 in
        ps)
          shift
          command docker ps --format 'table {{.Image}}\t{{.Names}}\t{{.Ports}}\t{{.Status}}' "$@"
          ;;
        *)
          command docker "$@";;
      esac
    }
    

    If you wanted a more generic wrapper function (that doesn't need to know about your specific desired ps logic), that could be done as follows (note that this version is not compatible with baseline POSIX sh due to its use of local; however, this is an extension implemented even by ash and its derivatives):

    docker() {
      local cmd=$1; shift
      if command -v "docker_$cmd" >/dev/null 2>/dev/null; then
        "docker_$cmd" "$@"
      else
        command docker "$cmd" "$@"
      fi
    }
    

    ...after which any subcommand can have its own functions defined, without the wrapper needing to be modified to know about them (you could also create a script in the PATH named docker_ps, or provide the command in any other manner you choose):

    docker_ps() {
      command docker ps --format 'table {{.Image}}\t{{.Names}}\t{{.Ports}}\t{{.Status}}' "$@"
    }
    
    0 讨论(0)
  • 2020-11-27 21:02

    You can alias subcommands. With aliasing, you still get the nice zsh completions as if you were typing the full command. That's why I prefer them over functions.

    The equivalent of your alias is:

    alias dp='docker ps --format "table {{.Image}}\t{{.Names}}\t{{.Ports}}'\t{{.Status}}"
    

    But the full commands seem to now be recommended, and ls has replaced ps, which makes your alias now:

    alias dp='docker container ls --format "table {{.Image}}\t{{.Names}}\t{{.Ports}}'\t{{.Status}}"
    

    It's nice to have docker aliases for everything. For this, I've been working on a set of comprehensive aliases, which would have your alias as something like:

    alias ddcls='docker container ls --format "table {{.Image}}\t{{.Names}}\t{{.Ports}}\t{{.Status}}"
    
    0 讨论(0)
  • 2020-11-27 21:22

    Using Docker Config

    Since this is fundamentally a docker questions, not a bash question, you don't even need an alias. Docker CLI allows you to customize these commands in your own config file! From this great tip from Container 42:

    1. Create or find your docker config file (if you've ever used docker login it should already be created.

      ~/.docker/config.json
      
    2. Then add the default formatting for docker to use every time it runs the ps command as a top level property in the config:

      {
          "psFormat": "table {{.Image}}\t{{.Names}}\t{{.Ports}}\t{{.Status}}",
      }
      
    3. Then just run docker ps like normal:

    PS Format

    Docker uses go templates and has a list of the valid placeholders:

    | Command      | Description                                       |
    | ------------ | ------------------------------------------------- |
    | .ID          | Container ID                                      |
    | .Image       | Image ID                                          |
    | .Command     | Quoted command                                    |
    | .CreatedAt   | Time when the container was created.              |
    | .RunningFor  | Elapsed time since the container was started.     |
    | .Ports       | Exposed ports.                                    |
    | .Status      | Container status.                                 |
    | .Size        | Container disk size.                              |
    | .Names       | Container names.                                  |
    | .Labels      | All labels assigned to the container.             |
    | .Label       | Value of a specific label for this container.     |
    | .Mounts      | Names of the volumes mounted in this container.   |
    | .Networks    | Names of the networks attached to this container. |
    

    Alternative Solutions / Threads

    • Github Issues
      • Default "docker ps" output is too wide
      • docker ps output is so long it's unreadable
    • Third Party Commands
      • ctop - Top-like interface for container metrics
      • docker-pretty-ps - beautiful, colored, long output log
      • dockerps - A better docker ps
    0 讨论(0)
提交回复
热议问题