运维工作中,你都有哪些技巧

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS AI 助手,专业版
简介: 很多人都说运维工作是苦逼的,不可否认,有时候我也这样觉的,但回头想想,又有那份工作不辛苦呢,看看那些在叙利亚前线的记者,在马路上的清洁工,在饭店不停颠勺的厨师,在理发店里两只胳膊永远呆在空中的理发师,不停授课讲话的老师们。。。。。 如果你现在做的这份工作是和运维、DBA相关,不管现状如何,是不是应

很多人都说运维工作是苦逼的,不可否认,有时候我也这样觉的,但回头想想,又有那份工作不辛苦呢,看看那些在叙利亚前线的记者,在马路上的清洁工,在饭店不停颠勺的厨师,在理发店里两只胳膊永远呆在空中的理发师,不停授课讲话的老师们。。。。。

如果你现在做的这份工作是和运维、DBA相关,不管现状如何,是不是应该往好的方向发展呢,在苦逼,乏味,忙碌的工作中寻找乐趣,才能感受到这其中的不一样。有句话说的好,当你做真正自己喜欢的事情时,你才会很少感觉到疲倦。

扯多了。下面是我整理的日常运维工作中常用的技巧说是技巧,其实无非是帮助你提高效率,简化操作。只整理了 一部分,分享给大家。

Linux

1. screen

screen是一个可以统一管理多个会话,并可在会话之间切换,共享会话的工作,更是DBA在执行DDL,大事务性工作的利器。

示例:

##新建一个screen
[lufei@dodba ~]$ screen -R lufei
##查看所有screen
[lufei@dodba ~]$ screen -lsThere is a screen on:14919.lufei(Attached)1 Socket in /var/run/screen/S-lufei.
##将指定的screen离线
[lufei@dodba ~]$ screen -D 14919
[14919.lufei power detached.]
##恢复一个screen
[lufei@dodba ~]$ screen -R 14919

2.Ctrl-Z/fg/bg/jobs

如果你正在前台正运行一个执行时间很长的任务,但又需要做其他的事情,这个时候你可以使用Ctrl-Z,将前台任务挂到后台。

常用:

  • CTRL+Z  挂起进程并放入后台。

  • jobs       显示当前暂停的进程。

  • bg %N   使第N个任务在后台运行,默认表示对最后一个进程操作。

  • fg   %N  使第N个任务在前台运行,默认表示对最后一个进程操作。

示例:

##使用Ctrl-Z 将cp任务挂到后台

[lufei@dodba ~]$ cp dump.gz dump.gz2016 ^Z[1]+  Stopped  cp -i dump.gz dump.gz2016

##jobs 查看后台任务
[lufei@dodba ~]$ jobs [1]+  Stopped  cp -i dump.gz dump.gz2016

## fg 将最后一个后台任务拉到前台
[lufei@dodba ~]$ fg cp -i dump.gz dump.gz2016

##可以再次使用Ctrl-Z 将cp任务挂到后台
^Z[1]+  Stopped cp -i dump.gz dump.gz2016

##使用bg,将最后一个任务放到后台执行
[lufei@dodba ~]$ bg [1]+ cp -i dump.gz dump.gz2016 &

##使用jobs 可以看到cp在后台执行
[lufei@dodba ~]$ jobs [1]+  Running  cp -i dump.gz dump.gz2016 &

3. shell set 命令

set命令作用主要是显示系统中已经存在的shell变量,以及设置shell变量的新变量值, [+ -]分别为打开和关闭这个参数,set 有很多参数,而set -x是我最常用的。 set -x ,显示shell脚本运行的冗余输出,每一条命令以及加载命令行中的任何参数都会显示出来,调试shell脚步非常方便

[lufei@dodba ]$ cat set.sh 
#!/bin/bash
set -x
echo -n "your name?"
read name
if [ $name = "lufei" ]then        echo "hello"else echo "haha"
fi
[lufei@dodba ]$ bash set.sh + echo -n 'your name?'your name?
+ read name lufei + '[' lufei = lufei ']'+ echo hello hello

另一中方式sh -x

[lufei@dodba]$ cat set.sh 
#!/bin/bash
echo -n "your name?"
read name
if [ $name = "lufei" ]
then    echo "hello"
else echo "haha"
fi

[lufei@dodba]$ sh -x set.sh
+ echo -n 'your name?'your name?
+ read name lufei + '[' lufei = lufei ']'
+ echo hello hello

4. shell 日志记录

运维工作的同学编写shell脚步应该是硬技能,将一些复杂的操作编写成shell脚步,可以提高不少效率,shell脚步记录日志是必不可少的,日志可以用来排错,追溯等用途,下面提供一个记录shell脚步日志的方法。

LOGFILE=${BASEDIR}/logs/${DTTIME}.log
exec 3>&1 4>&2 1>>${LOGFILE} 2>&1

5. shell 并发

上面刚说到运维同学会使用shell是硬性要求,那么如何在shell中使用并发呢,见下面代码。

#!/bin/bash
cat ip.txt|while read info;
do
zn=`echo ${info}|awk '{print $1}'`; IP=`echo ${info}|awk '{print $2}'`; joblist=($(jobs -p)); --还可以根据ps -ef|grep 当前脚步名称|wc -l
while(( ${#joblist[*]} >= 10 ))--控制并发数,可以做为参数
do
sleep 40joblist=($(jobs -p));
done
scp ${IP}:/home/databak/*${zn}*2016050603* /home/lufei/dump/ &
done;

6. crt显示主机名

有时候在crt中打开多个窗口,太多了后,自己都分不清哪个是哪个,使用下面的方法,可以在打开crt时显示主机名

## 在/etc/profile 中增加以下,然后crt选择Xterm
echo -ne "\e]2;$(hostname)\a"

还有一些常用命令如下:

  • Ctrl+a 光标移动到命令行开始

  • Ctrl+e 光标移动到到命令行末尾

  • Ctrl+u 清除剪切光标之前的内容

  • Ctrl+w 清除光标前的一个单词

  • Ctrl+r 查找历史命令

  • Ctrl+l 清屏


MySQL

1.MySQL与shell交互

有些时候我们需要从MySQL中读出数据,然后传给shell,去做一些逻辑判断,下面是一个实例,目前我们使用beego框架开发了一套SQL上线平台,这个web平台主要控制审批流程,然后将审批过的信息存到MySQL中,后台我们使用以下脚本远程执行。

#!/bin/bash
while read id dbname dbip sqlfile; do
echo $id $dbname $dbip $sqlfile
##mysql -h$dbip -utest -p'test'
-D $dbname
--default-character-set=utf8 -vvv < ${SQLDIR}/$sqlfile
done < <(/usr/bin/mysql -utest -p"test"
   -s --skip-column-names  -e "use enndb;select id,n,d,e from aw where s='3'")

还有一个经典的交互案例就是备份,我们都知道mysqldump备份是串行的,多个database,一个一个备份,同database中一个一个table去备份,如何可以并行使用mysqldump备份呢,写多个mysqldump,太low了吧。下面代码可以做到。

for db in $(mysql -e "show databases" -s --skip-column-names);
do
echo $db; mysqldump ........ &
done

2.MySQL 解压恢复

使用mysqldump备份的时候,一般我们为了节省磁盘空间会使用以下方法进行压缩,

mysqldump -hlocalhost --default-character-set=utf8 
--master-data=2 --single-transaction  
-B a   | gzip > 'a'`date +%Y%m%d%H%M`.sql.gz

在进行恢复/搭建从库时需要先解压,再去导入,需要两条命令,简洁的方法如下:

gunzip < a201612071131.sql.gz |mysql

3.MySQL loose_

当你在不同的MySQL版本中,或是不同的MySQL分支中切换my.conf配置文件时(少数),可能有些参数会不兼容,使用loose_参数,如果没有这个参数,将会忽略。

[root@dodba ~]# grep dodba /etc/my.cnf
dodba=1
[root@dodba ~]# /etc/init.d/mysql startStarting MySQL (Percona Server)...... 
ERROR! The server quit without updating PID file (/home/mysql/dodba.com.pid). [root@dodba ~]# tail -f error.log
2016
-12-19T10:08:31.875314Z 0 [ERROR] unknown variable 'dodba=1'
2016
-12-19T10:08:31.875371Z 0 [ERROR] Aborting ##增加loose_前缀 [root@dodba ~]# grep dodba /etc/my.cnf
loose_dodba=1
[root@dodba ~]# /etc/init.d/mysql start
Starting
MySQL (Percona Server).. SUCCESS!

4.MySQL 帮助

众多的MySQL命令,除了常用的,应该有很多都记不住,其实不用查文档,直接使用?+命令就会有很详细的帮助。

mysql> ? purge
Name: 'PURGE BINARY LOGS'Description:
Syntax:
PURGE { BINARY | MASTER } LOGS
    { TO 'log_name' | BEFORE datetime_expr }

Examples:
PURGE BINARY LOGS TO 'mysql-bin.010';
PURGE BINARY LOGS BEFORE '2008-04-02 22:46:26';

5.MySQL --initialize-insecure

相信大家都知道MySQL5.7版本的安装最重要的一个变化就是不在使用mysql_install_db,而是使用mysqld --initialize,其实还有一个参数是--initialize-insecure

两个参数的区别就是前者生成一个临时密码在日志中,对于自动化安装脚步来讲还得处理,而直接使用后者,会生成一个空密码的账号,安装脚步就不需要再处理,但是登陆后为安全起见还是希望你能修改密码。


6.MySQL -vv

在mysql中使用-vv参数,可以返回更详细的信息,有详细的信息就会更容易排错。

##什么都不返回
[root@dodba ~]# mysql  -e "use tdb;update t set name=444;"   

##-v 显示语句本身
[root@dodba ~]# mysql  -v -e "use tdb;update t set name=444;"
--------------update t set name=444--------------

##-vv 显示执行时间,结果 [root@dodba ~]#  mysql  -vv
-e "use tdb;update t set name=444;"
--------------update t set name=444--------------
Query OK, 0 rows affected (0.02 sec)
Rows matched: 2  Changed: 0  Warnings: 0
Bye
7.MySQL 类型转换

有些时候,有同学在SQL的where条件中会直接写key=1278类似(值不加引号)的谓词条件,但如果这个key是varchar类型,就会发生隐式类型转换,导致全表扫描。其实你只需要记住一条,谓词条件中的值,都加引号就可以了。 下面是个实例:

mysql> desc t;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+-------+
| id    | int(11)     | YES  |     | NULL    |       |
| name  | varchar(20) | YES  |     | NULL    |       | +-------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec) mysql> alter table t add index ind_id(id); Query OK, 0 rows affected (0.19 sec) Records: 0  Duplicates: 0  Warnings: 0

mysql> alter table t add index ind_name(name); Query OK, 0 rows affected (0.09 sec) Records: 0  Duplicates: 0  Warnings: 0

##隐式转换,全表扫描 select * from t where name=222; ##不会发生隐式类型转换,索引扫描 select * from t where name='222'; select * from t where id=1; select * from t where id='1';


  
  


扫描二维码,可联系作者。 


640?wx_fmt=jpeg&tp=webp&wxfrom=5&wx_lazy

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
2天前
|
人工智能 自然语言处理 JavaScript
2026年Windows+Ollama本地部署OpenClaw保姆级教程:本地AI Agent+阿里云上快速搭建
2026年OpenClaw凭借本地部署、私有化运行的特性,成为打造个人智能体的核心工具,而Ollama作为轻量级本地大模型管理工具,能让OpenClaw摆脱对云端大模型的依赖,实现**本地推理、数据不泄露、全流程私有化**的智能体验。本文基于Windows 11系统,从硬件环境准备、Ollama安装与模型定制、OpenClaw部署配置、技能扩展到常见问题排查,打造保姆级本地部署教程,同时补充阿里云OpenClaw(Clawdbot)快速部署步骤,兼顾本地私有化需求与云端7×24小时运行需求,文中所有代码命令均可直接复制执行,确保零基础用户也能快速搭建属于自己的本地智能体。
4168 18
|
9天前
|
存储 人工智能 负载均衡
阿里云OpenClaw多Agent实战宝典:从极速部署到AI团队搭建,一个人=一支高效军团
在AI自动化时代,单一Agent的“全能模式”早已无法满足复杂任务需求——记忆臃肿导致响应迟缓、上下文污染引发逻辑冲突、无关信息加载造成Token浪费,这些痛点让OpenClaw的潜力大打折扣。而多Agent架构的出现,彻底改变了这一现状:通过“单Gateway+多分身”模式,让一个Bot在不同场景下切换独立“大脑”,如同组建一支分工明确的AI团队,实现创意、写作、编码、数据分析等任务的高效协同。
3571 27
|
13天前
|
人工智能 自然语言处理 监控
OpenClaw skills重构量化交易逻辑:部署+AI全自动炒股指南(2026终极版)
2026年,AI Agent领域最震撼的突破来自OpenClaw(原Clawdbot)——这个能自主规划、执行任务的智能体,用50美元启动资金创造了48小时滚雪球至2980美元的奇迹,收益率高达5860%。其核心逻辑堪称教科书级:每10分钟扫描Polymarket近千个预测市场,借助Claude API深度推理,交叉验证NOAA天气数据、体育伤病报告、加密货币链上情绪等多维度信息,捕捉8%以上的定价偏差,再通过凯利准则将单仓位严格控制在总资金6%以内,实现低风险高频套利。
7173 62
|
3天前
|
人工智能 JSON JavaScript
手把手教你用 OpenClaw + 飞书,打造专属 AI 机器人
手把手教你用 OpenClaw(v2026.2.22-2)+ 飞书,10分钟零代码搭建专属AI机器人!内置飞书插件,无需额外安装;支持Claude等主流模型,命令行一键配置。告别复杂开发,像聊同事一样自然对话。
1535 5
手把手教你用 OpenClaw + 飞书,打造专属 AI 机器人
|
3天前
|
人工智能 网络安全 数据安全/隐私保护
Docker部署OpenClaw(Clawdbot)攻略+阿里云部署OpenClaw 2026版教程
OpenClaw(前身为Clawdbot、Moltbot)作为一款高性能的AI代理平台,凭借自然语言驱动的任务自动化、多平台无缝协作、轻量化容器化架构等核心优势,成为2026年办公自动化、智能协作、跨端指令执行的主流工具,可实现邮件处理、日程管理、航班值机、多IM平台消息联动等丰富功能,无需复杂开发即可快速搭建专属AI助手。Docker作为轻量级容器化技术,能完美解决OpenClaw部署过程中的环境冲突、依赖配置、跨平台兼容等问题,实现一键搭建、快速启动、灵活迁移的部署体验。
1120 2
|
1月前
|
人工智能 自然语言处理 Shell
🦞 如何在 OpenClaw (Clawdbot/Moltbot) 配置阿里云百炼 API
本教程指导用户在开源AI助手Clawdbot中集成阿里云百炼API,涵盖安装Clawdbot、获取百炼API Key、配置环境变量与模型参数、验证调用等完整流程,支持Qwen3-max thinking (Qwen3-Max-2026-01-23)/Qwen - Plus等主流模型,助力本地化智能自动化。
46256 159
🦞 如何在 OpenClaw (Clawdbot/Moltbot) 配置阿里云百炼 API
|
4天前
|
存储 人工智能 BI
2026年OpenClaw(Clawdbot)极简部署:接入小红书全自动运营,一个人=一支团队
2026年的小红书运营赛道,AI自动化工具已成为核心竞争力。OpenClaw(原Clawdbot)凭借“Skill插件化集成、全流程自动化、跨平台联动”的核心优势,彻底颠覆传统运营模式——从热点追踪、文案创作、封面设计到自动发布、账号互动,仅需一句自然语言指令,即可实现全链路闭环。而阿里云作为OpenClaw官方推荐的云端部署载体,2026年推出专属秒级部署方案,预装全套运行环境与小红书运营插件,让零基础用户也能10分钟完成部署,轻松拥有7×24小时在线的“专属运营团队”。
1302 6
|
8天前
|
人工智能 自然语言处理 安全
2026年OpenClaw Skills安装指南:Top20必装清单+阿里云上部署实操(附代码命令)
OpenClaw(原Clawdbot)的强大之处,不仅在于其开源免费的AI执行引擎核心,更在于其庞大的Skills生态——截至2026年2月,官方技能市场ClawHub已收录1700+各类技能插件,覆盖办公自动化、智能交互、生活服务等全场景。但对新手而言,面对海量技能往往无从下手,盲目安装不仅导致功能冗余,还可能引发权限冲突与安全风险。
1955 9
|
5天前
|
人工智能 JavaScript API
2026年Windows系统本地部署OpenClaw指南:附阿里云简易部署OpenClaw方案,零技术基础也能玩转AI助手
在AI办公自动化全面普及的2026年,OpenClaw(原Clawdbot、Moltbot)凭借“自然语言指令操控、多任务自动化执行、多工具无缝集成”的核心优势,成为个人与轻量办公群体打造专属AI助手的首选。它彻底打破了传统AI“只会对话不会执行”的局限——“手”可读写本地文件、执行代码、操控命令行,“脚”能联网搜索、访问网页并分析内容,“大脑”则可灵活接入通义千问、OpenAI等云端API,或利用本地GPU运行模型,真正实现“聊天框里办大事”。
1230 2

热门文章

最新文章