论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
IT评测·应用市场-qidao123.com
»
论坛
›
主机系统
›
linux
›
在shell脚本中为日志添加颜色
在shell脚本中为日志添加颜色
莱莱
金牌会员
|
2025-1-13 04:50:59
|
显示全部楼层
|
阅读模式
楼主
主题
993
|
帖子
993
|
积分
2979
在 Shell 脚本中,可以通过添加 ANSI 转义序列来为日志输出添加颜色。以下是一个完备的 Shell 脚本示例,包含日志颜色定义、日志函数封装以及使用示例:
完备脚本:colored_logs.sh
#!/bin/bash
# 定义颜色变量
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[0;33m'
BLUE='\033[0;34m'
NC='\033[0m' # 无颜色(重置颜色)
# 日志函数封装
log_error() {
echo -e "${RED}[ERROR] $1${NC}"
}
log_warn() {
echo -e "${YELLOW}[WARN] $1${NC}"
}
log_info() {
echo -e "${GREEN}[INFO] $1${NC}"
}
log_debug() {
echo -e "${BLUE}[DEBUG] $1${NC}"
}
# 示例函数,模拟一些操作
example_function() {
log_info "开始执行示例函数..."
log_debug "这是一个调试信息,通常用于详细日志。"
# 模拟一个操作
if [[ $1 == "error" ]]; then
log_error "操作失败,模拟错误场景。"
else
log_info "操作成功完成。"
fi
log_warn "这是一个警告信息,表示需要注意的情况。"
}
# 主脚本逻辑
main() {
log_info "脚本启动..."
# 调用示例函数
example_function "success"
example_function "error"
log_info "脚本结束。"
}
# 执行主函数
main
复制代码
脚本说明
颜色定义
:
使用 ANSI 转义序列定义了几种常见颜色(红色、绿色、黄色、蓝色)。
NC 用于重置颜色,避免后续文本被着色。
日志函数
:
log_error:输出红色错误日志。
log_warn:输出黄色告诫日志。
log_info:输出绿色信息日志。
log_debug:输出蓝色调试日志。
示例函数
:
example_function 模拟了一个操作,根据传入的参数决定是否模拟错误场景。
在函数中使用了不同的日志函数来记录不同级别的日志。
主函数
:
main 函数是脚本的入口,调用示例函数并输出日志。
实行脚本
:
脚本末了调用 main 函数来启动逻辑。
运行脚本
将脚本保存为 colored_logs.sh。
赋予脚本实行权限:
chmod +x colored_logs.sh
复制代码
运行脚本:
./colored_logs.sh
复制代码
输出示例
运行脚本后,您将看到类似以下的彩色输出:
注意事项
终端支持
:
确保您的终端支持 ANSI 颜色代码。大多数当代终端(如 Linux 终端、macOS Terminal、Windows Terminal)都支持。
日志级别
:
您可以根据必要调解日志级别,比方在生产环境中禁用 DEBUG 日志。
扩展功能
:
可以将日志输出重定向到文件,或者添加时间戳等功能。
通过这种方式,您可以为 Shell 脚本中的日志输出添加颜色,使其更易于阅读和区分。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
回复
使用道具
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
莱莱
金牌会员
这个人很懒什么都没写!
楼主热帖
SQL的约束
HCIA-OSPF协议
mac Error: EACCES: permission denied ...
MySQL 隐式类型转换导致索引失效问题 ...
你选对了超融合,可能却买错了交换机! ...
红标devcpp6.3编译器下载及配置教程 ...
MySQL实战45讲 9
攻防世界web 难度1新手练习
每日一练 数据库linux安装
老妈问我什么是超融合,我是这么和她解 ...
标签云
运维
CIO
存储
服务器
浏览过的版块
SAP
人工智能
运维.售后
数据仓库与分析
主机安全
边缘计算
网络安全
Java
分布式数据库
备份
快速回复
返回顶部
返回列表