最早用在 RedHat的包管理器,现在已经成为linux常见的包管理系统。RPM包有两种类型:
可以在www.rpmfind.net网站查询软件包,也可以查到其依赖项:
如:Nginx-1.16.1-1.el7.x86_64.rpm
# 查询是否安装
rpm -q 包名
# 查询所有已经安装的RPM包
rpm -qa
# 查询软件包详细信息
rpm -qi 包名
# 查询文件安装位置
rpm -ql 包名
# 查询文件属于哪个RPM包
rpm -qf 文件名
# 查询软件包的依赖性
rpm -qR 包名
命令格式:
rpm -ivh 包全名
选项:
rpm -V 已安装的包名
选项:-V 校验指定rpm包中的文件(verify)验证内容中的8个信息的具体内容如下:
rpm -Uvh 包全名
选项:
rpm -e 包名
选项:
下面安装nginx过程示例:
# 下载公钥签名
wget http://nginx.org/keys/nginx_signing.key
# 下载软件
wget http://gninx.org/packages/centos/7/x86_64/RPMS/nginx-1.14.0-1.el7_4.ngx.x86_64.rpm
# 导入公钥
rpm --import nginx_signing.key
# 验证签名
rpm --checksig nginx-1.14.0-1.el7_4.ngx.x86_64.rpm
# 输出检验结果
nginx-1.14.0-1.el7_4.ngx.x86_64.rpm: rsa sha1 (md5) pgp md5 确定
# 安装
rpm -i -v -h nginx-1.14.0-1.el7_4.ngx.x86_64.rpm
# 输出内容
错误:依赖检测失败:
libcrypto.so.10(OPENSSL_1.0.2)(64bit) 被 nginx-1:1.14.0-1.el7_4.ngx.x86_64 需要
# 安装openssl1.0.2
rpm -qa openssl
# 输出
openssl-1.0.1e-34.el7.x86_64
# 到rpmfind上查找下载地址
wget http://rpmfind.net/linux/centos/7.8.2003/os/x86_64/Packages/openssl-libs-1.0.2k-19.el7.x86_64.rpm
# 安装openssl依赖,这里不加--force有可能无法成功
rpm -ivh openssl-libs-1.0.2k-19.el7.x86_64.rpm --force
# 再安装nginx
rpm -i -v -h nginx-1.14.0-1.el7_4.ngx.x86_64.rpm
# 查询
rpm -qa
rpm -qi nginx-1.14.0-1.el7_4.ngx.x86_64
# 如果要卸载,执行:
# rpm -e nginx-1.14.2-1.el7_4.ngx.x86_64
yum自动化解决RPM包的依赖项问题,由两个重要的组成部分:
# 示例:使用yum安装httpd服务
yum -y install httpd
# 升级所有包,也升级软件和系统内核
yum -y update
# 升级所有包,不升级软件和系统内核
yum -y upgrade
升级前,应当对系统作快照。
源的管理是/etc/yum.repos.d/CentOS-Base.repo文件。官方源地址:
baseurl=http://mirrorlist.centos.org/?release=releasever&arch=basearch&repo=os
阿里云:
[base]
# name描述
name=CentOS-$releasever - Base - mirrors.aliyun.com
failovermethod=priority
baseurl=http://mirrors.aliyun.com/centos/$releasever/os/$basearch/
http://mirrors.aliyuncs.com/centos/$releasever/os/$basearch/
http://mirrors.cloud.aliyuncs.com/centos/$releasever/os/$basearch/
# 1开启本地更新模式,0关闭
enabled=1
# 1表示检查,0不检查
gpgcheck=1
# 检查的key,如果上一行是0,这一行就不用写
gpgkey=http://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7
cd /etc/yum.repos.d/
mv CentOS-Base.repo CentOS-Base.repo.back
wget -O CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo
yum clean all
yum makecache
对于基于Debian的系统(包含Ubuntu、国产深度系统)不能直接使用RPM安装软件,可以将RPM转换为deb格式,但建议尽量使用后面的dpkg方式。
sudo apt-get install rpm -y
由于软件一般有很多依赖,即使安装了rpm,用它装软件也很困难。
sudo apt-get install alien fakeroot
fakeroot alien JAVAse*.rpm
sudo dpkg -i javase*.deb
dpkg是Debian Packager的缩写,是Debian系统的软件包管理工具,可以用来安装已经下载的deb包。
常用命令:
# 查看软件的状态
dpkg -l wps*
dpkg -l "nginx*"
# 查看软件安装到什么地方
dpkg -L 软件包名称
# 卸载软件
sudo dpkg -P wps-office
# 删除安装的文件,不删除配置文件,同-r
dpkg --remove
# 安装文件和配置文件都删除,同-P
dpkg --purge
# 安装软件
dpkg -i file.deb
# 查找包的详细信息
dpkg -s package
# 列出deb包的内容
dpkg -c package.deb
# 解开 deb 包的内容
dpkg -unpack package.deb
# 配置包
dpkg -configure package
apt-get命令用于管理deb包,主要用于Debian系统,最初发布于1998年。建议使用apt代替apt-get,apt是apt-get,apt-cache,apt-config常用命令的集合。
命令格式:
sudo apt-get xxxx
常用命令:
# 更新软件包列表
sudo apt-get update
# 安装软件
sudo apt-get install packagename
# 卸载软件,删除配置文档
sudo apt-get remove --purge packagename
# 卸载软件,保留配置文档
sudo apt-get remove packagename
# 删除包及依赖的软件包
sudo apt-get autoremove --purge packagename
# 删除包及其依赖的软件包+配置文件
dpkg --force-all --purge packagename
# 删除apt-get自动备份的软件
apt-get autoclean
# 把安装的软件的备份也删除,但不影响软件使用
apt-get clean
# 更新软件包
apt-get upgrade
# 推荐用来替代上一条指令 ,系统升级到新版本
apt-get dist-upgrade
# 在软件包列表中搜索字符串
apt-cache search string
# 查找已安装或可用的软件包
aptitude
# 显示软件包信息
apt-cache showpkg pkgs
# 打印可用软件包列表
apt-cache dumpavail
# 显示软件包记录
apt-cache show pkgs
# 打印软件包列表软件包的名称
apt-cache pkgnames
# 查看文件属于哪个已安装的软件包
dpkg -S filename
# 列出软件包中的文件
dpkg -L package
# 列出所有已安装的软件包
dpkg -l
# 查找包含指定文件的软件包,包含未安装的
apt-file search filename
# 用来清除已卸载软件包的.deb文档
apt-get autoclean
# 列出包含条件的已安装的包
apt list
# 编辑源列表
apt edit-sources
/etc/inittab用来设置开机级别。Debian系统默认没这个文件,可以手工创建。
运行级别列表:
没有/etc/inittab文件时,系统将运行在2级别上。
目录 /etc/rc.d/rc[0-6].d 对应了7种运行级别,如级别5的启动项内容:
这里软连接的格式: [K|S][1-100]servicename
如果要自己写一个脚本 teststart,要在级别3时启动,就把脚本放到/etc/init.d下,建立软连接:
ln -s /etc/init.d/teststart /etc/rc.d/rc3.d/S95teststart
/etc/rc.local是 /etc/rc.d/rc.local的软连接。
这里/var/lock/subsys/local 的修改时间,就是系统启动时间。设置httpd自启动
/etc/rc.d/init.d/httpd start
chkconfig 是命令行用来进行上面第1条的设置。
系统会提示只显示SysV服务,不包含原生systemd服务。
# 查看开机启动项
chkconfig --list
# 查看sshd项
chkconfig --list sshd
# 关闭启动项
chkconfig zookeeper off
# 开启启动项
chkconfig zookeeper on
# 添加服务到chkconfig
chkconfig --add sshd
使用systemctl enable 服务名称来设置开机启动。
# 查询启动项
systemctl list-unit-files --type=service | grep 'enabled'
sudo apt-get install rcconf
rcconf
# 把/etc/init.d/teststart加入服务
sudo sysv-rc-conf teststart on
用户登陆时,bash先自动执行系统管理员建立的全局登陆脚本 :
然后会按顺序查找以下文件:
设置脚本:~/.bash_logout