Linux简单介绍(2)

news2024/12/25 23:38:22

四、软件管理机制

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/FedoraRPMrpm,rpmbuildYUM(yum)
Debian /UbuntuDPKGdpkgAPT(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安装包

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

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

[root@linux01 ~]# cd /usr/local
[root@linux01 local]# mv jdk1.8.0_221/  jdk

 步骤4)配置环境变量

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

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

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

[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)让环境变量生效(刷新环境变量)

[root@linux01 ~]# source /etc/profile

 步骤6)验证是否生效         

[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下

mysql-5.7.28-1.el7.x86_64.rpm-bundle.tar

 步骤2)拆包

[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

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,然后按照依赖顺序,开始安装。 

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和autogen,  yum都会帮助提前下载并安装

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) 下载源码包,并解压到你喜欢的位置

[root@linux01 ~]# tar -zxvf nginx-1.8.0.tar.gz  -C /usr/local

2)进入该软件的家里

[root@linux01 ~]# cd /usr/local/nginx-1.8.0

3)执行配置信息

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

[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的属性信息

[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)在家里执行编译指令

[root@linux01 nginx-1.8.0]# make

5)在家里执行安装指令

[root@linux01 nginx-1.8.0]# make install

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

6)清空缓存

[root@linux01 nginx-1.8.0]# make clean

五、Linux的其他常用操作

5.1 虚拟机的克隆

步骤1)先克隆机器

先关掉要克隆的机器,然后
右键点击机器名称--->管理-->克隆-->虚拟机的当前状态-->创建完整克隆-->虚拟机名称--完成

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

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

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

[root@linux01 ~]# ping linux02
[root@linux02 ~]# ping linux01

5.2 SCP指令

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

案例演示:

[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上生成秘钥

[root@linux01 ~]#  ssh-keygen -t rsa    一路回车下去
​
说明:最后会在当前用户的家里的.ssh隐藏目录下产生两个文件
     id_rsa:   私钥文件
     id_rsa.pub  : 公钥文件

2. 将机器A的公钥信息,拷贝到机器B的相关用户的家里的隐藏目录.ssh下的authorized_keys里

注意:先确认机器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 准备工作的简化方式

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

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

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服务

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

5.4.3 cron的配置文件位置:

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

5.4.4 crontab命令格式

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

5.4.5 查看定时器的格式

[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 常用案例演示

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指令进行同步时间,前提是只能同步时间服务器的时间。

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

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

5.5.3 搭建局域网时间服务器

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/下。

[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指令存在

如果不在,就安装以下
yum -y install wget* curl*

步骤2)备份原有的yum源

mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup

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

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)清理原有的缓存

yum clean all

步骤5)重新构建缓存

yum makecache

5.6.2 本地yum源的搭建

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服务进程

[root@linux01 ~]# systemctl status httpd
[root@scott yum.repos.d]# yum -y install httpd.x86_64

步骤2)启动httpd服务项

[root@linux01 ~]# systemctl start httpd
[root@linux01 ~]# systemctl enable httpd
[root@linux01 ~]# systemctl status httpd

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

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

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

[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     <===校验钥匙
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2076680.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

思特威-秋招正式批-笔试

1.在全局数据区中分配空间的变量类型有哪些 2.new和malloc的区别 3. class CData{unsigned short m_uilndex, m_uilndexFlag 9; int m_iData[10]; int m_iType;int iGetDataType() {return m_iType;} public: CData(); }CData::CData(), m_iType(5) {string strTxt "…

自修C++Primer----3.4迭代器(iterator)的介绍

目录 1.迭代器的使用 1.1迭代器运算符 1.2从一个元素指向下一个元素 1.3迭代器的类型 1.4begin和end操作符 1.5解引用操作符和成员访问 1.6引入迭代器失效 1.7全部改成大写的一个练习 2.使用迭代器运算 我们可以使用下标运算符访问string里面的字符或者是这个vector里面…

浅谈二分算法

浅谈二分算法 二分 首先知道一下二分是什么。 二分&#xff0c;是一种快速处理大型数据的方法。基本逻辑是折半查找。 设有一个共有 n n n 个数字的数组&#xff0c;要从中查询某个元素&#xff0c;就可以用二分查找。 注&#xff1a;这里的数组默认其成员数值具有单调性…

C++类和对象(总篇)

文章目录 C类和对象1、类的定义1.1类定义格式1.2访问限定符1.3类域 2、实例化2.1实例化概念 3、this指针4、类的默认成员函数5、构造函数5.1构造函数的特点5.2实例分析 6、析构函数6.1析构函数的特点6.2实例分析 7、拷贝构造函数7.1 拷贝构造函数的特点7.2实例分析7.3浅拷贝和深…

Linux中断管理

Linux 内核提供了完善的中断框架,我们只需要申请中断,然后注册中断处理函数即可,使用非常方便,不需要一系列复杂的寄存器配置。 1.Linux中断简介 中断号 每个中断都有一个中断号,通过中断号即可区分不同的中断,有的资料也把中断号叫做中断线。在 Linux 内核中使用一个 int 变…

神经网络—卷积层

1.讲解 Conv2d out_channels 参数为2时&#xff0c;会生成两个卷积核&#xff0c;分别与输入进行卷积。得到的两个输出为输出 新生成的卷积核和原来的卷积核不一定相同 in_channels (int) – Number of channels in the input image out_channels (int) – Number of channels…

Marching Cubes 算法再探

Marching Cubes 算法再探 基础过程代码mian.cppMarchingCubes.hMarchingCubes.cpp 之前做NeRF相关工作时简单看过&#xff0c;但没有深究其实现&#xff0c;知其然不知其所以然的程度&#xff0c;算是初探。 基础 为了对MC有大致了解&#xff0c;可以先根据Marching Cubes 算法…

两个实用的Python编程技巧

一、变量类型声明技巧 虽然在Python中可以不用声明变量的类型&#xff0c;但是为了加快程序的运算速度&#xff0c;减少不必要的bug&#xff0c;我们可以在定义变量之初就把它的类型确定&#xff0c;这样可以更好地传输变量值。如下面的例子。 我们定义了两个变量&#xff0c…

IO进程线程 240826作业

作业 创建3个进程,子进程1拷贝文件的前一半,子进程2拷贝后一半文件,父进程回收两个子进程资源。 将1.txt内容拷贝到2.txt中 #include <myhead.h> int main(int argc, const char *argv[]) {pid_t pid1;pid1 fork();int fd1 open("./1.txt",O_RDWR);if(fd1…

JavaWeb JavaScript ④ JS的对象和JSON

只要你的风格是适应客观规律的&#xff0c;那你以后会越来越好&#xff0c;做事情会越来越顺利 —— 24.8.26 一、JS创建对象 语法 方式1 new Object() 方式2 {属性名&#xff1a;属性值&#xff0c;… …&#xff0c;函数名&#xff1a;function(){}} 方式…

Python | Leetcode Python题解之第371题两整数之和

题目&#xff1a; 题解&#xff1a; MASK1 4294967296 # 2^32 MASK2 2147483648 # 2^31 MASK3 2147483647 # 2^31-1class Solution:def getSum(self, a: int, b: int) -> int:a % MASK1b % MASK1while b ! 0:carry ((a & b) << 1) % MASK1a (a ^ b) % MA…

Agent实际落地的应用 未来生活的无形助手

在这个信息爆炸的时代&#xff0c;我们每个人都在追求更高效的生活方式。想象一下&#xff0c;如果有一个无形的助手&#xff0c;能够理解我们的需求&#xff0c;自动处理繁琐的任务&#xff0c;甚至为我们提供个性化的建议&#xff0c;那将是多么美好的体验&#xff01;这正是…

线性DP经典题型

数字三角形&#x1f342; #include<bits/stdc.h> using namespace std; int main() {int n;cin>>n;vector<vector<int>>arr(n1,vector<int>(n1,0));for(int i 1;i<n;i){for(int j 1;j<i;j){cin>>arr[i][j];}}vector<vector<i…

【精选】分享9款AI毕业论文生成初稿题目网站

在当今学术研究领域&#xff0c;AI技术的应用日益广泛&#xff0c;尤其是在学术论文的撰写过程中。AI论文生成器的出现&#xff0c;极大地简化了学术写作流程&#xff0c;提高了写作效率。以下是9款推荐的AI毕业论文生成初稿的网站&#xff0c;它们各有特色&#xff0c;能够满足…

【Qt】多元素控件QTableWidget

多元素控件QTableWidget 使用QTableWidget表示一个表格控件&#xff0c;一个表格中包含若干行、每一个行又包含若干列。 表格中的每一个单元格&#xff0c;都是一个QTableWidget对象。 QTableWidget核心方法 方法说明 item(int row, int column) 根据⾏数列数获取指定的 Q…

【电路笔记】-运算放大器基础

运算放大器基础 文章目录 运算放大器基础1、概述2、运算放大器表示3、开环增益(Open-Loop Gain)4、输入和输出阻抗5、带宽6、偏移电压7、理想运算放大器模型7.1 饱和模式7.2 线性模式8、实际运算放大器9、总结1、概述 本文将介绍运算放大器(也称为运算放大器,Operational …

HandBrakeCLI 压缩工具的简单实用

HandBrakeCLI -i input.mp4 -o output.mp4 --encoder qsv_h264 -b 500k --preset "Android 576p25" --width 320 --height 576 --quiet--encoder qsv_h264 意思代表inter的gpu编码 -b 500k 设置比特率 --preset "Android 576p25" 设置预设 --width 320 --…

揭秘OTP与MTP:你的存储小秘密,一次性和多次可编程大不同!

NVM,即非易失性存储器,是一种非易失性内存。 NVM的特点是存储的数据在断电后不会消失。传统的NVM,如掩模ROM、可编程ROM(PROM)、可擦除可编程ROM(EPROM)、电可擦可编程ROM(EEPROM)、NAND/NOR闪存等,以及目前正在开发的许多新型状态存储器,如磁性存储器(MRAM)、电…

Jar包导入本地maven仓库

当jar包未引入到公共maven仓库时&#xff0c;直接通过maven坐标的方式引入会报错&#xff0c;找不到该依赖。所以可以将jar包导入到本地maven仓库&#xff0c;再通过maven坐标引入后就没有问题。 mvn install:install-file -Dfilexxxxxx.jar -DgroupIdcom.xx -DartifactIdxxxx…

idea debug 各个步骤含义

基本功能 IntelliJ IDEA 的 Debug 功能提供了强大的调试支持&#xff0c;允许开发者逐步执行代码&#xff0c;检查变量值&#xff0c;评估表达式等。以下是 Debug 模式中常见的几个按钮及其含义&#xff1a; Show Execution Point (显示执行点)&#xff1a;将光标跳转到当前正在…