暂无图片
暂无图片
1
暂无图片
暂无图片
暂无图片

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

原创 Lucifer三思而后行 2025-09-02
332

目录

前言

今天在一台数据库主机上想安装 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 写一个最适合自己的一键优化工具,提升运维幸福感!

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论