学习周报-20230106

news2025/1/23 9:11:29

文章目录

  • 一 Linux常用系统日志
    • 一 常用系统日志
    • 二 系统日志优先级
    • 三 其他日志文件
  • 二 DNS域名解析
    • 一 定义
    • 二 配置文件
    • 三 DNS解析流程
    • 四 总结
  • 三 vim编辑器的三种模式
  • 四 Linux虚拟机克隆后网卡名从eth0变成eth1
    • 一 系统环境
    • 二 问题发现
    • 三 解决过程
  • 五 在rhel6系统部署iscsi远程存储
    • 一 需求
    • 二 环境准备
    • 三 服务端配置
      • 3.1 添加硬盘
      • 3.2 安装软件
      • 3.3 编写配置文件
      • 3.4 启动服务
      • 3.5 检查配置信息
    • 四 客户端配置
      • 4.1 安装软件包
      • 4.2 启动服务
      • 4.3 发现目标
      • 4.4 登陆目标
      • 4.5 实现开机自动挂载
    • 五 对部署进行测试

一 Linux常用系统日志

一 常用系统日志

日志文件用途
/var/log/messages记录大多数系统日志信息,包括启动、IO错误、网络和程序等问题
/var/log/secure记录安全和身份验证等相关消息和错误
/var/logrsyslog将所有日志文件写入到该目录下
/var/log/maillog与邮件服务器相关消息的日志文件
/var/log/cron与定时任务执行相关的日志文件
/var/log/boot.log与系统启动相关的消息记录

二 系统日志优先级

rsyslogd服务使用日志消息的设备和优先级来确定如何处理,一般通过/etc/rsyslog.conf文件进行配置。

rsyslog处理的消息可能出现在多个不同的日志文件中,为了避免这种情况,将严重性字段设为none,表示定向到这一设备的所有消息都不添加到指定的日志文件中。

编码优先级严重性
0emerg系统不可用
1alert必须立即采取措施
2crit严重状况
3err非严重错误状况
4warning警告状况
5notice正常但重要的事件
6info信息性事件
7debug调试级别消息

三 其他日志文件

日志文件用途打开方式
/var/log/btmp记录错误的、失败的登陆尝试和验证消息last /var/log/btmp 或 last
/var/log/wtmp记录每个用户登录、注销及系统的启动、停机的事件who /var/log/wtmp 或 last
/var/run/utmp记录当前登录的每个用户的信息,仅暂时保留who /var/run/utmp 或 last
/var/log/dmesg包括内核缓冲信息以及硬件方面的信息cat /var/log/dmesg 或 dmesg
/var/log/lastlog记录所有用户的最近登录信息lastlog

打开 /var/log/wtmp 文件:

在这里插入图片描述

打开 /var/run/utmp 文件:

在这里插入图片描述

打开 /var/log/lastlog 文件:

在这里插入图片描述

二 DNS域名解析

一 定义

用户在浏览器输入URL,浏览器就会向该URL对应的服务器发送请求,获得对应的IP,才能将资源返回给用户。
简单来说,DNS就是将URL转化成IP的过程。

二 配置文件

在Linux系统中如果想要 ping 通外网,比如ping www.baidu.com,如果失败,很有可能是没有配置DNS。
一种方法是,在 /etc/sysconfig/network-scripts/ifcfg-eth0 文件中,添加参数 DNS1=223.5.5.5
一种方法是,在 /etc/resolv.conf 文件中,添加参数 nameserver 223.5.5.5

三 DNS解析流程

本文以访问www.baidu.com域名的DNS解析流程为例,进行说明。

1 )首先查询本地缓存

在这里插入图片描述

2)接着查询本地hosts文件是否有域名解析的IP

在这里插入图片描述

3)其次请求LDNS的缓存与向LDNS的查询

在这里插入图片描述

4)LDNS作为“中间商”,开始迭代查询,先请求根域名服务器,得到顶级域名服务器和.com

在这里插入图片描述

5)从顶级域名服务器得到权威域名服务器的IP,得到baidu.com
在这里插入图片描述

6)从权威域名服务器得到www.baidu.com的IP资源
在这里插入图片描述

7)资源返回给LDNS和本地客户端,并进行缓存,以便下次查询或其他用户的相同资源查询

在这里插入图片描述

四 总结

1)域名解析的顺序是:本地的缓存----->本地hosts文件----->LDNS的缓存----->LDNS查询----->根域名服务器----->顶级域名服务器----->权威域名服务器----->结果返回给本地客户端和LDNS并缓存

2)递归查询:客户端向LDNS发送DNS解析结果的请求,LDNS返回给客户端一个准确的结果,就是递归查询的过程。本文1-3都属于递归查询。
迭代查询:A向B发送获取资源的请求,B没有给A所需要的结果,反而告诉A可以向C发送请求,A则向C发送请求获取资源,以此类推,就是迭代查询。本文4-6都属于迭代查询过程。

三 vim编辑器的三种模式

在这里插入图片描述

四 Linux虚拟机克隆后网卡名从eth0变成eth1

一 系统环境

原本被克隆的主机是 rhel6.9 的操作系统。

在这里插入图片描述

二 问题发现

rhel6.9 的主机克隆后,发现无法SSH远程连接,从而发现可能是网卡的问题需要解决。

在这里插入图片描述

首先检查网卡服务是否启动
发现network服务是正常运行的。

在这里插入图片描述

接着检查本地网卡的IP是否显示正常
rhel6系统中默认设置的第一块网卡是eth0,而这里克隆后的网卡是eth1

在这里插入图片描述
但我们的网卡配置文件中设置的网卡名称应该是eth0,所以这里有问题了。

在这里插入图片描述

经过确认,网卡配置文件无误。

此时我们尝试重启一下网卡,看一下会有什么提示。

在这里插入图片描述

此处提示,设备eth0似乎不存在

三 解决过程

打开 /etc/udev/rules.d/70-persistent-net.rules 文件,会发现里面有eth0eth1两块网卡。

在这里插入图片描述

我们只需要把 eth0 网卡信息删掉或注释掉,将eth1网卡名改为eth0

在这里插入图片描述

然后找到该设备的MAC地址。

在这里插入图片描述

再打开网卡配置文件 /etc/sysconfig/network-scripts/ifcfg-eth0 ,找到参数 HWADDR,修改后面的值为新的mac地址。

在这里插入图片描述

保存退出后,重启网卡即可。

service network restart

执行命令后,网卡启动成功。

在这里插入图片描述

由于是克隆主机,我们需要修改IP和主机名,所以SSH连接后,直接在配置文件修改即可。

在这里插入图片描述

最后记得重启网卡,并重新登陆。(因为IP变了,所以要新建SSH会话)

service network restart

重新建立会话。

在这里插入图片描述

再进行SSH远程连接。

在这里插入图片描述

由此可见,网卡名和IP地址正确,克隆机设备修复成功。

五 在rhel6系统部署iscsi远程存储

一 需求

1)首先在服务端添加一块10G的硬盘,并进行分区,得到其中的1G作为远程存储设备
2)其次在服务端创建名为iqn.2023-01-05.com:server的新iscsi目标,并且仅限于客户端iqn.2023-01-06.com:client
3)在客户端可以发现并登录到新目标。
4)在新磁盘上创建 XFS 文件系统,并将其持久挂载到/data目录上。

二 环境准备

服务端IP:10.0.0.100 主机名:rhel-6
客户端IP:10.0.0.101 主机名:rhel6-01

[root@rhel-6 ~]# cat /etc/redhat-release 
Red Hat Enterprise Linux Server release 6.9 (Santiago)
[root@rhel-6 ~]# uname -r
2.6.32-696.el6.x86_64

三 服务端配置

3.1 添加硬盘

添加一块10G硬盘。
Linux磁盘分区和管理

在这里插入图片描述

3.2 安装软件

执行命令安装软件 yum install scsi-target-utils -y

在这里插入图片描述

3.3 编写配置文件

[root@rhel-6 ~]# tail -4  /etc/tgt/targets.conf 
<target iqn.2023-01-05.com:server>
        backing-store /dev/sdb
        initiator-address 10.0.0.101
</target>

此处补充说明配置文件下的一些常用参数:

参数说明
backing-store定义一个逻辑单元(LUN),这个LUN通常是一个普通文件或者块设备
initiator-address限制可以连接target的客户端地址范围
incominguser限制可以连接target的客户端用户

3.4 启动服务

[root@rhel-6 ~]# service tgtd start
Starting SCSI target daemon:                               [  OK  ]
[root@rhel-6 ~]# chkconfig tgtd on
[root@rhel-6 ~]# service tgtd status
tgtd (pid 6464 6461) is running...
[root@rhel-6 ~]# netstat -lntup|grep 3260
tcp        0      0 0.0.0.0:3260                0.0.0.0:*                   LISTEN      6461/tgtd           
tcp        0      0 :::3260                     :::*                        LISTEN      6461/tgtd 

3.5 检查配置信息

[root@rhel-6 ~]# tgt-admin -show
Target 1: iqn.2023-01-05.com:server
    System information:
        Driver: iscsi
        State: ready
    I_T nexus information:
    LUN information:
        LUN: 0
            Type: controller
            SCSI ID: IET     00010000
            SCSI SN: beaf10
            Size: 0 MB, Block size: 1
            Online: Yes
            Removable media: No
            Prevent removal: No
            Readonly: No
            Backing store type: null
            Backing store path: None
            Backing store flags: 
        LUN: 1
            Type: disk
            SCSI ID: IET     00010001
            SCSI SN: beaf11
            Size: 10737 MB, Block size: 512
            Online: Yes
            Removable media: No
            Prevent removal: No
            Readonly: No
            Backing store type: rdwr
            Backing store path: /dev/sdb
            Backing store flags: 
    Account information:
    ACL information:
        10.0.0.101

四 客户端配置

4.1 安装软件包

安装软件包 yum install -y iscsi-initiator-utils

在这里插入图片描述

4.2 启动服务

[root@rhel6-01 ~]# /etc/init.d/iscsid start
正在启动 iscsid:                                          [确定]
[root@rhel6-01 ~]# chkconfig iscsid on
[root@rhel6-01 ~]# /etc/init.d/iscsid status
iscsid (pid  52352) 正在运行...

4.3 发现目标

[root@rhel6-01 ~]# iscsiadm -m discovery -t sendtargets -p 10.0.0.100
10.0.0.100:3260,1 iqn.2023-01-05.com:server

4.4 登陆目标

[root@rhel6-01 ~]# iscsiadm -m node -T iqn.2023-01-05.com:server -l
Logging in to [iface: default, target: iqn.2023-01-05.com:server, portal: 10.0.0.100,3260] (multiple)
Login to [iface: default, target: iqn.2023-01-05.com:server, portal: 10.0.0.100,3260] successful.

检查后可以识别本地客户端多了一块磁盘。

在这里插入图片描述

补充说明,如果想要退出登录并删除目标,依次执行下列两个命令:

iscsiadm -m node -T iqn.2023-01-05.com:server --logout
iscsiadm -m node -T iqn.2023-01-05.com:server -o delete

4.5 实现开机自动挂载

首先创建挂载目录。

mkdir /data

接着创建成分区。

[root@rhel6-01 ~]# fdisk /dev/sdb

WARNING: DOS-compatible mode is deprecated. It's strongly recommended to
         switch off the mode (command 'c') and change display units to
         sectors (command 'u').

Command (m for help): n
Command action
   e   extended
   p   primary partition (1-4)
p
Partition number (1-4): 1
First cylinder (1-10240, default 1): 1
Last cylinder, +cylinders or +size{K,M,G} (1-10240, default 10240): +1G

Command (m for help): p

Disk /dev/sdb: 10.7 GB, 10737418240 bytes
64 heads, 32 sectors/track, 10240 cylinders
Units = cylinders of 2048 * 512 = 1048576 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x35da8dc7

   Device Boot      Start         End      Blocks   Id  System
/dev/sdb1               1        1025     1049584   83  Linux

Command (m for help): w
The partition table has been altered!

Calling ioctl() to re-read partition table.
Syncing disks.
[root@rhel6-01 ~]# partprobe /dev/sdb

检查创建好的分区。

[root@rhel6-01 ~]# lsblk
NAME   MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
sr0     11:0    1 1024M  0 rom  
sda      8:0    0   20G  0 disk 
├─sda1   8:1    0  200M  0 part /boot
├─sda2   8:2    0  1.5G  0 part [SWAP]
└─sda3   8:3    0 18.3G  0 part /
sdb      8:16   0   10G  0 disk 
└─sdb1   8:17   0    1G  0 part 

接着格式化分区。

[root@rhel6-01 ~]# mkfs -t ext4 /dev/sdb1
mke2fs 1.41.12 (17-May-2010)
警告: 252 块未使用.

文件系统标签=
操作系统:Linux
块大小=4096 (log=2)
分块大小=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
65664 inodes, 262144 blocks
13119 blocks (5.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=268435456
8 block groups
32768 blocks per group, 32768 fragments per group
8208 inodes per group
Superblock backups stored on blocks: 
        32768, 98304, 163840, 229376

正在写入inode表: 完成                            
Creating journal (8192 blocks): 完成
Writing superblocks and filesystem accounting information: 完成

This filesystem will be automatically checked every 24 mounts or
180 days, whichever comes first.  Use tune2fs -c or -i to override.

然后实现开机自动挂载。
此处需要注意的是,配置文件 /etc/fstab 文件中需要加一个参数 _netdev,否则在设备重启后会报错。

[root@rhel6-01 ~]# tail -1 /etc/fstab 
/dev/sdb1               /data                   ext4    defaults,_netdev 0 0
[root@rhel6-01 ~]# mount -a
[root@rhel6-01 ~]# df -h
Filesystem      Size  Used Avail Use% Mounted on
/dev/sda3        18G  5.2G   12G  31% /
tmpfs           491M   64K  491M   1% /dev/shm
/dev/sda1       190M   35M  146M  20% /boot
/dev/sdb1       976M  1.3M  924M   1% /data

五 对部署进行测试

最后我们进行测试,能否从客户端在设备中写一个文件。

[root@rhel6-01 ~]# cd /data/
[root@rhel6-01 data]# echo client > test
[root@rhel6-01 data]# ll
总用量 20
drwx------ 2 root root 16384 16 10:59 lost+found
-rw-r--r-- 1 root root     7 16 11:06 test
[root@rhel6-01 data]# cat test 
client

经过测试,设备挂载成功。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/144500.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

项目资源规划前需要了解的基础知识

项目资源规划是优化各项目资源使用的一个可靠方法。你根据团队成员的技能、能力和对项目的适应性将任务分配给他们&#xff0c;以实现最大效率。 换句话说&#xff0c;规划项目资源的过程可以帮助你回答项目经理可能提出的两个最重要的问题。 ● 如何确保在团队不过度劳累的情…

零基础学MySQL(一)-- 启动与创建数据库及对数据库的备份与恢复

&#x1f9e7;启动与创建数据库及对数据库的备份与恢复&#x1f957;一、启动与连接数据库1️⃣启动数据库2️⃣连接数据库&#x1f96b;二、数据库的基本介绍1️⃣数据库的三层结构2️⃣数据在数据库中的存储方式3️⃣SQL 语句分类&#x1f371;三、对数据库的操作1️⃣创建数…

Python 读取千万级数据自动写入 MySQL 数据库

Python 读取数据自动写入 MySQL 数据库&#xff0c;这个需求在工作中是非常普遍的&#xff0c;主要涉及到 python 操作数据库&#xff0c;读写更新等&#xff0c;数据库可能是 mongodb、 es&#xff0c;他们的处理思路都是相似的&#xff0c;只需要将操作数据库的语法更换即可。…

react+openlayers实现点要素的创建及其点上overlay叠加层的实现

前言 网上关于react或者vue3与openlayers结合的案例非常少&#xff0c;今天由于工作中用到&#xff0c;特记录下笔记&#xff0c;后面将持续更新react和vue3与ol的结合案例&#xff08;新手勿喷&#xff09;。 1.地图上要素&#xff08;点线面&#xff09;的创建 以点要素为…

C进阶:数据在内存中的存储

深度剖析数据在内存中的存储C进阶:数据在内存中的存储深度剖析数据在内存中的存储数据类型介绍类型的基本归类整型家族浮点数家族&#xff1a;构造类型&#xff1a;指针类型&#xff1a;空类型&#xff1a;整型在内存中的存储原码、反码、补码原码反码补码的相互转换整型数据的…

基于WebRtc的web播放大华海康rtsp视频流(延迟一秒以内)

基于WebRtc的web播放大华海康rtsp视频流&#xff08;延迟一秒以内&#xff09;WebRtc下载WebRtc运行Rtc测试Rtc使用html播放需要在vue上播放的可以看下一篇文章WebRtc你好&#xff01; 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可…

谷粒学院——第十七章、课程微信支付

需求分析 需要实现的功能 需要提供的接口 后端实现 创建数据库表 创建 service_order 模块 引入依赖 <dependencies><dependency><groupId>com.github.wxpay</groupId><artifactId>wxpay-sdk</artifactId><version>0.0.3</ve…

elasticsearch 7.9.3知识归纳整理(六)之 kibana图形化操作es指南

kibana图形化操作es指南 一、创建用户&#xff0c;角色和权限指引 1.创建角色 1.1 在kibana首页点击Manage and Administer the Elastic Stack下的securitys settings 1.2 点击左侧Security 下的roles 1.3 点击右上角的create role 1.4 输入角色名字 完成后点击下面的create…

华为手表开发:WATCH 3 Pro(3)创建项目以及运行完整流程

华为手表开发&#xff1a;WATCH 3 Pro&#xff08;3&#xff09;创建项目以及运行完整流程初环境与设备创建项目创建项目入口配置项目运行项目报错需要在 Appgallery Connect , 创建项目&#xff0c;然后在项目中登录账号就可以了登录后的最终结果再次点击运行&#xff0c;我们…

通俗易懂的java设计模式(5)-抽象工厂模式模式

什么是抽象工厂模式&#xff1f; 抽象工厂模式&#xff0c;可以说是工厂模式的升级版 关于工厂模式&#xff1a;通俗易懂的工厂模式 抽象工厂&#xff1a;围绕着一个超级工厂去创建其他的工厂&#xff0c;这个超级工厂也被称为工厂的工厂&#xff0c;这个设计模式属于创建型…

【小5聊】回看2022,展望2023,分享我的年度总结和感想,在一个行业十年,坚持下去你就是这个行业的专家

2022年&#xff0c;已成为过去&#xff01;2023年&#xff0c;TA已悄然而至&#xff01; 非常感谢CSDN提供的技术平台&#xff0c;很早就关注了C站&#xff0c;11年的时候&#xff0c;当时用的是163邮箱注册的账号&#xff0c;也是主要用来找资料看文章。 18年的时候&#xff0…

八、k8s 数据存储

文章目录1 数据存储介绍1.1 基本存储1.1.1 EmptyDir1.1.2 HostPath1.1.3 NFS2 高级存储2.1 PV2.2 PVC2.3 生命周期3 配置存储3.1 ConfigMap3.2 Secret1 数据存储介绍 在前面已经提到&#xff0c;容器的生命周期可能很短&#xff0c;会被频繁地创建和销毁。那么容器在销毁时&am…

基础数据结构——队列和栈

目录 一、队列 1、循环队列 2、Python队列的三种实现方式 3、例题——队列操作 4、优先队列 &#xff08;1&#xff09;基本操作 &#xff08;2&#xff09;例题&#xff08;lanqiaoOJ题号1228&#xff09; 二、栈 1、用 list 实现栈 2、用 collections.deque 实现栈…

【知识图谱导论-浙大】第一章:知识图谱概论

背景 2022年&#xff0c;随着在自然语言处理方向的深入&#xff0c;我逐渐开始对知识图谱在问答、搜索、推荐等领域的应用产生浓厚的兴趣。自己也通过书籍、博文、论文等对知识图谱有所了解&#xff0c;也通过中文开放知识图谱对中文知识图谱在各领域的发展有了深刻的认识。知…

将非负整数num转换为对应的英文表达(C++实现)—— 力扣第273号题的加强。

【问题描述】 将非负整数num转换为对应的英文表达式。 (样例1) 输入&#xff1a;25 输出&#xff1a;Twenty Five (样例2) 输入&#xff1a;12,315 输出&#xff1a;Twelve Thousand Three Hundred (and) Fifteen 备注&#xff1a;and可省略 另备注&#xff1a;偶然发…

(八)devops持续集成开发——jenkins流水线发布一个docker版的后端maven项目

前言 本节内容我们使用jenkins的流水化工具发布一个后端docker项目&#xff0c;实现后端项目的容器化部署。在开始本节内容之前&#xff0c;我们需要在生产环境安装好docker环境并且能够联网下载镜像。通过jenkins的流水化工具&#xff0c;实现代码拉取&#xff0c;maven打包编…

【java篇】反射机制简单理解

学到JDBC后&#xff0c;使用到反射机制&#xff0c;所以回顾反射机制相关知识点&#xff1b; 文章目录 文章目录 什么是反射机制&#xff1f; 如何理解反射呢&#xff1f; 总结 一、Java反射机制是什么&#xff1f; 二、Java反射机制中获取Class的三种方式及区别&#xff1f; 三…

【目标检测】EfficientDet

1、论文 题目&#xff1a;《EfficientDet: Scalable and Efficient Object Detection》 论文地址&#xff1a; https://arxiv.org/pdf/1911.09070.pdf 代码地址&#xff1a; https://github.com/bubbliiiing/efficientdet-pytorch 2、摘要 Google Brain团队在CVPR 2020上提出…

Liunx 对函数库的理解

一、前言 我们的C程序中&#xff0c;并没有定义“printf”的函数实现,且在预编译中包含的“stdio.h”中也只有该函数的声明,而没有定义函数的实现,那么,是在哪里实“printf”函数的呢?最后的答案是:系统把这些函数实现都被做到名为 libc.so.6 的库文件中去了,在没有特别指定时…

PCB入门学习— CHIP类PCB封装的创建

目录 2.12 原理图PCB封装完整性的检查 3.1 CHIP类PCB封装的创建 学习目录 2.12 原理图PCB封装完整性的检查 然后点接受变更。 www.digikey.com搜索规格的网站。 3.1 CHIP类PCB封装的创建 放焊盘——确定大小——画丝印——确定原点EFC。 创建一个PCB元件库&#xff0c;Ct…