百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

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

wptr33 2024-12-11 17:30 27 浏览

上次我们给大家介绍了一个很酷的,相对比较直观和易于使用的终端客户端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详细命令的用户会有很大帮助。

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...