动态时针进度条

简介: 【4月更文挑战第29天】

》》》》》魏红斌带你学shell脚本《《《《《


更多shell脚本学习点击个人主页


作为一个资深程序猿,我将带领您从零开始,一步步踏上运维之旅,无论您是否拥有现成的服务器,都将学会如何轻松购买、部署,并通过编写及应用精心设计的Shell脚本,解决实际工作中遇到的问题。这些脚本不仅源自真实的业务场景,经历了反复实践与严格测试,确保了其简洁高效、易于理解且便于使用。更重要的是,我们将全程免费分享,并深度解析背后原理,助您深入理解并灵活运用,每一款脚本均经过真实业务场景的反复打磨与严格测试,秉持着简洁高效、易于理解和使用的理念设计,无偿提供并且提供相关解析过程,让读者能更深入了解相关内容

无服务器的朋友们

让我们先从选购并部署服务器开始。只需简单三步,即可拥有您的专属云服务器:

  1. 访问ECS官网:点击链接直达阿里云ECS网站:ECS选择网址。这是您获取高质量云服务器的第一站。
  2. 选择并购买:在琳琅满目的服务器配置中,挑选符合您需求的那一款,一键下单,完成支付。整个过程犹如在线购物般便捷。
  3. 进入ECS控制台:支付成功后,您将被引导至ECS管理控制台。在这里,您可以全面掌控您的服务器资源,后续的所有运维操作都将在此展开。

已有服务器的朋友们

如果您已拥有ECS实例,那么请直接登录ECS管理控制台在左侧导航栏中,依次选择“实例与镜像” > “实例”,确保您已定位到目标资源所在的资源组和地域。接下来,在实例列表中找到待连接的实例,点击操作列下的“远程连接”,选择“通过Workbench远程连接”并点击“立即登录”。

登录实例

无论是新购还是已有服务器,接下来都需要进行实例登录。这里支持多种认证方式,以最常见的“密码认证”为例:

  • 输入用户名(通常为rootecs-user)。
  • 接着,输入登录密码。如果您忘记了密码,无需担忧,您可以在ECS实例详情页面查询,或者通过“更改密码”功能进行修改。

编写与运行Shell脚本

成功登录后,您将看到一个熟悉的命令行界面——这就是您的运维主战场。现在,键入vim test.sh,我们便进入了文本编辑模式,准备创建第一个Shell脚本。

按下键盘上的i键,进入插入模式,此刻您可以自由地复制粘贴今天要学习的脚本代码,粘贴后按ecs后,按:wq保存脚本,可以用./ test.sh或者sh test.sh进行脚本执行。

今天我们要学习的脚本是(脚本内容直接复制粘贴即可):

#!/bin/bash

#定义一个显示进度的函数,屏幕快速显示| / ‐ \

rotate_line(){

INTERVAL=0.1 #设置间隔时间

COUNT="0" #设置4 个形状的编号,默认编号为0(不代表任何图像)

while :

do

COUNT=`expr $COUNT + 1` #执行循环,COUNT 每次循环加1,(分别代表4 中不同的形状)

case $COUNT in #判断COUNT 的值,值不一样显示的形状就不一样

"1") #值为1 显示‐

echo ‐e '‐'"\b\c"

sleep $INTERVAL

;;

"2") #值为2 显示\\,第一个\是转义

echo ‐e '\\'"\b\c"

sleep $INTERVAL

;;

"3") #值为3 显示|

echo ‐e "|\b\c"

sleep $INTERVAL

;;

"4") #值为4 显示/

echo ‐e "/\b\c"

sleep $INTERVAL

;;

*) #值为其他时,将COUNT 重置为0

COUNT="0";;

esac

done

}

rotate_line

下面是脚本的逐行解释:

  1. #!/bin/bash:这是一个 shebang,它告诉操作系统该脚本应由 Bash shell 执行。

2-4. #定义一个显示进度的函数,屏幕快速显示| / ‐ \:这是一条注释,用中文说明了函数的目的。

  1. rotate_line(){:定义了一个名为 rotate_line 的函数。
  2. INTERVAL=0.1:设置了一个变量 INTERVAL,其值为 0.1,表示每次循环之间的间隔是 0.1 秒。
  3. COUNT="0":初始化了一个变量 COUNT 并设置其值为 0。这个变量用于追踪当前应该显示哪个字符。
  4. while ::这是一个无限循环,: 是一个空命令,所以这个循环会一直运行直到被外部命令终止。
  5. COUNT=expr $COUNT + 1``:每次循环时,COUNT 的值都会增加 1。

14-28. case $COUNT in ... esac:这是一个 case 语句,它根据 COUNT 的值来决定显示哪个字符。

  • COUNT 的值为 1 时,显示字符 -
  • COUNT 的值为 2 时,显示字符 \。注意这里使用了 \ 来转义字符 \,因为在 Bash 中,\ 是一个特殊字符,所以需要使用 \\ 来表示一个实际的反斜杠字符。
  • COUNT 的值为 3 时,显示字符 |
  • COUNT 的值为 4 时,显示字符 /

如果 COUNT 的值不是 1、2、3 或 4,则 COUNT 的值会被重置为 0,从而重新开始循环。

  1. done:表示 while 循环的结束。
  2. rotate_line:这是调用 rotate_line 函数的命令。但由于它没有被放在任何条件或循环结构中,所以这会导致函数立即执行并无限循环下去,直到你手动终止脚本。

如果想上手操作练代码的同学们可以通过阿里云ecs服务器免费试用参与!

入口:新老同学免费试用

相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
8月前
|
前端开发 JavaScript 开发者
【QML进阶 进度条设计】打造动态弧形进度条特效
【QML进阶 进度条设计】打造动态弧形进度条特效
423 2
|
7月前
|
C# C++
C# 自定义时间进度条
本文作者通过参考leslie_xin的一篇文章,成功创建了一个自定义的WinForms控件——时间进度条,该控件带有时间刻度和多种可定制的属性,如颜色、时间间隔等。作者在控件中加入了开始和结束时间,以及自适应的时间刻度间隔。控件能根据设置显示时间标签,并提供了事件处理,如值改变时的触发。代码中包含了计算时间刻度、绘制刻度线和时间标签的逻辑。作者强调了避免循环调用事件、使用OnXXX()形式的事件处理函数以及注意自定义控件中的属性和事件设计。
153 7
|
8月前
【sgDragSize】自定义组件:自定义拖拽修改DIV尺寸组件,适用于窗体大小调整
【sgDragSize】自定义组件:自定义拖拽修改DIV尺寸组件,适用于窗体大小调整
|
编解码 前端开发
前端设置页面字体尺寸跟随屏幕大小而进行变化
前端设置页面字体尺寸跟随屏幕大小而进行变化
683 0
前端设置页面字体尺寸跟随屏幕大小而进行变化
|
开发者
导航控件调整与增加| 学习笔记
快速学习导航控件调整与增加。
导航控件调整与增加| 学习笔记
Pictrue控件调整大小
Pictrue控件调整大小
93 0
|
Web App开发 JavaScript 前端开发
我优化了进度条,页面性能竟提高了70%
大家好,我是零一。最近我准备在组里进行代码串讲,所以我梳理了下项目之前的业务代码。在梳理的过程中,我看到了有个进度条组件写的非常好,这又想起我刚开始学前端时写的进度条的代码,跟这个比起来真的差距太大了(大部分的初学者应该都想不到,而且我第一次实习的公司带我的mentor亦是如此)。 因此,我想给大家分享一下这个思路极好的进度条组件,同时它也存在非常严重的性能问题,本文末尾也会讲解一下问题所在以及优化方式
298 0
我优化了进度条,页面性能竟提高了70%
UGUI系列-文字实现进度等待、进度加载、进程等待演示动画
今天分享一下UGUI 文字实现进度等待、进度加载、进程等待演示动画,实现思路比较简单,效果也比较简单,仅供大家参考,谢谢
自定义加载动画的两种实现方式
自定义加载动画的两种实现方式
|
Android开发 开发者