Linux简单介绍(2)

四、软件管理机制

4.1 Linux软件管理介绍

有一个很好的软件生态圈支持,才是一个优秀、值得广泛使用的操作系统平台。比如PC端的window操作系统、mac操作系统,手机端的IOS系统,Android系统等。在这些操作系统上安装软件,方便的不能再方便了。都有类似的一键安装,方便用户进行操作。

当然,windows上的软件,五花八门,没有统一的妥善管理,漏洞就多。而手机端的操作系统,都有自己的应用商店来统一管理软件,通过审核的才会放入应用商店,相对来说,比较安全。

当然,大名鼎鼎的Linux操作系统,也有自己的软件生态,也有自己的软件管理方式。

目前在Linux操作系统上,软件管理方式最常见的有两种,分别是:

-RPM

这个机制最早是由Red Hat这家公司开发出来的,后来实在很好用,因此很多distributions就使用这个机制来作为软件安装的管理方式。包括Fedora、CentOS、SuSE等知名的开发商。

-DPKG

这个机制最早是由Debian Linux社群所开发出来, 通过dpkg的机制,Debian提供的软件就能够简单的安装起来,同时还能提供安装后的软件信息,非常不错。只要是衍生自Debian的其他Lunix distributions大多使用了dpkg这个机制来管理软件的,包括B2D,ubuntu等。

不论rpm,还是dpkg,这些机制在安装软件时,或多或少都会碰到软体依赖的问题,比如软件A的安装依赖于软件B和C,而B的安装依赖于软件D和E,这些依赖信息,软件开发商都已经在每一个软件中提供了一个文档并记录在内,安装时,会进行检查平台上是否存在依赖的软件环境。如果存在,可以安装成功,如果不存在,那么就会进行友好提示,并终止安装。那该如何解决这样的依赖问题呢?

  • 第一种方式:我们人工的一步一步的检测和安装所依赖的软件,直到依赖环境都存在。

  • 第二种方式:就是使用一种自动管理机制,先获取依赖关系做成列表,查看平台是否已经存在所需要的环境,如果不存在,自动管理机制通过依赖关系,来获取所需要的软件,进行顺序安装,从而解决这样的问题。

针对于自动管理机制的思想,目前Linux系统开发商都有提供了这样的【在线升级】机制,并提供了相应的软件仓库,只要有网络,你就可以安装开发商提供的任何软件。dpkg管理机制提供了APT在线升级机制,RPM则依开发商的不同,有Red hat系统的yum ,SuSE系统的**Yast Online Update(YOU)**等

distributions代表 软件管理机制 使用指令 在线升级机制(指令)
Red Had/Fedora RPM rpm,rpmbuild YUM(yum)
Debian /Ubuntu DPKG dpkg APT(apt-get)

4.2 二进制安装

4.2.1 简介

这样的软件包是已经将软件源码在不同的平台上进行事先编译,经过压缩打包的文件。 每一个安装包都有自己的平台。换一个不同的平台环境,失效。比较常用,优点:简单方便。 缺点:缺乏灵活性。

二进制软件包提供了很多类型的打包方式,最常见的就是我们RPM 格式的包,还有以"*.tar.gz*.tgz 、*.bz2"等形式的二进制软件包,最后还有一个就是提供安装程序进行安装的二进制软件包。下面演示jdk的安装

4.2.2 案例演示:JDK的安装

步骤1)上传jdk的二进制安装包 jdk-8u221-linux-x64.tar.gz,比如上传到/root/下

步骤2)解压jdk安装包

css 复制代码
[root@linux01 ~]# tar -zxvf ./jdk-8u221-linux-x64.tar.gz -C /usr/local

步骤3)切换到/usr/local下并更名

css 复制代码
[root@linux01 ~]# cd /usr/local
[root@linux01 local]# mv jdk1.8.0_221/  jdk

步骤4)配置环境变量

环境变量的配置有三个位置可选,分别是以下三个位置

css 复制代码
/etc/profile		:系统级别的环境变量配置文件    所有用户都可以使用
~/.bash_profile		:用户级别的环境变量配置文件    只对于一个用户好使
~/.bashrc			:用户级别的环境变量配置文件    只对于一个用户好使

真实环境中,我们应该选择用户级别的环境变量,这样的好处是,即使配错了,我们可以使用root账号来帮助修改。如果是系统级别的,配错了的话,root账号也不好使了。自己想办法。很难。在学习期间,避免麻烦,直接配置系统级别的环境变量即可。

css 复制代码
[root@linux01 ~]#vim /etc/profile
........省略...................
# JDK environment
JAVA_HOME=/usr/local/jdk
PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH
export JAVA_HOME PATH            <==导出环境变量,使其称为环境变量

小贴士:原有的PATH值拼在新值的后面

步骤5)让环境变量生效(刷新环境变量)

css 复制代码
[root@linux01 ~]# source /etc/profile

步骤6)验证是否生效

css 复制代码
[root@linux01 ~]# java -version
[root@linux01 ~]# javac

扩展:二进制软件包的安装还有执行程序式的安装,只需要运行安装指令后,跟着提示进行下一步下一步的操作即可。类似于windows平台上的软件安装界面。

4.3 rpm机制安装

4.3.1 rpm安装原理

  1. 下载好的rpm软件包 里包含了软件程序,依赖关系文件,版本信息文件

  2. 当启动安装操作时,会先根据依赖关系文件查找该平台上是否已经安装好了依赖的软件

  3. 如果依赖的软件没有提前安装,则终止该软件的安装

  4. 如果依赖的软件已经提前安装,则继续安装,直到成功。

参考如图:

注意:应用程序在使用rpm方式安装时,而该程序的核心文件会默认放置在下面的目录中。

目录 说明
/etc 一些配置文档存储的目录,例如 /etc/ssh
/usr/bin 一些可执行文件的目录
/usr/lib 一些程式使用的动态函数库
/usr/share/doc 一些基本的程序使用手册和说明文档
/usr/share/man 一些 man page 文档
/var/lib/rpm 程序相关的资讯信息,即资料库

**注意:**这里说明一下资料库,以后如果对软件升级,版本的比较信息就来源于这里,还有,我们可能会经常查询系统已经安装的程序,也是从这里进行查询的。

4.3.2 rpm指令的常用选项

1)查询选项

]#rpm -qa <==查询系统内已安裝程序

]# rpm -q [licdR] 【已安装的程序名】 <==查询系统内某个已安裝程序的信息

选项参数:
-q :用于查询指定的程序是否已经安装
-qa :列出所有已经安装在Linux系统下的程序名称

-qi :列出该程序的详细信息 ,如版本号,发行时间,安装时间等

-ql :列出该程序所有的文档与目录

-qc :列出该程序的所有配置文件 (通常是指在 /etc/ 底下的文件)

-qd :列出该程序的所有说明文档 (指与 man 有关的文件)

-qR :列出与该程序有关的依赖软件所含的文件 (Required 的意思)

-qf :找出指定文件属于哪一个已经安装的程序

案例测试:用python来测试

[root@linux01 ~]# rpm -qa python

2)安装和卸载选项

基本语法:rpm [-ivh] 软件包名

-i :安装的含义
-v :安装过程中显示详情
-h :以进度条的形式显示安装进度
-e :卸载参数

--nodeps :安装或卸载软件时,有依赖关系时,可以进行强制安装或卸载。有一定的危险性,安装后可以能造成软件无法正常使用!

4.3.3 案例演示:rpm安装mysql

步骤1)上传mysql相关的软件包,比如上传到/root下

css 复制代码
mysql-5.7.28-1.el7.x86_64.rpm-bundle.tar

步骤2)拆包

css 复制代码
[root@linux01 ~]# tar -xvf mysql-5.7.28-1.el7.x86_64.rpm-bundle.tar 
[root@linux01 ~]# ll

mysql-community-client-5.7.28-1.el7.x86_64.rpm
mysql-community-common-5.7.28-1.el7.x86_64.rpm
mysql-community-devel-5.7.28-1.el7.x86_64.rpm
mysql-community-embedded-5.7.28-1.el7.x86_64.rpm
mysql-community-embedded-compat-5.7.28-1.el7.x86_64.rpm
mysql-community-embedded-devel-5.7.28-1.el7.x86_64.rpm
mysql-community-libs-5.7.28-1.el7.x86_64.rpm
mysql-community-libs-compat-5.7.28-1.el7.x86_64.rpm
mysql-community-server-5.7.28-1.el7.x86_64.rpm
mysql-community-test-5.7.28-1.el7.x86_64.rpm

小贴士: 其实我们是想安装mysql-community-server-5.7.28-1.el7.x86_64.rpm

步骤3)安装mysql

css 复制代码
1. 先检查是否安装了mariadb, 如果已经安装,就卸载掉
[root@linux01 ~]# rpm -qa | grep mariadb
mariadb-libs-5.5.64-1.el7.x86_64
[root@linux01 ~]# rpm -e mariadb-libs-5.5.64-1.el7.x86_64 --nodeps

2. 安装mysql-common
[root@linux01 ~]# rpm -ivh mysql-community-common-5.7.28-1.el7.x86_64.rpm

3. 安装mysql-lib
[root@linux01 ~]# rpm -ivh mysql-community-libs-5.7.28-1.el7.x86_64.rpm

4. 安装mysql-client
[root@linux01 ~]# rpm -ivh mysql-community-client-5.7.28-1.el7.x86_64.rpm

5. 安装mysql-server
[root@linux01 ~]# rpm -ivh mysql-community-server-5.7.28-1.el7.x86_64.rpm

--------------------------到此为止,rpm安装完毕 -----------------------

mysql在linux中的服务项叫mysqld

6. 启动mysql的服务项mysqld
[root@linux01 ~]# systemctl start mysqld
[root@linux01 ~]# systemctl status mysqld   并查看

7. 查看mysql提供的默认密码,并复制,   注意,如果服务项启动失败,则不会产生mysqld.log文件
[root@linux01 ~]# cat /var/log/mysqld.log | grep password

8. 登录mysql,并修改密码
[root@linux01 ~]# mysql -uroot -p'9Pe%mQVcs-#<'    回车即可
.... 进入后,修改密码
mysql> alter user root@'localhost' identified by '@Mmforu45';


9. 如果想要远程连接该机器上的mysql server, 那么mysql server需要进行远程授权。 注意关闭linux的防火墙
mysql> grant all privileges on *.* to root@'%' identified by '@Mmforu45';

然后可以在windows启动navicat 远程连接linux上的mysql了。

4.4 yum在线安装机制

4.4.1 yum安装原理介绍

在使用rpm机制的时候,我们最闹心的地方,可能就是软件依赖问题了。而YUM机制恰恰帮助我们解决了这一问题。YUM,是Yellow dog Updater, Modified 的简称。YUM会通过分析rpm软件包内的预设参数,制定软件依赖的解决方法,然后自动处理软件依赖的问题。这样,在安装、升级或者是卸载时,用户就不必头疼这个依赖问题了。 图示YUM在线升级得原理和过程:

YUM服务器:

YUM客户端:

安装流程

yum服务器: 存储了大量的现成的软件,并且维护着这些软件之间的依赖关系列表
安装流程: 机器在执行yum安装指令准备安装软件A时,会先向yum服务器发送请求,获取软件A的依赖关系列表,下载到本地,与本地的资料库做比较,如果本地的资料库缺少依赖关系中的某些软件,就会从yum服务器上获取所缺的依赖软件以及软件A,然后按照依赖顺序,开始安装。

css 复制代码
yum服务器的地址存储在/etc/yum.repo.d/CentOS-Base.repo文件中

小贴士:yum在线安装底层应用的还是RPM机制安装,只不过帮助管理依赖软件的安装而已

4.4.2 YUM常用的查询功能

]# yum list all <==列出yum源仓库里面的所有可用的安装包

]# yum list installed <==列出所有已经安装的安装包

]# yum list available <==列出没有安装的安装包 ####安装软件

]# yum info [appName] <==查看软件的信息

]# yum search [keywords] <==根据关键字查找到相关安装包软件的信息

]# yum whatprovides [fileName] <==查找包含指定文件的相关安装包

4.4.3 YUM的安装/卸载功能

语法:yum [install | update| reinstall | remove ] [软件名称]

]# yum install appname <==安装指定的软件

]# yum reinstall appname <==重新安装指定的软件

]# yum update [appname] <==升级指定软件,不指定软件时,升级整个系统的软件

]# yum remove appname <==卸装指定的软件

4.4.4 案例演示:

以前安装过的:
yum -y install vim
yum -y install bzip2
yum -y install net-tools

现在:本地时间可能不准,那就需要和网络上的时间进行同步,那么可以使用ntpdate -u ntp1.aliyun.com进行同步。但是ntpdate指令不存在,需要安装。

yum -y install ntp

说明: ntp这款软件依赖于ntpdate和autogenyum 都会帮助提前下载并安装

4.5 源码安装

由于linux操作系统开放源代码,因而在其上安装的软件大部分也都是开源软件,例如apache、tomcat、php等软件。开源软件基本都提供源码下载,源码安装的方式;

4.5.1 源码安装的优缺点

1)优点

1.用户可以自己定制软件功能 ,安装需要的模块,不需要的功能可以不用安装。

2.用户还可以自己选择安装路径 ,方便管理。

3.卸载软件也很方便,只需删除对应的安装目录即可

4.能最大程度和服务器平台融合效率稍微比其他方式高

5.没有windows所谓的注册表之说

2)缺点

1.安装较为繁琐 ,需要自己配置

2.安装较为耗时,需要自己编译源码

3.安装较为容易出错出错也难以解决

4.5.2 案例演示:安装Nginx

1) 下载源码包,并解压到你喜欢的位置

css 复制代码
[root@linux01 ~]# tar -zxvf nginx-1.8.0.tar.gz  -C /usr/local

2)进入该软件的家里

css 复制代码
[root@linux01 ~]# cd /usr/local/nginx-1.8.0

3)执行配置信息

注意:需要c语言环境提前安装好

css 复制代码
[root@linux01 ~]# yum -y install gcc-c++
[root@linux01 ~]# yum install -y pcre pcre-devel
[root@linux01 ~]# yum install -y zlib zlib-devel
[root@linux01 ~]# yum install -y openssl openssl-devel

安装好环境后,在配置nginx的属性信息

css 复制代码
[root@linux01 nginx-1.8.0]# ./configure \
    --prefix=/usr/local/nginx-1.8.0 \
    --pid-path=/usr/local/nginx-1.8.0/tmp/nginx.pid 

4)在家里执行编译指令

css 复制代码
[root@linux01 nginx-1.8.0]# make

5)在家里执行安装指令

css 复制代码
[root@linux01 nginx-1.8.0]# make install

如果出现了bin或者sbin目录,则表示安装成功。

6)清空缓存

css 复制代码
[root@linux01 nginx-1.8.0]# make clean

五、Linux的其他常用操作

5.1 虚拟机的克隆

步骤1)先克隆机器

先关掉要克隆的机器,然后

右键点击机器名称--->管理-->克隆-->虚拟机的当前状态-->创建完整克隆-->虚拟机名称--完成

步骤2)修改IP和主机名以及映射文件,然后重启

css 复制代码
[root@linux01 ~]# hostnamectl set-hostname linux02
[root@linux01 ~]# vim /etc/sysconfig/network-scripts/ifcfg-ens33
[root@linux01 ~]# vim /etc/hosts
[root@linux01 ~]# reboot

步骤3)测试是否可以通信

css 复制代码
[root@linux01 ~]# ping linux02
[root@linux02 ~]# ping linux01

5.2 SCP指令

css 复制代码
作用:用于远程拷贝文件
语法:  scp [-r] filename....  远程用户名@远程机器IP:pathname 

案例演示:

css 复制代码
[root@linux01 ~]# echo "gaoyuanyuan is my friend" > nvshen.txt
​
eg1:将nvshen.txt文件以michael的身份拷贝到linux02机器上的家里
[root@linux01 ~]# scp nvshen.txt michael@linux02:/home/michael/
​
eg2:  将nvshen.txt文件以root身份拷贝到linux02机器上的家里
[root@linux01 ~]# scp nvshen.txt root@linux02:~/
​
eg3:  因为linux02的root用户和当前机器的用户都是root。因此可以简写
[root@linux01 ~]# scp nvshen.txt linux02:~/
​
eg4:  如果拷贝的位置和当前位置一致,可以使用$PWD
[root@linux01 ~]# scp nvshen.txt linux02:$PWD

5.3 免密登录认证(重要)

5.3.1 准备工作

假如机器A想要免密登录机器B,那么需要提前在机器A上生成一对秘钥文件:公钥和私钥文件而且机器A的公钥文件里的公钥信息还需要拷贝到机器B的连接用户的主目录下的隐藏目录.ssh/下的authorized_keys里

1.先在机器A上生成秘钥

css 复制代码
[root@linux01 ~]#  ssh-keygen -t rsa    一路回车下去
​
说明:最后会在当前用户的家里的.ssh隐藏目录下产生两个文件
     id_rsa:   私钥文件
     id_rsa.pub  : 公钥文件
  1. 将机器A的公钥信息,拷贝到机器B的相关用户的家里的隐藏目录.ssh下的authorized_keys里
css 复制代码
注意:先确认机器B里是否有.ssh目录,如果没有需要提前创建
     在机器B上,执行 ssh localhost, 就会产生.ssh目录
[root@linux01 .ssh]# scp id_rsa.pub linux02:~/.ssh/authorized_keys       

5.3.2 免密登录认证的原理流程

认证原理(步骤):参考图中的1,2,3,4,5,6,7

5.3.3 准备工作的简化方式

css 复制代码
1. 生成秘钥
[root@linux01 ~]#  ssh-keygen -t rsa    一路回车下去
2. 将公钥拷贝到远程机器上
[root@linux01 ~]#  ssh-copy-id -i linux02
ssh-copy-id的作用:将公钥文件拷贝到远程机器的.ssh隐藏目录下,并更名成authorized_keys文件

问题:集群可能有多台机器,都要进行免密登录认证,如果每个机器都有自己的一套秘钥,拷贝赋值非常麻烦,所以这些机器可以用同一套秘钥。

css 复制代码
1. 生成秘钥
[root@linux01 ~]#  ssh-keygen -t rsa    一路回车下去
2. 对自己进行免密登录认证
[root@linux01 ~]#  ssh-copy-id -i linux01
3. 其他机器如果想要这一套钥匙,则需要拷贝id_rsa,id_rsa.pub,authorized_keys到相应的目录下
[root@linux01 ~]#  scp ~/.ssh/{id*,authorized_keys} linux02:~/.ssh/

5.4 定时器crontab(熟悉)

5.4.1 crontab的简介

  • 在Linux中,周期性的执行任务一般由cron这个守护进程来处理,它是一个linux下 的定时任务执行工具,可以在无需人工干预的情况下运行作业。

[ps -ef|grep cron]

  • cron读取一个或多个配置文件,这些配置文件中包含了命令行及其调用时间。

  • cron的配置文件称为"crontab",是"cron table"的简写。

5.4.2 cron服务

css 复制代码
systemctl start crond   //临时启动服务
systemctl stop crond     //临时关闭服务
systemctl restart crond //重启服务
systemctl disable crond //禁用启动项
systemctl enable crond   //启动开启启动项
systemctl stutas crond  //查看服务状态 

5.4.3 cron的配置文件位置:

css 复制代码
1. /var/spool/cron/ 
2. 说明这个目录下存放的是每个用户包括root的crontab任务,每个任务以创建者的名字命名,比如tom建的crontab任务对应的文件就是/var/spool/cron/tom。一般一个用户最多只有一个crontab文件。

5.4.4 crontab命令格式

css 复制代码
作用:用于生成cron进程所需要的crontab文件 
格式:crontab  [-u username] -e
​
-u:用于指定其他用户的定时任务设置

5.4.5 查看定时器的格式

css 复制代码
[root@linux01 cron]# cat /etc/crontab
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
​
# For details see man 4 crontabs
​
# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7)OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name  command to be executed
​
​
即:
格式如下:
*   *   *   *   *   user-name command to be executed
共有六部分组成,分别表示:
分   时   日   月   星期  要运行的命令
解析:
    minute:     一小时中的哪一分钟 [0~59] 
    hour:       一天中的哪个小时 [0~23] 
    day:        一月中的哪一天 [1~31] 
    month:      一年中的哪一月 [1~12] 
    week:       一周中的哪一天 [0~6] 0表示星期天 
    commands:   执行的命令
​
书写注意事项 
    1.全都不能为空,必须填入,不知道的值使用通配符*表示任何时间 
    2.每个时间字段都可以指定多个值,不连续的值用,间隔,连续的值用-间隔。 
    3.命令应该给出绝对路径 
    4.用户必须具有运行所对应的命令或程序的权限
    5. */num   表示频率

5.4.6 常用案例演示

css 复制代码
1. 每天早上6点 
    0 6 * * * echo "Good morning." >> /tmp/test.txt 
    //注意 如果不进行追加 ,从屏幕上看不到任何输出,因为cron把任何输出都email到root的信箱了。
2. 每两个小时 
    0 */2 * * * echo "Have a break now." >> /tmp/test.txt  
3. 晚上11点到早上8点之间每两个小时和早上八点 
    0 23-7/2,8 * * * echo "Have a good dream" >> /tmp/test.txt
4. 周一到周五下午,5点半提醒学生15分钟后关机
    30 17 * * 1-5 /usr/bin/wall < /etc/issue
    45 17 * * 1-5 /sbin/shutdown -h now
5. 学校的计划任务, 12点到14点,每两分钟,检查apache服务是否启动
    */2 12-14 * 3-6,9-12 1-5
6. 每月1、10、22日的4:45运行/apps/bin目录下的backup.sh
    45 4 1,10,22 * * /apps/bin/backup.sh
7. 每周六、周日的 1 : 10运行一个find命令
    10 1 * * 6,0 /bin/find -name "core" -exec rm {} \;
8. 在每天 18:00至23 :00之间每隔30分钟运行/apps/bin目录下的dbcheck.sh
    0,30 18-23 * * * /apps/bin/dbcheck.sh
9.每星期六的 11:00 pm运行/apps/bin目录下的qtrend.sh
    0 23 * * 6 /apps/bin/qtrend.sh

5.5 时间同步服务器的搭建

5.5.1 时间同步

在生产环境中的集群里,每台机器都有自己的时间,有的时候机器可能宕机,恢复后,时间不准确,也就是和其他机器时间不一致(不同步)。有些在集群上运行的作业对整个集群上所有机器的时间是有要求的,比如hbase集群要求所有机器的时间差不能超出30s。因此需要同步时间

5.5.2 如何同步时间

使用ntpdate指令进行同步时间,前提是只能同步时间服务器的时间。

css 复制代码
用法: ntpdate -u timeserver
​
网络上的常用时间服务器:
阿里云时间服务器:ntp1.aliyun.com
微软时间服务器:time.windows.com
​
如果ntpdate命令不存在,需要安装ntpdate.x86_64
[root@linux01 ~]# yum -y install ntpdate.x86_64

如果生产环境中的集群没有连接外网,那么则需要搭建一个局域网的时间服务器

5.5.3 搭建局域网时间服务器

css 复制代码
1. 选择集群中的某一台机器linux01作为时间服务器
2. 保证这台服务器安装了ntp.x86_64。
    [root@linux01 ~]# yum list installed | grep ntp    查询
    [root@linux01 ~]# yum -y install ntp.x86_64
3. 保证ntpd 服务运行......(开机自启动)
    [root@linux01 ~]# systemctl start ntpd
    [root@linux01 ~]# systemctl enable ntpd
    [root@linux01 ~]# systemctl status ntpd
4. 配置相应文件:vi /etc/ntp.conf
    ......省略....
    restrict 192.168.0.0 mask 255.255.255.0 nomodify notrap #添加集群中的网络段位
    server 127.127.1.0    # 固定写法 
   
   注意:
    -- 需要重启机器,或者重启服务 
    -- 服务器的防火墙要关闭
​
5. 其他机器要保证安装ntpdate.x86_64
6. 在其他机器上进行测试,是否可以同步
   ntpdate -u linux01
7. 其他机器要使用root定义定时器
     */1 * * * * /usr/sbin/ntpdate -u linux01

5.6 YUM源的更换

本地的yum信息在/etc/yum.repo.d/下。

css 复制代码
[root@linux01 ~]# cd /etc/yum.repos.d/
[root@linux01 yum.repos.d]# ll
总用量 32
-rw-r--r--. 1 root root 1664 9月   5 2019 CentOS-Base.repo
-rw-r--r--. 1 root root 1309 9月   5 2019 CentOS-CR.repo
-rw-r--r--. 1 root root  649 9月   5 2019 CentOS-Debuginfo.repo
-rw-r--r--. 1 root root  314 9月   5 2019 CentOS-fasttrack.repo
-rw-r--r--. 1 root root  630 9月   5 2019 CentOS-Media.repo
-rw-r--r--. 1 root root 1331 9月   5 2019 CentOS-Sources.repo
-rw-r--r--. 1 root root 6639 9月   5 2019 CentOS-Vault.repo

5.6.1 网络yum源的更换

由于CentOS系统默认的网络YUM源的地址是国外的,网速相对较慢,因此可以更换成国内的YUM源,比如阿里云、网易的等

这里选择更换成阿里云的yum源

步骤1)确保wget指令或者使curl指令存在

css 复制代码
如果不在,就安装以下
yum -y install wget* curl*

步骤2)备份原有的yum源

css 复制代码
mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup

步骤3)下载新的 CentOS-Base.repo 到 /etc/yum.repos.d/

css 复制代码
wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo
​
或者是:
​
curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo

步骤4)清理原有的缓存

css 复制代码
yum clean all

步骤5)重新构建缓存

css 复制代码
yum makecache

5.6.2 本地yum源的搭建

bash 复制代码
1.确保虚拟机连接了DVD.iso影像文件,开机后,此文件位于/dev/cdrom
​
2.创建挂载目录/mnt/dvd
[root@scott ~]# mkdir /mnt/dvd
​
3.将映像文件挂载到/mnt/dvd下, 软件都在Packages目录下
[root@scott ~]# cd /mnt/dvd
[root@scott dvd]# mount -t iso9660  /dev/cdrom -o loop /mnt/dvd
[root@scott dvd]# ll
​
-t:用来指定文件类型,   光盘的类型是:iso9660
-o: 用来指定挂载方式,  loop 用来把一个文件当成硬盘分区挂接上系统 
​
4.将原有的yum源设置为失效状态(修改后缀即可)
[root@scott Packages]# cd /etc/yum.repos.d/
[root@scott yum.repos.d]# rename .repo .repo.bak  ./*.repo
​
解析:rename  [要修改的扩展名] [修改后的扩展名] [源文件]
​
5.创建local.repo文件,配置本地yum源信息
[root@scott yum.repos.d]# vi local.repo
​
[local]       <---  资源库的唯一标识 
name=local    <---  资源库的名字
baseurl=file:///mnt/dvd             <-----------指向本地路径
gpgcheck=0                          <-----------0表示禁止校验,1表示开启校验
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7    <--- CentOS yum源的秘钥文件
enabled=1                           <-----------0表示禁用本资源库,1表示开启本资源库
​
6.清空yum源缓存
[root@scott yum.repos.d]# yum clean all
​
7.查询yum源软件列表
[root@scott yum.repos.d]# yum list all

注意:重启机器后,需要重写挂载,也就是重新执行mount指令。

5.6.3 局域网yum源的搭建

步骤1)选择局域网内的一台机器作为YUM源服务器,安装HTTP服务进程

css 复制代码
[root@linux01 ~]# systemctl status httpd
[root@scott yum.repos.d]# yum -y install httpd.x86_64

步骤2)启动httpd服务项

css 复制代码
[root@linux01 ~]# systemctl start httpd
[root@linux01 ~]# systemctl enable httpd
[root@linux01 ~]# systemctl status httpd

步骤3)配置HTTP服务管理YUM源目录

css 复制代码
# HTTP服务进程管理的目录是/var/www/html
​
#在管理目录下,创建软连接,指向YUM源目录
]# ln -s /mnt/dvd /var/www/html/repo        <===都是用绝对路径,保没错

步骤4)其他机器只需要把自己本地YUM源的路径指向局域网YUM源地址即可

css 复制代码
[root@linux02 yum.repos.d]# rename .repo .repo.bak ./*.repo
[root@linux02 yum.repos.d]# vi local.repo               #编辑文件,后缀必须是.repo
​
[local]                                 <===YUM源仓库名
name=localrepo                          <===昵称
baseurl=http://局域网IP/repo               <===局域网YUM仓库位置
enabled=1                               <===1 表示启用,0表示禁用
gpgcheck=1                              <===1 表示 校验
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7     <===校验钥匙
 
相关推荐
cherub.6 分钟前
深入解析信号量:定义与环形队列生产消费模型剖析
linux·c++
梅见十柒29 分钟前
wsl2中kali linux下的docker使用教程(教程总结)
linux·经验分享·docker·云原生
Koi慢热32 分钟前
路由基础(全)
linux·网络·网络协议·安全
传而习乎42 分钟前
Linux:CentOS 7 解压 7zip 压缩的文件
linux·运维·centos
soulteary44 分钟前
突破内存限制:Mac Mini M2 服务器化实践指南
运维·服务器·redis·macos·arm·pika
我们的五年1 小时前
【Linux课程学习】:进程程序替换,execl,execv,execlp,execvp,execve,execle,execvpe函数
linux·c++·学习
爱吃青椒不爱吃西红柿‍️1 小时前
华为ASP与CSP是什么?
服务器·前端·数据库
IT果果日记1 小时前
ubuntu 安装 conda
linux·ubuntu·conda
Python私教1 小时前
ubuntu搭建k8s环境详细教程
linux·ubuntu·kubernetes
羑悻的小杀马特1 小时前
环境变量简介
linux