第二阶段:高级核心基础知识·第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
第二阶段:高级核心基础知识·第4章shell特性·2的更多相关文章
- 第二阶段:高级核心基础知识·第1章Linux三剑客·1
1.用vmware添加一块10G的硬盘,且永久挂载到/data01中,写出详细的步骤 2.用自己语言描述raid0和raid1的区别 RAID 0: 将两个或以上相同信号,容量的硬盘组合,磁盘阵列的总 ...
- unix环境高级编程基础知识之第四章
1.从当前用户转到root用户:直接输入su命令,然后输入root密码,如果之前没有设置root命令密码会登陆不成功,这里需要命令sudo passwd命令设置密码,然后按照上面输入就成:从root命 ...
- Java核心技术卷一基础知识-第11章-异常、断言、日志和调试-读书笔记
第11章 异常.断言.日志和调试 本章内容: * 处理错误 * 捕获异常 * 使用异常机制的技巧 * 使用断言 * 日志 * 调试技巧 * GUI程序排错技巧 * 使用调试器 11.1 处理错误 如果 ...
- unix环境高级编程基础知识之第二篇(3)
看了unix环境高级编程第三章,把代码也都自己敲了一遍,另主要讲解了一些IO函数,read/write/fseek/fcntl:这里主要是c函数,比较容易,看多了就熟悉了.对fcntl函数讲解比较到位 ...
- Java核心技术卷一基础知识-第14章-多线程-读书笔记
第 14 章 多线程 本章内容: * 什么是线程 * 中断线程 * 线程状态 * 线程属性 * 同步 * 阻塞队列 * 线程安全的集合 * Collable与Future * 执行器 * 同步器 * ...
- Java核心技术卷一基础知识-第8章-事件处理-读书笔记
第8章 事件处理 本章内容: * 事件处理基础 * 动作 * 鼠标事件 * AWT事件继承层次 8.1 事件处理基础 在AWT所知的事件范围内,完全可以控制事件从事件源(event source)例如 ...
- Java核心技术卷一基础知识-第5章-继承-读书笔记
第5章 继承 本章内容: * 类.超类和子类 * Object:所有类的超类 * 泛型数组列表 * 对象包装器和自动装箱 * 参数数量可变的方法 * 枚举类 * 反射 * 继承设计的技巧 利用继承,人 ...
- 第一篇 网站基础知识 第5章 自己动手实现HTTP协议
第5章 自己动手实现HTTP协议 我们知道HTTP协议是在应用层解析内容的,只需要按照它的报文的格式封装和解析数据就可以了,具体的传输还是使用的Socket,在第4章NioServer的基础上自己做一 ...
- unix环境高级编程基础知识之第一篇
陆陆续续看完了圣经第一章,熟悉了unix的整个编程流程,c语言的用处在这里得到伸张. 从unix的体系结构,原来操作系统包括内核及一些其他软件,我们常常误称为linux内核为操作系统,这俨然成为一种共 ...
随机推荐
- Excel 逻辑函数(二):AND 和 OR
前言 AND 函数是且:OR 函数是或.AND 函数中的条件必须都满足才返回 TRUE:OR 函数中的条件只要满足一个就返回 TRUE.AND 和 OR 的参数最多允许有 30 个. AND [题目] ...
- CCF NOI Online 2021 提高组 T2 积木小赛 (子序列自动机+后缀自动机,O(n^2))
题面 Alice 和 Bob 最近热衷于玩一个游戏--积木小赛. Alice 和 Bob 初始时各有 n 块积木从左至右排成一排,每块积木都被标上了一个英文小写字母. Alice 可以从自己的积木中丢 ...
- C#/.NET/.NET Core优秀项目框架推荐
前言: 为.NET开源者提供的一个推荐自己优秀框架的地址,大家可以把自己的一些优秀的框架,或者项目链接地址存到在这里,提供给广大.NET开发者们学习(排名不分先后). Github项目仓库收集地址:h ...
- KingbaseES R6 主备流复制集群创建级联复制案例
案例环境: 数据库: test=# select version(); version -------------------------------------------------------- ...
- C/C++ Capstone 引擎源码编译
Capstone 是一个轻量级的多平台.多架构的反汇编框架.Capstone 旨在成为安全社区中二进制分析和反汇编的终极反汇编引擎.Capstone的编译非常简单只需要一步即可轻松得到对应的Lib库文 ...
- Self-Attention:初步理解
Self-Attention 的基本结构与计算 Attention(注意力)实际上就是权重的另一种应用的称呼,其具体结构与初始输入的 content \(\vec{x_{1}}, \vec{x_{2} ...
- Lua 支持虚函数的解决方案
概述 lua本身没有提供类似C++虚函数机制,调用的父类方法调用虚函数可能会出现问题. 问题分析 分析这段代码和输出 local Gun = {} -- 示例,实际应用还要考虑构造,虚表等情况 fun ...
- C#,使用FindWindow和FindWindowEx查找窗体和控件
函数: // Find Window // 查找窗体 // @para1: 窗体的类名 例如对话框类是"#32770" // @para2: 窗体的标题 例如打开记事本 标题是&q ...
- Python数据科学手册-机器学习: 流形学习
PCA对非线性的数据集处理效果不太好. 另一种方法 流形学习 manifold learning 是一种无监督评估器,试图将一个低维度流形嵌入到一个高纬度 空间来描述数据集 . 类似 一张纸 (二维) ...
- C语言[char**]与[malloc]的组合使用
简介 首先!要搞懂char**是什么? 我们知道 char* 是字符指针,是一个地址,指向一个字符串. 那么 char** 就是指向 char* 的指针,也是一个地址,指向指针的指针. 使用char* ...