DNF与PXE网络装机(Linux)_dnf挂载-程序员宅基地

技术标签: 运维  linux  服务器  

笔者的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

然后重新打开试验机

自动安装,成功!

这是我在学习空闲之余写的,可能会略有不足,有时间我会做出更新.

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/laykr/article/details/133042157

智能推荐

攻防世界_难度8_happy_puzzle_攻防世界困难模式攻略图文-程序员宅基地

文章浏览阅读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..._达梦数据库导入导出

js引入kindeditor富文本编辑器的使用_kindeditor.js-程序员宅基地

文章浏览阅读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

STM32学习过程记录11——基于STM32G431CBU6硬件SPI+DMA的高效WS2812B控制方法-程序员宅基地

文章浏览阅读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

计算机网络-数据链路层_接收方收到链路层数据后,使用crc检验后,余数为0,说明链路层的传输时可靠传输-程序员宅基地

文章浏览阅读1.2k次,点赞2次,收藏8次。数据链路层习题自测问题1.数据链路(即逻辑链路)与链路(即物理链路)有何区别?“电路接通了”与”数据链路接通了”的区别何在?2.数据链路层中的链路控制包括哪些功能?试讨论数据链路层做成可靠的链路层有哪些优点和缺点。3.网络适配器的作用是什么?网络适配器工作在哪一层?4.数据链路层的三个基本问题(帧定界、透明传输和差错检测)为什么都必须加以解决?5.如果在数据链路层不进行帧定界,会发生什么问题?6.PPP协议的主要特点是什么?为什么PPP不使用帧的编号?PPP适用于什么情况?为什么PPP协议不_接收方收到链路层数据后,使用crc检验后,余数为0,说明链路层的传输时可靠传输

软件测试工程师移民加拿大_无证移民,未受过软件工程师的教育(第1部分)-程序员宅基地

文章浏览阅读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...

随便推点

Thinkpad X250 secure boot failed 启动失败问题解决_安装完系统提示secureboot failure-程序员宅基地

文章浏览阅读304次。Thinkpad X250笔记本电脑,装的是FreeBSD,进入BIOS修改虚拟化配置(其后可能是误设置了安全开机),保存退出后系统无法启动,显示:secure boot failed ,把自己惊出一身冷汗,因为这台笔记本刚好还没开始做备份.....根据错误提示,到bios里面去找相关配置,在Security里面找到了Secure Boot选项,发现果然被设置为Enabled,将其修改为Disabled ,再开机,终于正常启动了。_安装完系统提示secureboot failure

C++如何做字符串分割(5种方法)_c++ 字符串分割-程序员宅基地

文章浏览阅读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++ 字符串分割

2013第四届蓝桥杯 C/C++本科A组 真题答案解析_2013年第四届c a组蓝桥杯省赛真题解答-程序员宅基地

文章浏览阅读2.3k次。1 .高斯日记 大数学家高斯有个好习惯:无论如何都要记日记。他的日记有个与众不同的地方,他从不注明年月日,而是用一个整数代替,比如:4210后来人们知道,那个整数就是日期,它表示那一天是高斯出生后的第几天。这或许也是个好习惯,它时时刻刻提醒着主人:日子又过去一天,还有多少时光可以用于浪费呢?高斯出生于:1777年4月30日。在高斯发现的一个重要定理的日记_2013年第四届c a组蓝桥杯省赛真题解答

基于供需算法优化的核极限学习机(KELM)分类算法-程序员宅基地

文章浏览阅读851次,点赞17次,收藏22次。摘要:本文利用供需算法对核极限学习机(KELM)进行优化,并用于分类。

metasploitable2渗透测试_metasploitable2怎么进入-程序员宅基地

文章浏览阅读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怎么进入

Python学习之路:从入门到精通的指南_python人工智能开发从入门到精通pdf-程序员宅基地

文章浏览阅读257次。本文将为初学者提供Python学习的详细指南,从Python的历史、基础语法和数据类型到面向对象编程、模块和库的使用。通过本文,您将能够掌握Python编程的核心概念,为今后的编程学习和实践打下坚实基础。_python人工智能开发从入门到精通pdf

推荐文章

热门文章

相关标签