菜单

CentOS7本子基础运用

2019年4月8日 - UNIXSolaris

第1章 CentOS7的使用

概要

应DBA须要,要求将一台线下测试机内核版本从此时此刻的2本子升级到叁以上版本,在此以前在投机虚拟机里做过编写翻译升级,不过在其后采纳中相遇很多难题,是因为在新的config文件中,暗许有众多模块被诠释掉,导致使用新的默许config文件编写翻译后很多模块不能够加载使用,比如itpables的NAT模块,Docker也就不能安装了,为了幸免这一个题材吧,此次升迁希望选取yum格局自行升级。

一.壹 为何要采用CentOS7版本

CentOS7是在CentOS陆基础上表露的新本子,与前面包车型地铁本子对照,首要的更新包涵:

壹、内核更新到叁.10.0

2、支持Linux容器

三、LVM快速照相帮忙ext4和XFS

4、转用systemd、firewalld和GRUB2

5、XFS作为缺省文件系统

6、支持PTPv2

7、支持40G 以太网卡

八、在同盟的硬件上支撑以UEFI安全开发银行格局安装

这其间最在意的新特征就是永葆Docker技术。作为当下风行的运用虚拟化技术之一,Docker能够将应用程序与系统完全隔开分离,让其在系统里面完成迁移而不要求停机,升高了应用程序的移动性和灵活性。CentOS七在基本层面帮衬Docker容器技术,能够做实Docker稳定性和可信赖性。

综上,大家会选拔CentOS7来作为服务器的操作系统。

晋级历程

在素有不曾展开过类似操作的前提下呢,第2步当然必要google了,但是并不曾找到描述清晰的言传身教,所以不得不去官网看英文文书档案了(英文很差的自小编骨子里是充裕拒绝的)。。。没悟出的是竟然这么这么的简要。。。

 http://elrepo.org/tiki/tiki-index.php

先看一下地面yum仓库中相继kernel的版本

[root@localhost ~]# yum list | grep kernel
abrt-addon-kerneloops.x86_64            2.0.8-34.el6.centos         @anaconda-CentOS-201508042137.x86_64/6.7
dracut-kernel.noarch                    004-388.el6                 @anaconda-CentOS-201508042137.x86_64/6.7
kernel.x86_64                           2.6.32-573.el6              @anaconda-CentOS-201508042137.x86_64/6.7
kernel-devel.x86_64                     2.6.32-573.el6              @anaconda-CentOS-201508042137.x86_64/6.7
kernel-firmware.noarch                  2.6.32-573.el6              @anaconda-CentOS-201508042137.x86_64/6.7
kernel-headers.x86_64                   2.6.32-573.el6              @anaconda-CentOS-201508042137.x86_64/6.7
libreport-plugin-kerneloops.x86_64      2.0.9-24.el6.centos         @anaconda-CentOS-201508042137.x86_64/6.7
abrt-addon-kerneloops.x86_64            2.0.8-43.el6.centos         base        
dracut-kernel.noarch                    004-409.el6_8.2             base        
kernel.x86_64                           2.6.32-696.6.3.el6          updates     
kernel-abi-whitelists.noarch            2.6.32-696.6.3.el6          updates     
kernel-debug.x86_64                     2.6.32-696.6.3.el6          updates     
kernel-debug-devel.i686                 2.6.32-696.6.3.el6          updates     
kernel-debug-devel.x86_64               2.6.32-696.6.3.el6          updates     
kernel-devel.x86_64                     2.6.32-696.6.3.el6          updates     
kernel-doc.noarch                       2.6.32-696.6.3.el6          updates     
kernel-firmware.noarch                  2.6.32-696.6.3.el6          updates     
kernel-headers.x86_64                   2.6.32-696.6.3.el6          updates     
libreport-plugin-kerneloops.x86_64      2.0.9-33.el6.centos         base        
[root@localhost ~]# 

本来意料之中都和当前已运行的kernel版本相差无几

[root@localhost ~]# uname -r
2.6.32-573.el6.x86_64
[root@localhost ~]# 

根据官网提醒,安装新的yum仓库,已得到合法脚下提供的较新本子的安装包

#导入KEY,必要的步骤
[root@localhost ~]# rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org
#安装elrepo,根据CentOS版本进行选择
[root@localhost ~]# rpm -Uvh http://www.elrepo.org/elrepo-release-6-8.el6.elrepo.noarch.rpm
Retrieving http://www.elrepo.org/elrepo-release-6-8.el6.elrepo.noarch.rpm
Preparing...                ########################################### [100%]
   1:elrepo-release         ########################################### [100%]
[root@localhost ~]# 

那几个库房里富含了[elrepo]、[elrepo-testing]、[elrepo-kernel]、[elrepo-extras]三个仓库,暗中同意仅启用了[elrepo],那里我们供给启用[elrepo-kernel]仓库

#这里我们直接编辑elrepo配置文件,将[elrepo-kernel]模块中的enable置为1,或直接使用yum --ebable即可
[root@localhost ~]# vi /etc/yum.repos.d/elrepo.repo
[elrepo-kernel]
name=ELRepo.org Community Enterprise Linux Kernel Repository - el6
baseurl=http://elrepo.org/linux/kernel/el6/$basearch/
        http://mirrors.coreix.net/elrepo/kernel/el6/$basearch/
        http://mirror.rackspace.com/elrepo/kernel/el6/$basearch/
        http://repos.lax-noc.com/elrepo/kernel/el6/$basearch/
        http://mirror.ventraip.net.au/elrepo/kernel/el6/$basearch/
mirrorlist=http://mirrors.elrepo.org/mirrors-elrepo-kernel.el6
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-elrepo.org
protect=0

本条时候重新翻开一下大家yum源中存在的kernel版本,供给的新本子已经得以行使了

[root@localhost ~]# yum list | grep kernel
abrt-addon-kerneloops.x86_64            2.0.8-34.el6.centos         @anaconda-CentOS-201508042137.x86_64/6.7
dracut-kernel.noarch                    004-388.el6                 @anaconda-CentOS-201508042137.x86_64/6.7
kernel.x86_64                           2.6.32-573.el6              @anaconda-CentOS-201508042137.x86_64/6.7
kernel-devel.x86_64                     2.6.32-573.el6              @anaconda-CentOS-201508042137.x86_64/6.7
kernel-firmware.noarch                  2.6.32-573.el6              @anaconda-CentOS-201508042137.x86_64/6.7
kernel-headers.x86_64                   2.6.32-573.el6              @anaconda-CentOS-201508042137.x86_64/6.7
libreport-plugin-kerneloops.x86_64      2.0.9-24.el6.centos         @anaconda-CentOS-201508042137.x86_64/6.7
abrt-addon-kerneloops.x86_64            2.0.8-43.el6.centos         base       
dracut-kernel.noarch                    004-409.el6_8.2             base       
kernel.x86_64                           2.6.32-696.6.3.el6          updates     
kernel-abi-whitelists.noarch            2.6.32-696.6.3.el6          updates     
kernel-debug.x86_64                     2.6.32-696.6.3.el6          updates     
kernel-debug-devel.i686                 2.6.32-696.6.3.el6          updates     
kernel-debug-devel.x86_64               2.6.32-696.6.3.el6          updates     
kernel-devel.x86_64                     2.6.32-696.6.3.el6          updates     
kernel-doc.noarch                       2.6.32-696.6.3.el6          updates     
kernel-firmware.noarch                  2.6.32-696.6.3.el6          updates     
kernel-headers.x86_64                   2.6.32-696.6.3.el6          updates     
kernel-lt.x86_64                        3.10.107-1.el6.elrepo       elrepo-kernel
kernel-lt-devel.x86_64                  3.10.107-1.el6.elrepo       elrepo-kernel
kernel-lt-doc.noarch                    3.10.107-1.el6.elrepo       elrepo-kernel
kernel-lt-firmware.noarch               3.10.107-1.el6.elrepo       elrepo-kernel
kernel-lt-headers.x86_64                3.10.107-1.el6.elrepo       elrepo-kernel
kernel-ml.x86_64                        4.12.8-1.el6.elrepo         elrepo-kernel
kernel-ml-devel.x86_64                  4.12.8-1.el6.elrepo         elrepo-kernel
kernel-ml-doc.noarch                    4.12.8-1.el6.elrepo         elrepo-kernel
kernel-ml-firmware.noarch               4.12.8-1.el6.elrepo         elrepo-kernel
kernel-ml-headers.x86_64                4.12.8-1.el6.elrepo         elrepo-kernel
libreport-plugin-kerneloops.x86_64      2.0.9-33.el6.centos         base       
perf.x86_64                             4.12.8-1.el6.elrepo         elrepo-kernel
python-perf.x86_64                      4.12.8-1.el6.elrepo         elrepo-kernel
[root@localhost ~]#

此处大家选择大家必要的三.0版本进行设置,命名格式name+version,那么大家一贯使用yum实行点名版本安装

#如果不确定可以先不使用-y选项,在结果中查看对应版本后在确认安装即可
[root@localhost ~]# yum install kernel-lt-3.10.107-1.el6.elrepo
Dependencies Resolved

========================================================================================================================================================================================================================
 Package               Arch                     Version                    Repository               Size
============================================================================================================================================================================================================================================
Installing:
 kernel-lt            x86_64             3.10.107-1.el6.elrepo           elrepo-kernel              33 M

Transaction Summary
============================================================================================================================================================================================================================================
Install       1 Package(s)

Total download size: 33 M
Installed size: 154 M
Is this ok [y/N]: y

坐等安装成功即可。
设置到位后需求大家开始展览末段一步神圣的操作,接纳暗许运维的grub为新本子。

#编辑grub启动文件,这款需要注意两个值,default和title
[root@localhost ~]# vi /etc/grub.conf 
#default选择默认启动的title标号,自上而下从0开始计数,那么我们一般新安装的kernel呢会出出现在第一个title中,所以我们将default的值改为0,即默认选择第一个title后的kernel进行启动
default=0
#每个title后跟一个以安装的kernel版本信息
title CentOS (3.10.107-1.el6.elrepo.x86_64)
    root (hd0,0)
    kernel /vmlinuz-3.10.107-1.el6.elrepo.x86_64 ro root=UUID=97b15044-9109-48d4-bf6c-a3e87e46ad3c rd_NO_LUKS rd_NO_LVM LANG=en_US.UTF-8 rd_NO_MD SYSFONT=latarcyrheb-sun16 crashkernel=auto  KEYBOARDTYPE=pc KEYTABLE=us rd_NO_DM rhgb
quiet
    initrd /initramfs-3.10.107-1.el6.elrepo.x86_64.img

title CentOS 6 (2.6.32-573.el6.x86_64)
    root (hd0,0)
    kernel /vmlinuz-2.6.32-573.el6.x86_64 ro root=UUID=97b15044-9109-48d4-bf6c-a3e87e46ad3c rd_NO_LUKS rd_NO_LVM LANG=en_US.UTF-8 rd_NO_MD SYSFONT=latarcyrheb-sun16 crashkernel=auto  KEYBOARDTYPE=pc KEYTABLE=us rd_NO_DM rhgb quiet
    initrd /initramfs-2.6.32-573.el6.x86_64.img

重启系统,让系统运用新本子的kernel进行运维,运营后翻看内核版本,KO~!

[root@localhost ~]# uname -r
3.10.107-1.el6.elrepo.x86_64
[root@localhost ~]# 

第壹章 CentOS七与CentOS陆版本的区分

二.一 系统基础服务浮动

操作

Centos6

Centos7

对比

自动补全

只支持命令、文件名

支持命令、选项、文件名

 

文件系统

ext4       

xfs                

随机读写更快

repo仓库

yum

yum-config-manager  

添加仓库便捷

修改主机名

/etc/sysconfig/network

/etc/hostname            

hostnamectl

修改时区    

/etc/sysconfig/clock

timedatectl set-timezone   

更方便

修改字符集

/etc/sysconfig/il8n    

/etc/locale.conf           

localectl

防火墙

iptables

firewalld

 

服务管理

System V init

systemd

 

时间同步服务

ntp

chrony 

 

 

贰.二 系统文件目录结构

centos6

cetos7

bin 

usr/bin

sbin

usr/sbin

lib

usr/lib

二.叁 修改主机名

贰.3.1 centos陆落到实处情势

临时修改主机名

[root@zeq ~]# hostname zeq_temp

[root@zeq ~]# bash

[root@zeq_temp ~]#

永久修改主机名

[root@zeq_temp ~]# sed -i '/^HOSTNAME=/c HOSTNAME=zeq' /etc/sysconfig/network

[root@zeq_temp ~]# cat /etc/sysconfig/network

NETWORKING=yes

HOSTNAME=zeq

贰.三.二 centos柒兑现格局

临时修改主机名

[root@zeq ~]# hostname zeq-c7

[root@zeq ~]# bash

永久修改主机名

[root@zeq-c7 ~]# hostnamectl set-hostname zeq-cc7

[root@zeq-c7 ~]# cat /etc/hostname

zeq-cc7

二.四 时区修改

2.四.一 查看时区

[root@zeq ~]# timedatectl list-timezones

贰.四.二 修改时区

[root@zeq ~]#timedatectl set-timezone "America/Punta_Arenas" 

[root@zeq ~]# timedatectl set-timezone "Asia/Shanghai"

贰.五 网络接口变化

net.ifnames
基于固件、拓扑、进行活动分配网卡名称,缺点比eth0、更难读,如ens3二

biosdevname
依据戴尔服务器系统的BIOS提供的音信对互连网接口进行重命名,如em壹

暗中认可命名规则 eth0 eth一 eth二

biosdevname em1 em2 em3

net.ifnames ens33 ens34 ens35

二.5.一 centos7应用ip命令查看ip地址方法

1.翻看ip地址新闻 ip addr

贰.添加两个IP地址 ip addr add 192.168.5陆.200/二四 dev eth0:一

3.操纵网络接口 ip link set dev eth0 down

贰.陆 Systemd服务概述

Systemd初始

Systemd是Centos七新利用的壹套管理系列,能够达成运转及进度服务管理等,相比较Centos陆种类在此以前所选拔sysVini连串,带来了累累变更。

Centos7支撑互相运转,分明抓实开机运转作用(测试陆与七区分)

Centos7关机只关闭正在运行的劳动,Centos陆关机会从头关到尾

Centos7劳动的开行与甘休不在需求init.d下的剧本

②.柒 systemd运行级别

在Centos7中尚无级别的概念,而是利用target指标来含有运行级别的定义

SysVinit     

级别

Systemd

关闭系统

0

runlevel0.target,poweroff.target

单用户模式

1

runlevel1.target,rescue.target

多用户模式

2

runlevel2.target,multi-user.target

多用户带网络模式

3

runlevel3.target,multi-user.target

多用户图形化模式  

5

runlevel5.target,graphical-user.target

重启操作系统

6

runlevel6.target,reboot.target

Centos七开机默许系统运营指标target

multi-user.target: analogous to runlevel 3

graphical.target: analogous to runlevel 5

二.柒.一 查看系统当下暗中认可运转级别(指标)

[root@zeq ~]# systemctl get-default

multi-user.target

贰.柒.2 修改系统运营暗中认可级别(指标)

[root@zeq ~]# systemctl set-default runlevel5.target

建议修改回去

[root@zeq ~]# systemctl set-default multi-user.target

2.七.3 centos柒关机指令

poweroff、shutdown -h now、init0 (不提出采纳)

reboot

贰.八 systemd服务管理

指令 选项(非必须) 执行命令 单元名称(非必须)

systemctl [OPTIONS…]COMMAND[NAME…]

操作

Centos6

Centos7

启动服务

/etc/init.d/crond start

systemctl start     crond

停止服务

/etc/init.d/crond stop

systemctl stop      crond

重启服务

/etc/init.d/crond restart

systemctl restart   crond

查看状态

/etc/init.d/crond status

systemctl status    crond

开机启动

chkconfig –level 35 crond on

systemctl enable    crond

开机禁用

chkconfig crond off

systemctl disable   crond

禁止运行

 

systemctl umask     crond

贰.八.一 centos7上的service命令依旧为了包容centos陆的习惯

[root@zeq ~]# service crond restart

Redirecting to /bin/systemctl restart crond.service

二.8.二 centos7起步与甘休建议使用systemctl

[root@zeq ~]# systemctl restart crond

贰.八.三 centos七查看全体的服务开机运行和开机不运营的单元

[root@zeq ~]# systemctl list-unit-files

2.捌.肆 centos7开机不自启

[root@zeq ~]# systemctl disable crond

二.8.伍 centos7开机自启

[root@zeq ~]# systemctl enable crond

二.捌.6 centos7反省是不是开机自启

[root@zeq ~]# systemctl is-enabled crond

disabled

第二章 CentOS7体系优化

3.1 调整yum源

rm -rf /etc/yum.repos.d/*

curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo

三.二 清理缓存,不分厚薄新生成缓存文件

yum clean all

yum makecache

3.3 安装基础软件包

yum install net-tools vim tree htop iotop iftop \

iotop lrzsz sl wget unzip telnet nmap nc psmisc \

dos2unix bash-completion sysstat rsync nfs-utils -y

叁.肆 关闭防火墙

systemctl disable firewalld

systemctl stop firewalld

3.5 关闭selinux

sed -i '/^SELINUX=/c SELINUX=disabled' /etc/selinux/config

3.6 优化ulimit

echo '* - nofile 65535' >> /etc/security/limits.conf

3.7 执行shutdown -h now 关闭Centos7系统

三.8 选中对应的虚拟机->快速照相->拍录快速照相

第一章 参考文献

参照与徐亮伟(标杆徐)的讲课:http://www.xuliangwei.com

 

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图