第二阶段:高级核心基础知识·第4章shell特性·2

1.统计日志,日志内容

39.96.187.239 - - [11/Nov/2019:10:08:01 +0800] "GET / HTTP/1.1" 302 0 "-" "Zabbix"

211.162.238.91 - - [11/Nov/2019:10:08:02 +0800] "GET /api/v1/course_sub/category/list/?belong=1 HTTP/1.1" 200 363 "https://www.luffycity.com/free" "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36"

211.162.238.91 - - [11/Nov/2019:10:08:02 +0800] "GET /api/v1/degree_course/ HTTP/1.1" 200 370 "https://www.luffycity.com/free" "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36"

统计日志的访客ip数量

[root@huahua-centos7-aliyun luffy]# cat log.txt | awk '{print $1}' | sort -r | uniq  | wc -l
2

查看访问最频繁的前10个ip

[root@huahua-centos7-aliyun luffy]# cat log.txt | awk '{print $1}' | sort -nr | uniq  -c | tail -10
      2 211.162.238.91
      1 39.96.187.239
[root@huahua-centos7-aliyun luffy]# 

2.查看linux的定时任务列表

[root@huahua-centos7-aliyun ~]# crontab -l

*/1 * * * * root echo "hello world!"

3.每晚0点整,把站点目录/var/www/html下的内容打包备份到/data目录下

[root@vm-main data]# crontab -e

*/1 * * * *  tar -zcPf /data/log.tgz /var/log/www/*

4.每5分钟让服务器进行时间同步

*/5 * * * *  /usr/sbin/ntpdate ntp.tencent.com

5.在每天的10:31开始,每隔2小时重复一次

31 10-23/2 * * *  /usr/sbin/ntpdate ntp.tencent.com

6.每周六凌晨4:00执行

00 4 * * 6  /usr/sbin/ntpdate ntp.tencent.com

7.linux对磁盘分区格式化的命令

mkfs

8.解释inode与block的含义

inode

   中文名叫索引节点,是存放文件的元信息(文件创建者,日期,大小等,可以通过stat

查看)和文件的实体指针(指向block的位置,这也是inode和block的关系)的区域。

inode 的大小一般为128-256字节,inode节点总数在格式化时就决定了

 

block

   block就是存放实际文件数据的单元,单个文件占多个block存储,通过inode寻找block

一个block最少4K,也就意味着你创建一个文件至少需要一个block也就是4k

9.格式化分区/dev/sdc1为xfs文件系统(提示:注意格式化分区文件系统前,检查好当前分区是否在用,是否重要,明确后再自己本地虚拟机实验)

mkfs.xfs /dev/sdc1

10.简述buffers和cache含义及作用

cache是缓存,cached是给读取数据时加速的cached是指把读取出来的数据保存在内存中,再次读取,不用读取硬盘而直接从内存中读取,加速数据读取过程。

buffers是缓冲buffers是指写入数据时,把分散的写入操作保存到内存,达到一定程度集中写入硬盘,减少磁盘碎片,以及反复的寻道时间,加速数据写入。

11.简述raid不同级别的区别

raid 0:

  将两个或以上相同型号,容量的磁盘组合,磁盘阵列的总容量便是多个硬盘的总和,

数据依次写入物理硬盘,理想状态下,硬盘读写性能翻倍,但是任意一块磁盘损坏会导致,

所有数据丢失。raid 0适用于对数据安全性不太关注,追求性能的场景。

raid 1:

  是将两块硬盘以上硬盘绑定,数据写入时,同时写入多个硬盘,因此即使有硬盘故障,

也有数据备份。raid 1的利用率很低,冗余性高。

raid 3:

  通过异或运算:数字相同则为0,数字不同则为1。只要存储异或结果的磁盘不坏,其他

任意坏一块磁盘都可以通过异或运算反推恢复数据,最少三块磁盘,同样浪费一块磁盘。

存放异或运算的磁盘不能损坏。

raid 5:

  需要四块硬盘,也是通过异或运算,但是异或运算的结果是会均匀的放在每一块硬盘上,

如disk 1存放disk 2,3,4的结果,这样任意一块磁盘损坏都能恢复数据了,提高的容错率,

但是也仅仅是只能挂掉一块硬盘。

raid 10:

  raid 10 其实是raid 0 加上raid 1,吸收了raid 0的效率,raid 1的安全性,因此需要四块

12.简述lvm创建流程

1.物理分区阶段:将物理磁盘fdisk格式化修改System ID为LVM标记(8e)

2.PV阶段:通过pvcreate、pvdisplay将Linux分区处理为物理卷PV

pvcreate /dev/sdc /dev/sdd

3.VG阶段:接下来通过vgcreate、vgdisplay将创建好的物理卷PV处理为卷组VG

vgcreate storage  /dev/sdc /dev/sdd

4.LV阶段:通过lvcreate将卷组分成若干个逻辑卷LV

lvcreate -n lvm-test -L 100M storage

5.开始使用:通过mkfs对LV格式化,最后挂载LV使用

mkfs.xfs /dev/storage/lvm-test

mount /dev/storage/lvm-test /LVN-TEST/

13.简述lvm动态扩容流程

[root@vm-main /]# lvs

 LV    VG    Attr    LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert

 root   centos  -wi-ao---- 17.80g

 swap   centos  -wi-ao----  2.00g

 lvm-test storage -wi-ao----  1.20g

[root@vm-main /]# lvextend -L 1.5G /dev/storage/lvm-test

 Size of logical volume storage/lvm-test changed from 1.20 GiB (308 extents) to 1.50 GiB (384 extents).

 Logical volume storage/lvm-test successfully resized.

[root@vm-main /]# df -h

Filesystem           Size  Used Avail Use% Mounted on

/dev/mapper/centos-root     18G  2.2G  16G  13% /

devtmpfs            478M   0  478M  0% /dev

tmpfs              489M   0  489M  0% /dev/shm

tmpfs              489M  6.9M  482M  2% /run

tmpfs              489M   0  489M  0% /sys/fs/cgroup

/dev/sdb1            10G  59M  10G  1% /data

/dev/sda1            197M  103M  95M  53% /boot

tmpfs              98M   0  98M  0% /run/user/0

/dev/mapper/storage-lvm--test  1.2G  26M  1.2G  3% /LVN-TEST

[root@vm-main /]# xfs_growfs /dev/storage/lvm-test

meta-data=/dev/mapper/storage-lvm--test isize=512   agcount=10, agsize=32000 blks

​     =            sectsz=512  attr=2, projid32bit=1

​     =            crc=1     finobt=0 spinodes=0

data   =            bsize=4096  blocks=315392, imaxpct=25

​     =            sunit=0    swidth=0 blks

naming  =version 2        bsize=4096  ascii-ci=0 ftype=1

log    =internal        bsize=4096  blocks=855, version=2

​     =            sectsz=512  sunit=0 blks, lazy-count=1

realtime =none          extsz=4096  blocks=0, rtextents=0

data blocks changed from 315392 to 393216

[root@vm-main /]# df -h

Filesystem           Size  Used Avail Use% Mounted on

/dev/mapper/centos-root     18G  2.2G  16G  13% /

devtmpfs            478M   0  478M  0% /dev

tmpfs              489M   0  489M  0% /dev/shm

tmpfs              489M  6.9M  482M  2% /run

tmpfs              489M   0  489M  0% /sys/fs/cgroup

/dev/sdb1            10G  59M  10G  1% /data

/dev/sda1            197M  103M  95M  53% /boot

tmpfs              98M   0  98M  0% /run/user/0

/dev/mapper/storage-lvm--test  1.5G  26M  1.5G  2% /LVN-TEST

[root@vm-main /]# lvs

 LV    VG    Attr    LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert

 root   centos  -wi-ao---- 17.80g

 swap   centos  -wi-ao----  2.00g

 lvm-test storage -wi-ao----  1.50g

14.如何配置yum源,能够下载诸多第三方软件?

备份原始配置文件

[root@vm-main yum.repos.d]# cd /etc/yum.repos.d/

[root@vm-main yum.repos.d]# mkdir bak

[root@vm-main yum.repos.d]# mv *.repo bak/

下载新的阿里云配置文件到本地

wget -O aliyun.repo http://mirrors.aliyun.com/repo/Centos-7.repo

yum clean all

yum makecache

15.简述源代码编译安装nginx的步骤

1.补包

[root@vm-main yum.repos.d]# yum install gcc patch libffi-devel python-devel  zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel openssl openssl-devel -y

2.获取安装包

wget -c https://nginx.org/download/nginx-1.12.0.tar.gz

3.解压并进入目录

tar -zxvf nginx-1.12.0.tar.gz

4.检查安装环境

./configure --prefix=/opt/nginx112/

5.编译安装

make && make install

16.linux有哪些系统资源监控的命令?

top
posted @ 2022-10-08 01:05  整天就会哈哈哈  阅读(66)  评论(0编辑  收藏  举报