笔者的LINUX系统默认双网卡,一个VM1(STATIC),一个NET(DHCP),所使用的镜像是OpenEuler,如果有需要初始化虚拟机教程,我之后可以发
一、DNF
基于RPM包构建的软件更新机制
可以自动解决依赖关系
所有软件包由集中的DNF软件仓库提供
DNS有三种部署方式如下:
FTP服务:ftp://......
HTTP服务:http://......
本地目录:file:///.......
本文主要介绍FTP服务
1.1.DNF服务器配置仓库
# mkdir -p /var/ftp/dnf
# mount /dev/cdrom /mnt/
# cp -rf /mnt/* /var/ftp/dnf //用于存放客户端需要的rpm包软件,必放在此目录中,该目录为FTP共享根目录
# cd /mnt/Packages/
# rpm -ivh vsftpd-3.0.3-33.oe2203sp1.x86_64.rpm
# vim /etc/vsftpd/vsftpd.conf //用于设置匿名访问,让新虚拟机能够访问dnf
anonymous_enable=YES //把NO改成YES
# systemctl enable vsftpd
# systemctl start vsftpd
注意:笔者在这里配置觉得给/var/ftp 文件夹 赋予了 -R 777权限就可以不用开启匿名就访问了,后来发现/var/ftp文件夹一旦被赋予了777权限就不能登入,后来又改回了755权限,当然匿名访问也必须开启,所以不要跟我一样随意更改权限,浪费大量时间.
1.2.客户端配置DNF
DNF服务是典型的C/S架构,我们不仅要配置服务器还要配置客户端.
# cd /etc/yum.repos.d/ //把openeuler自带的替换成我们的DNF,注意地址
# mkdir backup //创建备份文件夹,备份自带的openeuler(以后想下东西记得移出来)
# mv ./* backup/ //会警告但无所谓这是因为操作系统不能把自己移到自己里面
# vim /etc/yum.repos.d/local.repo
[openeuler]
name=openeuler
baseurl=ftp://192.168.147.2/dnf //指定服务器的IP地址与DNF仓库目录,注意此处是两个斜杠
enabled=1
gpgcheck=1 //gpg可以不开启
gpgkey=ftp://192.168.147.2/dnf/RPM-GPG-KEY-openEuler //注意此处是两个斜杠
(记得改ftp地址,是你服务器的地址)
1.3.DNF相关命令
现在可以进行验证了,直接在客户端进行DNF相关操作.
# dnf list //查询软件包列表
# dnf list installed //当前已安装的软件包
# dnf list available //当前未安装的软件包
# dnf list updates //当前能够升级的软件包
# dnf info httpd //查询软件包详细信息
# dnf install -y ntsysv //安装软件包
# dnf remove -y ntsysv //卸载软件包
# dnf update //更新软件包
# dnf groupupdate //更新多个软件包
# dnf search //查询某个命令属于哪个包
# dnf provides */命令
部署PXE远程安装服务
PXE(Pre-boot Execution Environment) 中文名称:预启动执行环境,学会了这个你就可以不用自己手动配置新虚拟机了,是不是很方便(bushi)
PXE大致工作原理:
第一步:PXE-client发送请求
去找dhcp服务器获取地址
第二步:DHCP应答请求并回应
分配的IP地址,pxelinux启动程序(TFTP)的位置,以及配置文件的位置
第三步:PXE-client请求下载启动文件
PXE客户端收到回应后,向TFTP服务器请求下载所需的启动系统安装文件
第四步:TFTP服务器响应请求并传送文件
当TFTP服务器收到请求后,服务器会响应请求并应答请求,之后传送所需的文件给客户端
第五步:PXE-client请求下载自动应答文件
PXE客户端通过文件成引导linux安装后,接着读取文件中指定的自动应答文件ks.cfg,然后根据文件位置请求下载镜像
第六步:客户端安装系统
有了镜像之后就能安装操作系统了
作者:知乎用户3QM3N1
链接:https://www.zhihu.com/question/30234256/answer/1993465019
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
那我们就知道了,要部署成功PXE,我们需要一个DHCP服务器,一个TFTP服务器,所以我们接下来就会回到服务器上进行部署.(注:记得关闭客户机防火墙)
2.2.PXE网络批量装机步骤
1.安装FTP服务并准备openeuler安装源;
2.安装TFTP服务并启动;
3.准备Linux内核、初始化镜像文件;
4.准备PXE引导程序、启动菜单文件;
5.安装并启动DHCP服务;
6.验证PXE网络安装效果。
2.3.服务器配置PXE
1.准备镜像安装源
# mkdir -p /var/ftp/dnf
# mount /dev/cdrom /mnt/ //挂载
# cp -rf /mnt/* /var/ftp/dnf //拷贝一份当镜像放到我们的DNF服务器下
2.安装并启用tftp、FTP服务
# dnf install -y tftp-server xinetd vsftpd
# vim /etc/vsftpd/vsftpd.conf
anonymous_enable=YES //前面已经开启了,不用做
# vim /etc/xinetd.d/tftp
disable = no //修改为no //开启tftp
systemctl start tftp
systemctl start vsftpd
systemctl enable tftp
systemctl enable vsftpd
systemctl start xinetd
systemctl enable xinetd //PXE这个也要
3.准备linux内核、初始化镜像文件、准备PXE引导程序、启动菜单文件:
# cp -r /mnt/images/pxeboot/* /var/lib/tftpboot/
# cp /mnt/EFI/BOOT/grubx64.efi /var/lib/tftpboot/
# cp /mnt/EFI/BOOT/grub.cfg /var/lib/tftpboot/
# vim /var/lib/tftpboot/grub.cfg
set default="1"
function load_video {
if [ x$feature_all_video_module = xy ]; then
insmod all_video
else
insmod efi_gop
insmod efi_uga
insmod ieee1275_fb
insmod vbe
insmod vga
insmod video_bochs
insmod video_cirrus
fi
}
load_video
set gfxpayload=keep
insmod gzio
insmod part_gpt
insmod ext2
set timeout=60
### BEGIN /etc/grub.d/10_linux ###
menuentry 'Install openEuler 22.03-LTS-SP1' --class red --class gnu-linux --class gnu --class os {
set root=(tftp,192.168.1.111)
linux /vmlinuz ro inst.geoloc=0 console=ttyAMA0 console=tty0 rd.iscsi.waitnet=0 inst.ks=ftp://192.168.1.111/openEuler-ks.cfg
initrd /initrd.img
}
4.设置kickstart配置文件 openEuler-ks.cfg,此处选择ftp安装源。
如果你看不懂下面的配置,你可以先到你之前开的客户机上cd ~到root用户的家目录下,里面有原生的配置文件
# vim /var/ftp/openEuler-ks.cfg //在ftp下创建我们新机的配置文件,权限会自动设置可读,不要改!
====================================
***以下内容根据实际需求进行修改***
# Generated by Anaconda 36.16.5
# Generated by pykickstart v3.34
#version=DEVEL
# Use graphical install
graphical
%post
#enable kdump
sed -i "s/ ro / ro crashkernel=1024M,high /" /boot/efi/EFI/openEuler/grub.cfg
%end
# Keyboard layouts
keyboard --vckeymap=cn --xlayouts='cn'
# System language
lang zh_CN.UTF-8
# Use network installation
url --url="ftp://192.168.147.2/dnf/" //DNF服务器地址
%packages
@^minimal-environment
%end
# Generated using Blivet version 3.4.2
ignoredisk --only-use=nvme0n1
autopart
# Partition clearing information
clearpart --none --initlabel
# System timezone
timezone Asia/Shanghai
# Root password
rootpw --iscrypted $y$j9T$ITRK1pgk9ENqmnRyyS2UEgmK$R.XP8WO6r4.mr5/4Hf8vwiFuDM3n1LOQAgeKW7CLmE4
# root密码为Aa123.com //随便设,反正我们匿名登录
5.安装并启用DHCP服务
# dnf install -y dhcp //安装DHCP
# vim /etc/dhcp/dhcpd.conf
ddns-update-style interim;
ignore client-updates;
filename "grubx64.efi";
next-server 192.168.147.2; //主机的地址
subnet 192.168.147.0 netmask 255.255.255.0 {
range 192.168.147.50 192.168.147.100; 分配的范围
option routers 192.168.147.1; //网关
default-lease-time 86400;
max-lease-time 172800;
option domain-name-servers 192.168.147.2; //DHCP服务器的DNS地址
}
如果你不知道你服务器的DNS地址,请看下图
systemctl start dhcpd
systemctl enable dhcpd
systemctl restart tftp
systemctl enable tftp
systemctl restart vsftpd
systemctl restart xinetd
systemctl enable xinetd
systemctl enable vsftpd
现在,我们有DHCP,TFTP服务也已经安装并且开启,那么可以进行试装机步骤了(一般都不会有错)
下方多图流量警告!
随便选一个版本都一样的,都是以你原机的配置来的
随便放位置,待会成功了都得删
下一步
内存调高,默认1g不够用的
把网卡设置成你主机DHCP服务器的同网卡,不然连不到
这里点否
然后完成,如果你直接开始的话,可能会像下面这样
卡住了是吧,我也是这样,但是可以解决,
先关机,打开设置里的选项
默认的bios我们改成UEFI
然后重新打开试验机
自动安装,成功!
这是我在学习空闲之余写的,可能会略有不足,有时间我会做出更新.
文章浏览阅读645次。这个肯定是末尾的IDAT了,因为IDAT必须要满了才会开始一下个IDAT,这个明显就是末尾的IDAT了。,对应下面的create_head()代码。,对应下面的create_tail()代码。不要考虑爆破,我已经试了一下,太多情况了。题目来源:UNCTF。_攻防世界困难模式攻略图文
文章浏览阅读2.9k次,点赞3次,收藏10次。偶尔会用到,记录、分享。1. 数据库导出1.1 切换到dmdba用户su - dmdba1.2 进入达梦数据库安装路径的bin目录,执行导库操作 导出语句:./dexp cwy_init/[email protected]:5236 file=cwy_init.dmp log=cwy_init_exp.log 注释: cwy_init/init_123..._达梦数据库导入导出
文章浏览阅读1.9k次。1. 在官网上下载KindEditor文件,可以删掉不需要要到的jsp,asp,asp.net和php文件夹。接着把文件夹放到项目文件目录下。2. 修改html文件,在页面引入js文件:<script type="text/javascript" src="./kindeditor/kindeditor-all.js"></script><script type="text/javascript" src="./kindeditor/lang/zh-CN.js"_kindeditor.js
文章浏览阅读2.3k次,点赞6次,收藏14次。SPI的详情简介不必赘述。假设我们通过SPI发送0xAA,我们的数据线就会变为10101010,通过修改不同的内容,即可修改SPI中0和1的持续时间。比如0xF0即为前半周期为高电平,后半周期为低电平的状态。在SPI的通信模式中,CPHA配置会影响该实验,下图展示了不同采样位置的SPI时序图[1]。CPOL = 0,CPHA = 1:CLK空闲状态 = 低电平,数据在下降沿采样,并在上升沿移出CPOL = 0,CPHA = 0:CLK空闲状态 = 低电平,数据在上升沿采样,并在下降沿移出。_stm32g431cbu6
文章浏览阅读1.2k次,点赞2次,收藏8次。数据链路层习题自测问题1.数据链路(即逻辑链路)与链路(即物理链路)有何区别?“电路接通了”与”数据链路接通了”的区别何在?2.数据链路层中的链路控制包括哪些功能?试讨论数据链路层做成可靠的链路层有哪些优点和缺点。3.网络适配器的作用是什么?网络适配器工作在哪一层?4.数据链路层的三个基本问题(帧定界、透明传输和差错检测)为什么都必须加以解决?5.如果在数据链路层不进行帧定界,会发生什么问题?6.PPP协议的主要特点是什么?为什么PPP不使用帧的编号?PPP适用于什么情况?为什么PPP协议不_接收方收到链路层数据后,使用crc检验后,余数为0,说明链路层的传输时可靠传输
文章浏览阅读587次。软件测试工程师移民加拿大 无证移民,未受过软件工程师的教育(第1部分) (Undocumented Immigrant With No Education to Software Engineer(Part 1))Before I start, I want you to please bear with me on the way I write, I have very little gen...
文章浏览阅读304次。Thinkpad X250笔记本电脑,装的是FreeBSD,进入BIOS修改虚拟化配置(其后可能是误设置了安全开机),保存退出后系统无法启动,显示:secure boot failed ,把自己惊出一身冷汗,因为这台笔记本刚好还没开始做备份.....根据错误提示,到bios里面去找相关配置,在Security里面找到了Secure Boot选项,发现果然被设置为Enabled,将其修改为Disabled ,再开机,终于正常启动了。_安装完系统提示secureboot failure
文章浏览阅读10w+次,点赞93次,收藏352次。1、用strtok函数进行字符串分割原型: char *strtok(char *str, const char *delim);功能:分解字符串为一组字符串。参数说明:str为要分解的字符串,delim为分隔符字符串。返回值:从str开头开始的一个个被分割的串。当没有被分割的串时则返回NULL。其它:strtok函数线程不安全,可以使用strtok_r替代。示例://借助strtok实现split#include <string.h>#include <stdio.h&_c++ 字符串分割
文章浏览阅读2.3k次。1 .高斯日记 大数学家高斯有个好习惯:无论如何都要记日记。他的日记有个与众不同的地方,他从不注明年月日,而是用一个整数代替,比如:4210后来人们知道,那个整数就是日期,它表示那一天是高斯出生后的第几天。这或许也是个好习惯,它时时刻刻提醒着主人:日子又过去一天,还有多少时光可以用于浪费呢?高斯出生于:1777年4月30日。在高斯发现的一个重要定理的日记_2013年第四届c a组蓝桥杯省赛真题解答
文章浏览阅读851次,点赞17次,收藏22次。摘要:本文利用供需算法对核极限学习机(KELM)进行优化,并用于分类。
文章浏览阅读1.1k次。一、系统弱密码登录1、在kali上执行命令行telnet 192.168.26.1292、Login和password都输入msfadmin3、登录成功,进入系统4、测试如下:二、MySQL弱密码登录:1、在kali上执行mysql –h 192.168.26.129 –u root2、登录成功,进入MySQL系统3、测试效果:三、PostgreSQL弱密码登录1、在Kali上执行psql -h 192.168.26.129 –U post..._metasploitable2怎么进入
文章浏览阅读257次。本文将为初学者提供Python学习的详细指南,从Python的历史、基础语法和数据类型到面向对象编程、模块和库的使用。通过本文,您将能够掌握Python编程的核心概念,为今后的编程学习和实践打下坚实基础。_python人工智能开发从入门到精通pdf