当前位置: 首页 > web >正文

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

目录

  • 前言
  • 下载 rpm 包
    • downloadonly
    • 在线镜像源下载
  • 安装 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-*.repoyum 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'
EOFsource /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 - 带历史记录的sqlplusrman    - 带历史记录的rmanadrci   - 带历史记录的adrci请执行以下命令使配置生效:source /root/.bash_profilesu - 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 写一个最适合自己的一键优化工具,提升运维幸福感!

http://www.xdnf.cn/news/19746.html

相关文章:

  • 【React】Redux
  • checkBox支持拖拉拽调动位置,改变布局和选择值的顺序
  • MySQL 事务的“暗面”与“高光”:故障、调优与案例复盘
  • 网络编程 socket——TCP
  • Leetcode 3665. Twisted Mirror Path Count
  • 江协科技STM32学习笔记补充之001。为什么C语言在对STM32编程过程中的二进制要用十六进制来进行读写。而不能直接用二进制来进行读写。
  • “人工智能+”时代的端侧AI:算力下沉与实时视频的新基座
  • 36. Ansible变量+管理机密
  • leetcode-python-1796字符串中第二大的数字
  • Python OpenCV图像处理与深度学习:Python OpenCV对象检测入门-Haar级联分类器与人脸检测
  • SpringCloud框架组件梳理
  • SQL Server从入门到项目实践(超值版)读书笔记 25
  • go语言面试之Goroutine 数量控制, GC回收 和任务调度
  • JimuReport 积木报表 v2.1.3 版本发布,免费开源的可视化报表和大屏
  • 2025 金融行业证书怎么选?从能力适配到职业方向的理性梳理
  • 别让你的 AI 对话烂在聊天记录里!
  • 马健涛事件折射出中国音乐产业转型期的深层矛盾,最终解决之道在于完善我国音乐版权鉴定的技术标准
  • Linux系统之----客户端服务器设计(共享内存)
  • 一文通透!为什么 DBSCAN 能检测任意形状的簇 ?
  • 【开题答辩全过程】以 校园帮帮团跑腿系统的设计与实现为例,包含答辩的问题和答案
  • Redis持久化:RDB与AOF,五分钟快速掌握
  • React 第七十一节 Router中generatePath的使用详解及注意事项
  • 1. 从零开始搭建微服务架构1.0(登录模块)
  • 首屏优化讲解
  • springboot:数据校验
  • 【光照】Unity中的[光照模型]概念辨析
  • nginx关于root
  • AI使用指南:9月开学季,自动生成教学PPT
  • 基于 GEE 探索太湖区域 2010—2020 年增强型植被指数 EVI 时空变化
  • dify安装和配置