优秀的编程知识分享平台

网站首页 > 技术文章 正文

Lazy系列:另一个很酷的终端界面工具lazydocker

nanyue 2025-01-06 14:42:47 技术文章 5 ℃

上次我们给大家介绍了一个很酷的,相对比较直观和易于使用的终端客户端lazygit,其实上lazyxx是一个系列工具。日常我们除了git用得多以外,docker也是常用的,本文我们就介绍该系列有一个高star工具lazydocker。

Docker很好用,docker命令难记!如果集中在一个终端窗口展示所有的docker容器信息,然后通过快捷键切换各个部分的信息会很有帮助。这就lazydocker 所实现的功能。和lazygit一样,lazydocke是一个简单的docker和docker-compose终端UI,基于gocui用Golang语言编写。

功能特点

lazydocker中,可以一键切换面板信息,能展示:

一目了然地查看docker或docker-compose容器环境的运行状态;

查看容器/服务的日志;

查看容器各个指标的scii图表,炫酷而且又非常直观。

可以自定义要展示的指标生成图表。

附加到容器/服务。

重新启动/删除/重建容器/服务。

查看给定镜像的层次和继承关系。

调整占用磁盘空间的容器、镜像或卷。

安装部署

Lazydocker软件对docker的版本有要求:

Docker >= 1.13 (API >= 1.25

Docker-Compose >= 1.23.2 (可选)

二进制包

目前Lazydocker最新版本为0.12,各个平台的二进制包和源码都可以通过其github仓库的发布页面下载。

请务必使用checksums.txt提供的哈希值校对安装包,确保没有被篡改。

Homebrew

Lazygit也支持使用homebrew包管理器安装:

brew install jesseduffield/lazygit/ lazydocker

或者

brew install lazydocker

源码安装

本地机器上有golang环境的,可以直接获取源码安装:

git clone github/jesseduffield/lazydocker.git

cd lazydocker

go install

可以自己修改然后编译或者运行

go run main.go

使用

安装后在终端就可以直接用lazydocker使用。

启动,lazydocker就会自动连接docker api获得相关信息(当前用户必须要有docker api权限)。

为了方便,可以设置一个别称,比如

echo "alias dinfo='lazydocker'" >> ~/.bashrc

基本使用看下面的提示:

Pgup/PgDn: scroll,b: view bulk commands,esc/q: close,x: menu,->

基本可以简单地使用了 ,esc或者q可以推出界面,x可以弹出命令菜单,进行更多的操作。

个性化配置

Lazydocker完全支持个性化定制,支持定义快捷键、定义配色、自定义显示git命令内容等。其配置在不同平台是不同目录通过config.yml配置文件。

OSX: ~/Library/Application Support/jesseduffield/lazydocker/config.yml
Linux: ~/.config/jesseduffield/lazydocker/config.yml
Windows: C:\\Users\\<User>\\AppData\\Roaming\\jesseduffield\\lazydocker\\config.yml

默认配置项为:

ui:
scrollHeight: 2
language: 'auto' # one of 'auto' | 'en' | 'pl' | 'nl' | 'de' | 'tr'
theme:
activeBorderColor:
- green
- bold
inactiveBorderColor:
- white
optionsTextColor:
- blue
returnImmediately: false
wrapMainPanel: false
reporting: undetermined
commandTemplates:
dockerCompose: docker-compose
restartService: '{{ .DockerCompose }} restart {{ .Service.Name }}'
stopService: '{{ .DockerCompose }} stop {{ .Service.Name }}'
serviceLogs: '{{ .DockerCompose }} logs --since=60m --follow {{ .Service.Name }}'
viewServiceLogs: '{{ .DockerCompose }} logs --follow {{ .Service.Name }}'
rebuildService: '{{ .DockerCompose }} up -d --build {{ .Service.Name }}'
recreateService: '{{ .DockerCompose }} up -d --force-recreate {{ .Service.Name }}'
viewContainerLogs: docker logs --timestamps --follow --since=60m {{ .Container.ID
}}
containerLogs: docker logs --timestamps --follow --since=60m {{ .Container.ID }}
allLogs: '{{ .DockerCompose }} logs --tail=300 --follow'
viewAlLogs: '{{ .DockerCompose }} logs'
dockerComposeConfig: '{{ .DockerCompose }} config'
checkDockerComposeConfig: '{{ .DockerCompose }} config --quiet'
serviceTop: '{{ .DockerCompose }} top {{ .Service.Name }}'
customCommands:
containers:
- name: bash
attach: true
command: "docker exec -it {{ .Container.ID }} /bin/sh -c 'eval $(grep ^$(id -un): /etc/passwd | cut -d : -f 7-)'"
serviceNames: []
oS:
openCommand: open {{filename}}
openLinkCommand: open {{link}}
update:
dockerRefreshInterval: 100ms
stats:
graphs:
- caption: CPU (%)
statPath: DerivedStats.CPUPercentage
color: blue
- caption: Memory (%)
statPath: DerivedStats.MemoryPercentage
color: green

可以自己基于默认配置做调整:打开lazydocker,单击左上角的“项目”面板,然后按“e”)。

lazydocker支持鼠标事件,所以需要在拖动鼠标时按住option以表明正在尝试选择文本而不是单击某些内容或者可以通过以下方式禁用鼠标事件 gui.ignoreMouseEvents配置值。。

默认情况下,只显示最后一小时的日志,这样免得对机器造成太大压力。第一次启动lazydocker时看不到日志的原因。 可以在配置

commandTemplates

如果在容器中运行lazydocker,这是一个已知错误,即看不到日志或CPU使用率。

总结

本文我们介绍了一个基于一个终端面板集中管理docker的软件,对于重度docker使用者,但是又不是很熟悉docker详细命令的用户会有很大帮助。

最近发表
标签列表