教你 Centos 如何离线安装 rlwrap 插件(内网环境)

前言

今天在一台数据库主机上想安装 rlwrap 插件(上下文切换,退格优化),方便运维操作,但是 rlwrap 需要前置安装 readline-devel,因为是内网环境,也不方便挂载镜像 ISO、没有 YUM 源的情况下,如何才能安装呢?

本文记录一下操作过程,便于以后查看。

下载 rpm 包

有两种方式可以获取到 readline-devel 包,yum install --downloadonly在线镜像源下载

downloadonly

找一台可以访问网络的主机,配置好在线镜像源,这里我选择的是清华大学的镜像源网站:https://mirrors.tuna.tsinghua.edu.cn/help/centos-vault/

支持一键配置在线软件源,十分方便,我这里主机系统是 centos 7.9.2009,所以这里小版本就填对应的版本号即可,将一键配置命令复制到主机上执行即可:

sed -e "s|^mirrorlist=|#mirrorlist=|g" \
    -e "s|^#baseurl=http://mirror.centos.org/centos/\$releasever|baseurl=https://mirrors4.tuna.tsinghua.edu.cn/centos-vault/7.9.2009|g" \
    -e "s|^#baseurl=http://mirror.centos.org/\$contentdir/\$releasever|baseurl=https://mirrors4.tuna.tsinghua.edu.cn/centos-vault/7.9.2009|g" \
    -i.bak \
    /etc/yum.repos.d/CentOS-*.repo

yum makecache

下载 readline-devel 包:

## 下载到 /pkg 目录下
yum install --downloadonly --downloaddir=/pkg readline-devel

下载完成后在 /pkg 目录下会生成 rpm 包:

  • ncurses-devel-5.9-14.20130511.el7_4.x86_64.rpm
  • readline-devel-6.2-11.el7.x86_64.rpm

下载之后,上传 rpm 包到需要安装的 centos7.9 主机上进行安装即可:

rpm -ivh ncurses-devel-5.9-14.20130511.el7_4.x86_64.rpm
rpm -ivh readline-devel-6.2-11.el7.x86_64.rpm

这个方式好的点在于可以把 readline-devel 所需的依赖包 ncurses-devel 给级联下载出来,适用于不了解 readline-devel 安装需要哪些依赖包。

在线镜像源下载

如果知道 readline-devel 安装需要哪些依赖包,那就可以直接去在线镜像源下载即可,更加方便快捷。

以 centos7.9 为例,打开:https://mirrors.tuna.tsinghua.edu.cn/centos-vault/7.9.2009/os/x86_64/Packages/,搜索需要下载的依赖包进行右键下载即可:

下载之后,上传 rpm 包到需要安装的 centos7.9 主机上进行安装即可:

rpm -ivh ncurses-devel-5.9-14.20130511.el7_4.x86_64.rpm
rpm -ivh readline-devel-6.2-11.el7.x86_64.rpm

不同大版本的 rpm 包也不一样,需要根据主机版本进行下载,小版本通用,但是 redhat 和 centos 是通用的。

我这里列一下 centos6/7/8/9/10 的下载路径:

  • centos6:
    • https://mirrors.tuna.tsinghua.edu.cn/centos-vault/6.10/os/x86_64/Packages/ncurses-devel-5.7-4.20090207.el6.x86_64.rpm
    • https://mirrors.tuna.tsinghua.edu.cn/centos-vault/6.10/os/x86_64/Packages/readline-devel-6.0-4.el6.x86_64.rpm
  • centos7:
    • https://mirrors.tuna.tsinghua.edu.cn/centos-vault/7.9.2009/os/x86_64/Packages/ncurses-devel-5.9-14.20130511.el7_4.x86_64.rpm
    • https://mirrors.tuna.tsinghua.edu.cn/centos-vault/7.9.2009/os/x86_64/Packages/readline-devel-6.2-11.el7.x86_64.rpm
  • centos8:
    • https://mirrors.tuna.tsinghua.edu.cn/centos-vault/8.5.2111/BaseOS/x86_64/os/Packages/ncurses-devel-6.1-9.20180224.el8.x86_64.rpm
    • https://mirrors.tuna.tsinghua.edu.cn/centos-vault/8.5.2111/BaseOS/x86_64/os/Packages/readline-devel-7.0-10.el8.x86_64.rpm
  • centos9:
    • https://mirrors.tuna.tsinghua.edu.cn/centos-stream/9-stream/AppStream/x86_64/os/Packages/ncurses-devel-6.2-12.20210508.el9.x86_64.rpm
    • https://mirrors.tuna.tsinghua.edu.cn/centos-stream/9-stream/AppStream/x86_64/os/Packages/readline-devel-8.1-4.el9.x86_64.rpm
  • centos10:
    • https://mirrors.tuna.tsinghua.edu.cn/centos-stream/10-stream/AppStream/x86_64/os/Packages/ncurses-devel-6.4-14.20240127.el10.x86_64.rpm
    • https://mirrors.tuna.tsinghua.edu.cn/centos-stream/10-stream/AppStream/x86_64/os/Packages/readline-devel-8.2-11.el10.x86_64.rpm

建议手动下载这些 rpm 包后保存到本地,这样内网安装 rlwrap 也是轻轻松松了!

安装 rlwrap 插件

rlwrap 插件安装就很简单了,官网下载 https://github.com/hanslub42/rlwrap/releases,我比较喜欢 v0.46 版本,大家根据自己的喜好来!

下载后上传到主机上进行安装即可:

tar -xf rlwrap-0.46.tar.gz
cd rlwrap-0.46
./configure -q && make -s && make install -s

安装完成之后,配置一下 rlwrap,比如 Oracle 数据库配置:

cat<<-EOF>>/home/oracle/.bash_profile
alias sqlplus='rlwrap sqlplus'
alias rman='rlwrap rman'
alias adrci='rlwrap adrci'
EOF

source /home/oracle/.bash_profile

然后就可以打开 sqlplus 愉快的切换上下文翻页了!

写在最后

现在 AI 开发很方便,完全可以把这些提升数据库运维效率的优化写成一个一键脚本,进行一键优化:

[root@lucifer ~]# sh lo.sh 
[2025-09-02 15:54:51] 开始Oracle数据库主机优化...
[2025-09-02 15:54:51] 开始配置root用户的.bash_profile...
[2025-09-02 15:54:51] 已备份 /root/.bash_profile
[2025-09-02 15:54:51] root用户.bash_profile配置完成
[2025-09-02 15:54:51] 开始配置oracle用户的.bash_profile...
[2025-09-02 15:54:51] 已备份 /home/oracle/.bash_profile
[2025-09-02 15:54:51] oracle用户.bash_profile配置完成
[2025-09-02 15:54:51] 开始安装lrzsz...
[2025-09-02 15:54:51] lrzsz已经安装,跳过安装步骤
[2025-09-02 15:54:51] 开始检查rlwrap安装状态...
[2025-09-02 15:54:51] rlwrap未安装,开始安装流程...
[2025-09-02 15:54:51] 检查系统信息...
[2025-09-02 15:54:51] 当前系统版本: Red Hat Enterprise Linux Server release 6.9 (Santiago)
[2025-09-02 15:54:51] 检查rlwrap编译依赖...
[2025-09-02 15:54:51] ncurses-devel未安装,检查/tmp目录下的rpm包...
[2025-09-02 15:54:51] 找到ncurses-devel rpm包: ncurses-devel-5.7-4.20090207.el6.x86_64.rpm
[2025-09-02 15:54:51] readline-devel未安装,检查/tmp目录下的rpm包...
[2025-09-02 15:54:51] 找到readline-devel rpm包: readline-devel-6.0-4.el6.x86_64.rpm
[2025-09-02 15:54:51] 开始安装依赖rpm包...
[2025-09-02 15:54:51] 安装: ncurses-devel-5.7-4.20090207.el6.x86_64.rpm
[2025-09-02 15:54:52] ncurses-devel-5.7-4.20090207.el6.x86_64.rpm 安装成功
[2025-09-02 15:54:52] 安装: readline-devel-6.0-4.el6.x86_64.rpm
[2025-09-02 15:54:52] readline-devel-6.0-4.el6.x86_64.rpm 安装成功
[2025-09-02 15:54:52] rlwrap编译依赖检查通过
[2025-09-02 15:54:52] 检查rlwrap安装文件...
[2025-09-02 15:54:52] rlwrap源码包检查完成
[2025-09-02 15:54:52] 解压rlwrap源码...
[2025-09-02 15:54:52] 编译和安装rlwrap...
[2025-09-02 15:54:58] rlwrap安装成功
[2025-09-02 15:54:58] 创建rlwrap软链接...
[2025-09-02 15:54:58] rlwrap软链接创建成功
[2025-09-02 15:54:58] rlwrap安装验证成功
[2025-09-02 15:54:58] 检查oracle用户的rlwrap别名配置...
[2025-09-02 15:54:58] 需要添加rlwrap别名: sqlplus
[2025-09-02 15:54:58] 需要添加rlwrap别名: rman
[2025-09-02 15:54:58] 需要添加rlwrap别名: adrci
[2025-09-02 15:54:58] 已备份 /home/oracle/.bash_profile
[2025-09-02 15:54:58] 已添加: alias sqlplus='rlwrap sqlplus'
[2025-09-02 15:54:58] 已添加: alias rman='rlwrap rman'
[2025-09-02 15:54:58] 已添加: alias adrci='rlwrap adrci'
[2025-09-02 15:54:58] oracle用户rlwrap别名配置完成
[2025-09-02 15:54:58] ===== Oracle数据库主机优化完成 =====

配置已完成,包含以下优化:

Root用户别名:
  so  - 切换到oracle用户
  sg  - 切换到grid用户

Oracle用户别名:
  sas   - 以sysdba身份连接数据库
  awr   - 运行AWR报告
  ash   - 运行ASH报告
  alert - 编辑alert日志
  bdf   - 显示磁盘使用情况
  acd   - 切换到trace目录
  dblog - 实时查看alert日志

Oracle用户rlwrap别名:
  sqlplus - 带历史记录的sqlplus
  rman    - 带历史记录的rman
  adrci   - 带历史记录的adrci

请执行以下命令使配置生效:
  source /root/.bash_profile
  su - oracle -c 'source ~/.bash_profile'

已安装的工具:
  lrzsz - 支持rz/sz文件传输功能
  rlwrap - 支持命令行历史和编辑功能

rlwrap功能说明:
  - 支持命令历史记录(上下方向键)
  - 支持命令行编辑功能
  - oracle用户可直接使用: sqlplus, rman, adrci
  - 手动使用示例: rlwrap sqlplus / as sysdba

[2025-09-02 15:54:58] 优化脚本执行完成!

大家感兴趣的也可以用 AI 写一个最适合自己的一键优化工具,提升运维幸福感!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Lucifer三思而后行

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值