本主題將從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之類)
參考:https://www.cnblogs.com/chia/p/7379775.html
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更好!
微信: 小慢哥Linux運維
每週一文,輕鬆學Linux運維
個人網站fzxiaomange.com