linux基础(五)

时间:2023-03-08 20:21:06

一、linux网络原理及基础设置

ifconfig 命令:显示所有正在启动的网卡的详细信息或设定系统中网卡的IP地址。

[root@bogon ~]# ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.0.108 netmask 255.255.255.0 broadcast 192.168.0.255
inet6 fe80::8c6c:c7be:1c12:9ddc prefixlen 64 scopeid 0x20<link>
ether 00:0c:29:b8:b3:a4 txqueuelen 1000 (Ethernet)
RX packets 1974 bytes 1815266 (1.7 MiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 428 bytes 42066 (41.0 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
inet6 ::1 prefixlen 128 scopeid 0x10<host>
loop txqueuelen 1 (Local Loopback)
RX packets 6 bytes 536 (536.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 6 bytes 536 (536.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 virbr0: flags=4099<UP,BROADCAST,MULTICAST> mtu 1500
inet 192.168.122.1 netmask 255.255.255.0 broadcast 192.168.122.255
ether 52:54:00:ee:81:cc txqueuelen 1000 (Ethernet)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

ens33代表网卡

inet 后面的192.168.0.108 就是IP地址

netmask 是子网掩码

ether 是mac地址

mtu 指最大传输单元,默认一次最多1500字节

lo 是本地回环网卡,第二行分别表示ip地址和子网掩码,本地回环网卡的IP地址默认就是127.0.0.1

virbr0是虚拟机的网卡

可以用ifconfig修改IP地址和子网掩码

例:修改ens33网卡的IP地址为192.18.16.56和子网掩码255.255.255.100的命令:
  ifconfig ens33 192.18.16.56 netmask 255.255.255.128

[root@bogon ~]# ifconfig ens33 192.18.16.56 netmask 255.255.255.128
[root@bogon ~]# ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.18.16.56 netmask 255.255.255.128 broadcast 192.18.16.127
inet6 fe80::8c6c:c7be:1c12:9ddc prefixlen 64 scopeid 0x20<link>
ether 00:0c:29:b8:b3:a4 txqueuelen 1000 (Ethernet)
RX packets 11201 bytes 4780758 (4.5 MiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 568 bytes 56374 (55.0 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
inet6 ::1 prefixlen 128 scopeid 0x10<host>
loop txqueuelen 1 (Local Loopback)
RX packets 30 bytes 3032 (2.9 KiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 30 bytes 3032 (2.9 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 virbr0: flags=4099<UP,BROADCAST,MULTICAST> mtu 1500
inet 192.168.122.1 netmask 255.255.255.0 broadcast 192.168.122.255
ether 52:54:00:ee:81:cc txqueuelen 1000 (Ethernet)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

但这种操作只是临时修改,要想永久修改必须修改配置文件,网卡的配置文件存放在/etc/sysconfig/network-scripts目录中,且每个网卡对应的配置文件的文件名以ifcfg-开始,如ens33这个网卡对应的网络配置文件就是ifcfg-ens33。

用vim编辑器修改配置文件

把BOOTROTO改成static

写入以下几个命令

IPADDR=要改的IP地址

NETMASK=子网掩码

GATEWAY=网关

DNS=202.106.0.20(改成自己指定的DNS)

最后,ONBOOT要改成yes

TYPE=Ethernet
BOOTPROTO=static
IPADDR=192.168.0.20
NETMASK=255.255.255.0
GATEWAY=192.168.0.254
DNS1=192.168.0.254
DNS2=202.106.0.20
DNS3=8.8.8.8
NAME=ens33
UUID=6e166b31-83c8-4a37-b31e-71c82062889b
DEVICE=ens33
ONBOOT=yes
PEERDNS=yes
PEERROUTES=yes
IPV6_PEERDNS=yes
IPV6_PEERROUTES=yes

保存退出后,重启网络服务就可以生效了

centos7重启网络服务的命令是:systemctl restart network

再次用ifconfig命令查看,可以发现IP,网关,子网掩码都已经修改成功了

[root@localhost network-scripts]# ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.0.100 netmask 255.255.255.0 broadcast 192.168.0.255
inet6 fe80::8c6c:c7be:1c12:9ddc prefixlen 64 scopeid 0x20<link>
ether 00:0c:29:b8:b3:a4 txqueuelen 1000 (Ethernet)
RX packets 71 bytes 10926 (10.6 KiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 114 bytes 12259 (11.9 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
inet6 ::1 prefixlen 128 scopeid 0x10<host>
loop txqueuelen 1 (Local Loopback)
RX packets 9 bytes 872 (872.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 9 bytes 872 (872.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 virbr0: flags=4099<UP,BROADCAST,MULTICAST> mtu 1500
inet 192.168.122.1 netmask 255.255.255.0 broadcast 192.168.122.255
ether 52:54:00:ee:81:cc txqueuelen 1000 (Ethernet)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 [root@localhost network-scripts]# ping www.baidu.com
PING www.a.shifen.com (119.75.217.109) 56(84) bytes of data.
64 bytes from 119.75.217.109 (119.75.217.109): icmp_seq=1 ttl=54 time=7.98 ms
64 bytes from 119.75.217.109 (119.75.217.109): icmp_seq=2 ttl=54 time=5.60 ms
64 bytes from 119.75.217.109 (119.75.217.109): icmp_seq=3 ttl=54 time=8.82 ms
64 bytes from 119.75.217.109 (119.75.217.109): icmp_seq=4 ttl=54 time=6.72 ms

查看网关的命令是route -n,可以自己添加网关,命令是:route add default gw 网关地址 dev 网卡名

DNS的配置文件在/etc/resolv.conf里

本地解析的配置文件在/etc/hosts里,可以自己设置IP和域名的对应关系,优先级比DNS高

二、软件包管理(rpm命令)

1.安装命令:rpm -ivh 软件包位置

2.查看是否安装:rpm -q 软件名

查看软件包中所包含的所有文件:rpm -ql 软件名

查看软件包详细信息:rpm -qi 软件名

查看某条命令是哪个软件包产生的:rpm -qf 命令的绝对路径

查看所有安装的软件:rpm -qa

3.卸载命令:rpm -e 软件名

在命令后面加上 --nodeps 可以忽略依赖性卸载

rpm命令安装软件是存在依赖性问题的,yum命令可以避免这个问题

三、yum命令管理软件包

yum(全称为 Yellow dog Updater, Modified)是一个Shell前端软件包管理器。基于rpm包管理,能够从指定的服务器自动下载rpm包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软体包,常用的命令有:

yum install 软件包名 -y   :安装

yum list :列出有哪些软件包

yum grouplist :列出有哪些组

yum clean all :清除yum缓存

yum makecache -y :自己制作缓存

yum remove 软件名 -y :卸载

yum之所以能自动下载rpm包,是因为它有指定的yum源,我们也可以自己指定yum源。yum源文件在/etc/yum.repos.d/ 下,进入该目录后可以发现有一些.repo 文件,在Centos-Base.repo中的[base]标题下就指定了yum源。

[base]
name=CentOS-$releasever - Base
mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=os&infra=$infra
#baseurl=http://mirror.centos.org/centos/$releasever/os/$basearch/
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7

同样我们也可以自己写一个本地yum源,Centos光盘中就有许多rpm包,存放在Packages下,但我们要指定Packages的上层目录作为源,我们创建一个local.repo的文件,文件内容如下:

[root@localhost yum.repos.d]# vim local.repo 

[local]                  #标题行,内容无要求,但必须有
name=local repo for test
baseurl=file:///opt #如果是网络源,baseurl后面就要写http://
enabled=1 #表示开启yum源
gpgcheck=0 #表示不检测key
~

写好以后保存退出,测试时可以先把之前文件夹下的其他repo文件移动到其他文件夹,重新安装一个软件,可以发现安装过程中不会从网络下载东西