本主题将从3个角度进行对比
1. 常见设置(CentOS 6 vs CentOS 7)
2. 服务管理(Sysvinit vs Upstart vs Systemd)
3. 性能测试(cpu/mem/io/oltp)
环境说明
硬件
- 服务器: Dell PowerEdge R620
- CPU: E5-2620 v2 @ 2.10GHz * 2
- MEM: 8G DDR3 1333 MHz * 4
- DISK: 300G SSD * 1
- BIOS: 默认
系统
- CentOS 6: CentOS 6.10 (2.6.32-754.el6.x86_64)
- CentOS 7: CentOS 7.5 (3.10.0-862.el7.x86_64)
一. 常见设置
1. 字符集
CentOS 6
- 方法: /etc/sysconfig/i18n
CentOS 7
- 方法1: localectl set-locale.utf8
- 方法2: /etc/locale.conf`中的LANG=
2. 主机名
CentOS 6
- 在线生效: hostname
- 重启生效: /etc/sysconfig/network中的HOSTNAME=
CentOS 7
- 在线+重启生效: hostnamectl set-hostname
3. 时区
CentOS 6
- 方法: ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
CentOS 7
- 方法1: 同CentOS 6
- 方法2: timedatectl set-timezone Asia/Shanghai
4. 时间同步
CentOS 6
- 逐步: ntpd或ntpdate
- 直接: ntpdate -b(通常加到crontab)
CentOS 7
- 方法1: systemctl start chronyd
- 方法2: timedatectl set-ntp yes(同systemctl start chronyd)
可以通过timedatectl | grep "NTP synchronized"判断当前时间是否已同步
不建议用ntpd和ntpdate,RedHat强烈推荐chrony,可用于网络不稳定的环境 chrony.conf关键参数
makestep 1.0 -1 ntpd和chronyd区别
5. 手动更改时间
CentOS 6
- 方法: date -s "2018-07-08 11:11:11"
CentOS 7
- 方法1: 同CentOS 6
- 方法2: timedatectl set-time "2018-07-08 11:11:12"(前提是timedatectl set-ntp false)
6. 单用户修改密码
CentOS 6: grub
界面键入 e
,在 kernel
行最后加 1
,键入 b
启动进入单用户模式,之后输入 passwd
修改密码
CentOS 7: grub
界面键入 e
,在 linux16
行上将 ro
改为 rw
,并在当前行最后加 init=/bin/sh
,键入 ctrl-x
进入,之后输入 passwd
修改密码
- 如果有开启selinux,则需要在修改密码后,重启前,执行 touch/.autorelabel
- passwd执行后,最好执行sync,防止强制重启导致修改密码没有落地
7. grub添加参数
CentOS 6:
-
/boot/grub/grub.conf的kernel中加入需要添加的参数
CentOS 7:
-
步骤1:/etc/default/grub的GRUBCMDLINELINUX中加入需要添加的参数
-
步骤2:grub2-mkconfig -o /boot/grub2/grub.cfg
8. 查看开机记录
CentOS 6: last
CentOS 7: journalctl --list-boots或last
9. 修改启动内核
1.查看当前启动内核
- CentOS 6: cat /boot/grub/grub.conf中的default
- CentOS 7: grub2-editenv list
2.查看有哪些内核
- CentOS 6: cat /boot/grub/grub.conf | sed -n '/^title/s/^title //p'
- CentOS 7: cat /boot/grub2/grub.cfg | grep '^menuentry' | awk -F"'" '{print $2}'
3.设置启动内核
CentOS 6:
- 修改/boot/grub/grub.conf中的default
CentOS 7:
- 步骤1:确保/etc/default/grub中的 GRUB_DEFAULT为saved
- 步骤2:grub2-set-default 'CentOS Linux (3.10.0-693.el7.x86_64) 7 (Core)'
10. rc.local
执行顺序
- CentOS 6: 串行的最后一个执行
- CentOS 7: 和其他服务并行执行
可执行权限
- CentOS 6: 默认有可执行权限
- CentOS 7: 默认没有可执行权限(官方不推荐使用rc.local),需要自行增加(chmod +x /etc/rc.d/rc.local)
CentOS 7的注意事项
- rc.local由rc-local.service执行,由于systemd服务是并行执行,仅能保证在network之后启动,因此建议rc.local里增加sleep 10来尽可能在最后执行
- 需要在rc.local的最后一行增加exit 0,否则可能导致已启动的进程被关闭(echo 'exit 0' >> /etc/rc.d/rc.local)
- 建议尽量使用systemd来配置服务,不要使用rc.local
11. limit配置
CentOS 6:
- 全局设置: 没有全局设置的方法(/etc/security/limits.conf仅针对使用pam的进程,且有加载pamlimits.so的模块,因为limits.conf是pamlimits.so的配置文件)
- 服务设置: 只能在服务启动前设置ulimit,才能在启动后看到效果
CentOS 7:
- 全局设置: /etc/systemd/system.conf里DefaultLimitNOFILE=65535
- 服务设置: [Service]里增加LimitNOFILE=65535
12. yum仅使用ipv4
CentOS 6: yum没有自带方法
CentOS 7: yum.conf里增加ip_resolve=4
13. 彻底禁用ipv6
CentOS 6和CentOS 7相同
- 在grub上增加ipv6.disable=1
查看是否彻底关闭
- sysctl -a | grep -i ipv6如果没有任何输出,则表示彻底关闭
14. 防火墙
CentOS 6
- 默认开启iptables服务,只不过默认没有条目
CentOS 7
- 默认安装并开启firewalld服务
- 默认不安装iptables服务(yum install iptables-services)
15. NetworkManager
CentOS 6: 默认未安装
CentOS 7: 默认安装并启动
16. 网卡名
CentOS 6:
- 系统安装完,默认是em1开始,这其实是在装机完成时在udev里做的绑定
- 把/etc/udev/rules.d/70-persistent-net.rules内容清空,则恢复成eth0开始编号
CentOS 7:
- 不再通过udev绑定网卡名,默认是em1开始,有的是eno、enp、ens等名字
- 如果想恢复eth0,则/etc/default/grub里增加net.ifnames=0 biosdevname=0
- 如果想让CentOS 6的网卡名不受udev影响,达到CentOS 7的效果,则删除3个文件即可
rm -f /etc/udev/rules.d/70-persistent-net.rules
rm -f /lib/udev/write_net_rules
rm -f /lib/udev/rules.d/75-persistent-net-generator.rules
网卡名规则
- eno:主板板载网卡
- enp:独立网卡(PCI网卡)
- ens:热插拔网卡(usb之类)
17. CPU频率(performance)
CentOS 6
-
始终:2.1GHz
CentOS 7:
-
空闲:1.2GHz
-
sysbench 1线程压测:一个物理cpu所有核的频率瞬间增长,其中最高打到2.6GHz
-
sysbench 42线程压测:所有cpu所有核的频率全部达到2.4GHz
-
若要和6一样保持频率,则在/etc/default/grub里增加intel_pstate=disable(不建议,因为性能没有任何提升,还在某些情况下降)
二. 服务管理
1. sysvinit、upstart、systemd简介
2. sysvinit、upstart、systemd常用命令
3. runlevel运行级别
4. 日志查询
CentOS 6: 手工在/var/log/messages、/var/log/dmesg、/var/log/secure中grep,麻烦且效率低
CentOS 7: 统一使用journalctl,可以使用多个因素匹配,比如时间段、服务名、日志级别等等。另外,systemd日志默认经过压缩,是二进制文件,无法直接查看
5. 实现守护进程
CentOS 6
-
sysvinit需要自行实现,如:
-
- nohup &
-
- screen
-
- supervisor
-
upstart和systemd类似,将程序运行在前台即可
CentOS 7
-
由systemd启动,将程序运行在前台即可
6. sysvinit、upstart、systemd例子
sysvinit
cat > /etc/init.d/mytest <<EOF
. /etc/rc.d/init.d/functions
start() { … }
stop() { … }
restart() { … }
reload() { … }
status() { … }
case "$1" in
start)
start ;;
stop)
stop ;;
…
esac
exit $RETVAL
EOF
chmod +x /etc/init.d/mytest
service mytest start
upstart
cat > /etc/init/mytest.conf <<EOF
start on runlevel [3]
description “mytest"
exec /root/mytest.sh
EOF
initctl start mytest
systemd
cat > /usr/lib/systemd/system/mytest.service <<EOF
[Unit]
Description=mytest
[Service]
Type=simple
ExecStart=/root/mytest.sh
[Install]
WantedBy=multi-user.target
EOF
systemctl start mytest
7. PID管理
sysvinit: 需要生成PID文件,用于后期关闭、重启等使用
upstart: 无需PID文件,upstart会记录主进程ID,子进程ID没有记录
systemd: 无需PID文件,所有进程ID由cgroup统一接管
8. 内置的资源限制
CentOS 6: 除了ulimit,没有其他限制进程资源的简便方法
CentOS 7: 除了ulimit,还支持部分cgroup限制,可对进程做内存限制和cpu资源限制等
[Service]
ExecStart=...
MemoryLimit=500M
CPUShares=100
另外,CentOS 7可以通过systemd-cgtop命令查看cgroup里的性能数据
9. 服务异常自动重启
upstart
start on runlevel [3]
description "mytest"
exec /root/mytest.sh
post-stop exec sleep 5
respawn
respawn limit unlimited
systemd
[Unit]
Description=mytest
[Service]
Type=simple
ExecStart=/root/mytest.sh
Restart=always
RestartSec=5
StartLimitInterval=0
[Install]
WantedBy=multi-user.target
上面2种方式均表示,无限次自动重启,每次重启前等待5秒
10. 写日志方式
CentOS 6: 自行输出到文件中,或通过syslog记录(如logger命令)
CentOS 7: 只要程序由systemd启动,只需将输出日志到标准输出或标准错误
-
建议centos7只将应用程序的一些元信息输出到标准输出或标准错误,比如启动成功、启动失败等等
-
不建议将业务日志输出到journal。因为journal中所有日志都存在一个文件中,会导致2个问题:
-
1. 如果没有做日志持久化,则默认存在内存中,会导致最多一半的内存被占用
-
2. 存储量很大,会导致查询其他日志很耗时
-
解决办法:输出到syslog,[Service]支持StandardOutput=syslog
11. 指定每条日志级别
CentOS 6: 通过syslog将不同级别的日志输出到不同文件
CentOS 7: 只需在输出的每一行开头加<日志级别>,比如
echo '<0>hello, emerg'
echo '<1>hello, alert'
echo '<2>hello, crit'
echo '<3>hello, err'
echo '<4>hello, warning'
echo '<5>hello, notice'
echo '<6>hello, info'
echo '<7>hello, debug'
12. systemd日志永久保存
systemd日志默认保存在内存中,因此当服务器重启后,就无法通过journalctl来查看之前的日志,解决方法:
mkdir -p /var/log/journal
systemctl restart systemd-journald
三. 性能对比
1. CPU测试
工具: 通过sysbench对cpu进行压力测试
参数设置
-
素数: 10000
-
测试时间: 900秒
-
线程数: 1、6、12、18、24、30、36、42
分别测试使用睿频和不实用睿频
> 图1: cpu测试 - 每秒events
如何看图:越高越好
此图结论:
-
cpu性能基本一致
-
CentOS 7固定频率(不使用睿频),并没有提升性能,因此没有关闭睿频的必要
> 图2: cpu测试 - event数量标准差
如何看图:越少越好
此图结论:
-
通过标准差可以看出在稳定性方面,CentOS 7要稳定很多(包括不使用睿频)
2. 内存测试
工具: 通过sysbench对内存进行压力测试
参数设置
-
读写方式: 随机
-
测试时间: 900秒
-
分别测试读和写
-
块大小: 4K、16K、2M
-
线程数: 1、12、24、36、48
> 图1: 内存测试 - 速率
如何看图:越高越好
此图结论:
-
CentOS 6和CentOS 7性能一致
> 图2: 内存测试 - event数量标准差
如何看图:越少越好
此图结论:
-
通过标准差可以看出在稳定性方面,CentOS 7要稳定很多
3. IO测试
工具: 通过fio对io进行压力测试
参数设置
- ioengine: libaio
- iodepth: 16
- 测试时间: 900秒
- 文件大小: 100G
- 运行方式: 线程
- 缓存方式: 无缓存(non-buffered I/O)
- 读写方式: 随机读写
- 块大小: 分别测试4K和16K
- 线程数: 1、12、24、36、48
> 图1: io测试 - iops
如何看图:越高越好
此图结论:
- CentOS 6(默认ext4)不如CentOS 7(默认xfs)
- CentOS 6(默认ext4)不如CentOS 6(xfs)
> 图2: io测试 - 读写平均延时
如何看图:越少越好
此图结论:
- CentOS 7的写延时和CentOS 6(默认ext4)接近
- CentOS 7的读延时比CentOS 6(默认ext4)好很多
4. OLTP测试
工具: 通过tpcc-mysql对整机性能进行测试
参数设置
- 文件系统: 均为xfs
- mysql版本: mysql-8.0.12
- tpccload:
- warehouse: 100
- sql: createtable.sql、addfkeyidx.sql
- 运行时长: 没有限制,跑完将近1小时
- tpcc_start:
- warehouse: 100
- warmup: 300秒
- 运行时长: 1800秒
- 线程数: 16、32、64、128、256、512、1024
> 图: oltp测试 - tpmc
如何看图:越高越好
此图结论:
- CentOS 7比CentOS 6(默认ext4)高
5. 总结
总结:7个测试结果中,只有2项是基本一致,其余5项均是CentOS 7胜利,因此基本可以得出结论,CentOS 7性能比CentOS 6更好!