RHCE——十一、NFS服务器

NFS服务器

  • 一、简介
    • 1、NFS背景介绍
    • 2、生产应用场景
  • 二、NFS工作原理
    • 1、示例图
    • 2、流程
  • 三、NFS的使用
    • 1、安装
    • 2、配置文件
    • 3、主配置文件分析
      • 3.1 实验1
    • 4、NFS账户映射
      • 4.1 实验2
      • 4.2 实验3
  • 四、autofs自动挂载服务
    • 1、产生原因
    • 2、安装
    • 3、配置文件分析
    • 4、实验4
    • 5、实验5

一、简介

1、NFS背景介绍

  • NFS是一种古老的用于在UNIX/Linux主机之间进行文件共享的协议。它古老到你必须穿着白大褂才能接近一台计算机的年代。在那个年代,所有的联网计算机都被认为是可信的,而不像现今这样,任何人都有多种多样方法能连接到你的计算机。因此,NFS在开发的时候专注于快速及易用的文件共享,而忽视了其安全性设计
  • NFS(Network File System,网络文件系统)是FreeBSD支持的文件系统中的一种,它允许网络中的计算机(不同的计算机、不同的操作系统)之间通过TCP/IP网络共享资源,主要在unix系列操作系统上使用。
  • NFS服务器可以让PC将网络中的NFS服务器共享的目录挂载到本地端的文件系统中,而在本地端的系统中看来,那个远程主机的目录就好像是自己的一个磁盘分区一样。
  • 由于NFS支持的功能比较多,而不同的功能都会使用不同的程序来启动,每启动一个功能就会启用一些端口来传输数据,因此NFS的功能所对应的端口并不固定,而是随机取用一些未被使用的小于1024的端口用于传输。但如此一来就会产生客户端连接服务器的问题,因为客户端需要知道服务器端的相关端口才能够连接。此时就需要RPC
  • RPC(Remote Procedure Call,远程过程调用):由于服务器在启动NFS时会随机选取数个端口号,并主动向RPC注册,所以RPC知道每个NFS功能所对应的端口号,RPC将端口号通知给客户端,让客户端可以连接到正确的端口上去。RPC采用固定端口号port 111来监听客户端的需求并向客户端响应正确的端口号。
  • 注:在启动NFS之前,要先启动RPC,否则NFS会无法向RPC注册。另外,RPC若重新启动,原来注册的数据会消失不见,因此RPC重启后,它管理的所有服务都需要重新启动以重新向RPC注册。

2、生产应用场景

  • NFS网络文件系统很像windows系统的网络共享、安全功能、网络驱动器映射,这也和linux系统里的Samba服务器类似。只不过一般情况下,windows网络共享服务或Samba服务用于办公局域网共享,而互联网中小型网站集群架构后端常用NFS进行数据共享,如果是大型网站,那可能会用到更复杂的分布式文件系统。

  • 在企业集群架构的工作场景中,NFS作为所有前端web服务的共享存储,存储的内容一般包括网站用户上传的图片、附件、头像等,注意,网站的程序代码就不要放在NFS共享里了,因为网站程序是开发运维人员统一发布,不存在发布延迟问题,直接批量发布到web节点提供访问比共享到NFS里访问效率会更高些。

  • NFS是当前互联网系统架构中常用的数据存储服务之一,中小型网站(2000万pv(页面浏览量)以下)公示应用频率居高,大公司或门户除了使用NFS外,还可能会使用更为复杂的分布式文件系统

二、NFS工作原理

1、示例图

2、流程

  • 首先服务器端启动RPC服务,并开启111端口
  • 服务器端启动NFS服务,并向RPC注册端口信息
  • 客户端启动RPC(portmap服务),向服务端的RPC(portmap)服务请求服务端的NFS端口
  • 服务端的RPC(portmap)服务反馈NFS端口信息给客户端。(服务器搭建成功后可以使用下列命令查看,一般都是2049)

三、NFS的使用

1、安装

[root@server ~]# yum  install  nfs-utils   -y
[root@server ~]# yum  install  rpcbind  -y # 默认已安装

在这里插入图片描述

2、配置文件

  • 主配置文件:/etc/exports , 文件不一定存在
  • /usr/sbin/exportfs : 该文件是维护NFS共享目录资源的命令文件,可以使用命令重新共享/etc/exports的目录资源、卸载共享目录
  • 日志目录:/var/lib/nfs
  • 权限设置文件:/var/lib/nfs/etab

3、主配置文件分析

  • /etc/exports 文件默认为空文件,需要输入nfs共享命令

  • 格式:共享目录的路径 允许访问的NFS客户端(共享权限参数)

  • 分析

    • 允许访问的NFS客户端:可以写完整的IP地址或IP网段,如:
      • 192.168.48.130/24
      • 192.168.48.130/255.255.255.0
      • 192.168.48.0/24
      • *: 允许所有主机都可以访问
    • 权限参数:必须卸载园括号中,且括号是紧挨着主机名的,全选的相关参数如下,多个参数之间使用逗号隔开:
权限参数作用
ro只读
rw读写(最终还要看文件系统rwx权限)
root_squash当NFS客户端以root账户访问时,映射为NFS服务器端的匿名账户(nobody)
no_root_squash当NFS客户端以root账户访问时,映射为root账户(不推荐、不安全)
all_squash无论NFS客户端使用什么账户访问,均映射为NFS 服务器的匿名账户(nobody),推荐
no_all_squash客户端普通账户访问服务器的数据时,实际的信息原样显示
anonuid= anongid=将文件的用户和工作组映射为指定UID和GID,若不指定则默认为65534(nobody)
sync同步,同时将数据写入内存与硬盘中,保证数据不会丢失,推荐
async异步,优先将数据保存到内存,然后在写入硬盘,效率高,但可能会数据丢失
  • exports文件内容示例
  • /home/public *(rw,sync) : 对所有主机共享/home/public目录,可读可写,同步传输
    • /home/public 192.168.48.131/24(ro,all_squash,sync) : 只对131主机开发共享/home/public ,只读权限,客户端映射为nobody账户,同步传输
    • /home/public 192.168.48.0/24(rw , sync , all_squash , anonuid=2000, anongid=2000): 对192.168.48.0网段中所有主机开放/home/public 目录,可读可写,同步传输,客户端映射为nobody,uid为2000,gid为2000

3.1 实验1

  • 建立NFS服务器,使用客户端访问
  • 第一步:服务端server操作,完成准备工作
root@server ~]# setenforce  0
[root@server ~]# systemctl stop  firewalld
[root@server ~]# yum  install  nfs-utils  -y   
  • 第二步:客户端node1操作,完成准备工作
root@server ~]# setenforce  0
[root@server ~]# systemctl stop  firewalld
[root@server ~]# yum  install  nfs-utils  -y  

在这里插入图片描述

  • 第三步:服务端server操作,新建共享目录,并设置权限
[root@server ~]# mkdir   /nfsfile
[root@server ~]# echo  "www.openlab.com" >   /nfsfile/redme
[root@server ~]# ls  /nfsfile/
redme
[root@server ~]# cat  /nfsfile/redme 
www.openlab.com
[root@server ~]# chmod  -Rf  777  /nfsfile/

在这里插入图片描述

  • 第四步:服务端server操作,修改nfs配置文件
[root@server ~]# vim  /etc/exports
/nfsfile        192.168.13.135/24(rw,all_squash,sync)

在这里插入图片描述

  • 第五步:服务端server操作,先启动rpc服务,后启动nfs服务
[root@server ~]# systemctl start rpcbind
[root@server ~]# systemctl start nfs-server
[root@server ~]# systemctl enable rpcbind
[root@server ~]# systemctl enable nfs-server
# 注意:启动rpcbind服务时,若启动失败,可以先停止服务,在重新启动
systemctl stop rpcbind
systemctl start rpcbind
  • 第六步:客户端node1操作,通过命令查询共享数据并远程挂载使用
# 查询远程共享信息:showmount  -参数  服务器IP地址
# 参数:# -e:显示NFS服务器的共享列表# -a:显示本地挂载的文件资源列表# -v:显示版本号
[root@node1 ~]# showmount  -e  192.168.48.130  # 查询130的共享信息
Export list for 192.168.48.130:
/nfsfile 192.168.48.131/24[root@node1 ~]# mkdir  /nfs1  # 新建本地挂载目录
[root@node1 ~]# mount  -t  nfs  192.168.48.130:/nfsfile  /nfs1  # 远程挂载
[root@node1 ~]# cd  /nfs1/   # 通过本地目录查看远程共享数据
[root@node1 nfs1]# ls
redme
[root@node1 nfs1]# cat  redme 
www.openlab.com
  • 第七步:客户端node1操作,设置开机挂载,实现挂载永久性
[root@node1 nfs1]# vim   /etc/fstab   # 添加如下:
192.168.48.130:/nfsfile         /nfs1   nfs     defaults        0       0
# 重启后测试

原文件:
在这里插入图片描述
更改后:
在这里插入图片描述

4、NFS账户映射

4.1 实验2

  • 基于上例,将/nfsfile权限进行修改,查看客户端是够可以访问,是否可以写入数据
# 定位server端[root@server ~]# vim  /etc/exports  # 确认是否为rw写权限
[root@server ~]# cd  /nfsfile/
[root@server nfsfile]# ll
总用量 4
-rwxrwxrwx 1 root root 16  828 09:29 redme
[root@server nfsfile]# chmod  -Rf  444  /nfsfile/   # 修改权限
[root@server nfsfile]# ll
总用量 4
-r--r--r-- 1 root root 16  828 09:29 redme# 定位node1端
root@node1 nfs1]# cd  ~
[root@node1 ~]# cd  /nfs1
-bash: cd: /nfs1: 权限不够# 定位server端
[root@server nfsfile]# chmod  -Rf  777  /nfsfile/  # 多执行几次,可能有延迟
[root@server nfsfile]# chmod  -Rf  777  /nfsfile/
[root@server nfsfile]# chmod  -Rf  777  /nfsfile/# 定位node1端
[root@node1 ~]# cd  /nfs1
[root@node1 nfs1]# 

在这里插入图片描述
在这里插入图片描述

4.2 实验3

  • 客户端访问服务端,演示账户映射
# 定位node1端
[root@node1 nfs1]# touch  test.txt# 定位server端
[root@server nfsfile]# ll
总用量 4
-rwxrwxrwx 1 root   root   16  828 09:29 redme
-rw-r--r-- 1 nobody nobody  0  828 10:18 test.txt  # 注意:账户及工作组
[root@server nfsfile]# vim  /etc/exports
/nfsfile        192.168.48.131/24(rw,root_squash,sync)
[root@server nfsfile]# exportfs  -arv    # 不卸载,即可让配置文件生效
exporting 192.168.48.131/24:/nfsfile# 定位node1端
[root@node1 nfs1]# cd  /
[root@node1 /]# su  fox
[fox@node1 /]$ cd  /nfs1
[fox@node1 nfs1]$ ls
redme  test2.txt  test.txt
[fox@node1 nfs1]$ touch  test3.txt
[fox@node1 nfs1]$ ll
总用量 4
-rwxrwxrwx 1 root   root   16  828 09:29 redme
-rw-r--r-- 1 nobody nobody  0  828 10:23 test2.txt
-rw-rw-r-- 1 fox    fox     0  828 10:25 test3.txt  # 注意:账户映射名称
-rw-r--r-- 1 nobody nobody  0  828 10:18 test.txt
[fox@node1 nfs1]$ su  root
密码: 
[root@node1 nfs1]# # 定位server端
[root@server nfsfile]# vim  /etc/exports
/nfsfile        192.168.48.131/24(rw,all_squash,sync,anonuid=3000,anongid=3000)
[root@server nfsfile]# exportfs  -arv  # 信配置生效
exporting 192.168.48.131/24:/nfsfile# 定位node1端
[root@node1 nfs1]# touch  test4.txt
[root@node1 nfs1]# ll
总用量 4
-rwxrwxrwx 1 root   root   16  828 09:29 redme
-rw-r--r-- 1 nobody nobody  0  828 10:23 test2.txt
-rw-rw-r-- 1 fox    fox     0  828 10:25 test3.txt
-rw-r--r-- 1   3000   3000  0  828 10:29 test4.txt  # 注意:uid和guid
-rw-r--r-- 1 nobody nobody  0  828 10:18 test.txt

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

四、autofs自动挂载服务

1、产生原因

  • 在一般NFS文件系统的使用过程中,如果客户端要使用服务端所提供的文件系统,可以在 /etc/fstab中设置开机时自动挂载,也可以在登录系统后手动利用mount来挂载。

  • 由于网络的问题,NFS服务器与客户端的连接不会一直存在,当我们挂载了NFS服务器之后,任何一方脱机都可能造成另外一方等待超时,如果在资源挂载后长期不使用,也会造成服务器硬件资源的浪费。

  • 为了解决这样的问题,就出现了下面的想法:

    • 当客户端在有使用NFS文件系统的需求时才让系统自动挂载。

    • 当NFS文件系统使用完毕后(autofs默认自动卸载时间为300s即5分钟),让NFS自动卸载。

  • autofs 自动挂载服务可以帮我们解决这一问题,该服务是运行在客户端的一种 Linux 系统守护进程,在用户需要使用该文件系统时才去动态挂载,从而节约了网络资源和服务器的硬件资源。

2、安装

[root@node1 ~]# yum install autofs -y   # 客户端安装

3、配置文件分析

  • 配置文件路径:/etc/auto.master

  • 作用:处于生产环境中的 Linux 服务器,一般会同时管理许多设备的挂载操作。如果把这些设备挂载信息都写入到 autofs 服务的主配置文件中,无疑会让主配置文件臃肿不堪,不利于服务执行效率,也不利于日后修改里面的配置内容,则需要将挂载的设备独立配置形成子文件,主配置文件只存储配置挂载设置的文件名

  • /etc/auto.master文件内容格式:挂载目录 子配置文件

    • 挂载目录:不需要事先存在,因为autofs会主动建立该目录
    • 子配置文件:文件名可自定义
    • 例:/nfs /etc/auto.nfs
  • 子配置文件由自己创建,内容格式:

    • 本地挂载子目录 [-挂载参数] 服务器地址:目录
    • 例:testmnt 192.168.48.130:/data
    • 挂载参数:
参数功能
fg/bg当执行挂载时,该挂载行为会在前台(fg)还是后台(bg)执行,若在前台执行,则mount会持续尝试挂载,直到成功或time out为止;若为后台执行,则mount会在后台持续多次进行mount,而不会影响到前台的程序运行。
soft/hardhard表示当两者之间的任何一台主机脱机,则RPC会持续地呼叫,直到对方恢复连接为止。如果是soft的话,那RPC会在time out后重复呼叫,而非持续呼叫
intr当使用上面提到的hard方式挂载时,若加上intr这个参数,则当RPC持续呼叫时,该次的呼叫是可以被中断的
rsize/wsize读出(rsize)与写入(wsize)的区块大小。这个设置值可以影响客户端与服务器

4、实验4

  • 服务器创建共享目录,客户端实现自动挂载
  • 第一步:服务器与客户端都恢复快照,关闭安全软件
  • 第二步:安装软件
# 定位server端
[root@server ~]# yum  install  nfs-utils  -y
[root@server ~]# yum  install  rpcbind  -y# 定位node1端
[root@node1 ~]# yum  install  nfs-utils  -y
[root@node1 ~]# yum  install  autofs  -y
  • 第三步:定位server端,新建共享目录,编辑nfs配置文件,设置权限
root@server ~]# mkdir  /data
[root@server ~]# vim   /etc/exports
/data   *(ro,sync,all_squash)[root@server ~]# echo  "this is test"  > /data/file.txt
[root@server ~]# chmod  -Rf  777 /data

在这里插入图片描述
在这里插入图片描述

  • 第四步:定位server端,启动服务,必须先启动rpcbind
[root@server ~]# systemctl start rpcbind  
[root@server ~]# systemctl start nfs-server  
[root@server ~]# systemctl enable rpcbind  
[root@server ~]# systemctl enable nfs-server  
  • 第五步:定位node1端,编辑自动挂载主配置文件
# 计划node1端,挂载目录为/nfs/testmnt
[root@node1 ~]# vim  /etc/auto.master  #定位第7行添加一行 
/nfs    /etc/auto.nfs            # 挂载的父目录及子配置文件(子配置文件自行命名)[root@node1 ~]# vim  /etc/auto.nfs   # 编辑子配置文件
testmnt         192.168.48.130:/data   # 挂载目录的子目录    nfs服务器参数

在这里插入图片描述
在这里插入图片描述

  • 第六步:定位node1端,启动服务
[root@node1 /]# systemctl start autofs
[root@node1 /]# systemctl enable autofs
  • 第七步:定位node1端,测试
[root@node1 /]# cd  /nfs
[root@node1 nfs]# ls
[root@node1 nfs]# cd  testmnt   # 进入挂载目录时,testmnt自动创建
[root@node1 testmnt]# ls
file.txt
[root@node1 testmnt]# cat  file.txt 
this is test
[root@node1 testmnt]# df  -h
文件系统               容量  已用  可用 已用% 挂载点
devtmpfs               4.0M     0  4.0M    0% /dev
tmpfs                  968M     0  968M    0% /dev/shm
tmpfs                  388M  9.4M  378M    3% /run
/dev/mapper/rhel-root   16G  4.2G   12G   27% /
/dev/nvme0n1p1         395M  235M  160M   60% /boot
tmpfs                  194M   92K  194M    1% /run/user/0
/dev/sr0               8.5G  8.5G     0  100% /run/media/root/RHEL-9-1-0-BaseOS-x86_64
192.168.48.130:/data    16G  4.2G   12G   27% /nfs/testmnt

在这里插入图片描述
在这里插入图片描述

5、实验5

  • 自动挂载光驱

  • 第一步:定位server,恢复快照,关闭安全软件,安装autofs软件

[root@server ~]# yum  install  autofs  -y
  • 第二步:计划光驱本地挂载目录为:/media/cdrom
  • 第三步:编辑主配置文件
[root@server ~]# vim  /etc/auto.master
/media  /etc/iso.aa# /media 为最终挂载目录的父目录
# /etc/iso.aa:为子配置文件

在这里插入图片描述

在这里插入图片描述

  • 第四步:编写子配置文件
[root@server ~]# vim  /etc/iso.aa
cdrom   -fstype=iso9660,ro,nosuid,nodev :/dev/sr0  # 注意:冒号前有空格

在这里插入图片描述

  • 第五步:启动服务
[root@server ~]# systemctl start autofs
[root@server ~]# systemctl enable autofs
  • 第六步:测试
[root@server ~]# umount  /dev/sr0   # 先卸载设备[root@server ~]# df  -h             # 查看已挂载的设备信息
文件系统               容量  已用  可用 已用% 挂载点
devtmpfs               4.0M     0  4.0M    0% /dev
tmpfs                  968M     0  968M    0% /dev/shm
tmpfs                  388M  9.5M  378M    3% /run
/dev/mapper/rhel-root   16G  4.2G   12G   27% /
/dev/nvme0n1p1         395M  235M  160M   60% /boot
tmpfs                  194M  104K  194M    1% /run/user/0[root@server ~]# cd  /media
[root@server media]# ls
[root@server media]# cd  cdrom   # 触发自动挂载
[root@server cdrom]# ls          
AppStream  EFI   extra_files.json  images    media.repo               RPM-GPG-KEY-redhat-release
BaseOS     EULA  GPL               isolinux  RPM-GPG-KEY-redhat-beta
[root@server cdrom]# df -h     
文件系统               容量  已用  可用 已用% 挂载点
devtmpfs               4.0M     0  4.0M    0% /dev
tmpfs                  968M     0  968M    0% /dev/shm
tmpfs                  388M  9.5M  378M    3% /run
/dev/mapper/rhel-root   16G  4.2G   12G   27% /
/dev/nvme0n1p1         395M  235M  160M   60% /boot
tmpfs                  194M  104K  194M    1% /run/user/0
/dev/sr0               8.5G  8.5G     0  100% /media/cdrom

在这里插入图片描述

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

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

相关文章

算法通关村十三关 | 进制转换问题处理模板

1. 七进制数 题目&#xff1a;LeetCode504&#xff1a;504. 七进制数 - 力扣&#xff08;LeetCode&#xff09; 思路 进制转换&#xff0c;对几转换就是对几求余&#xff0c;最后将所有的余数反过来即可、如果num< 0&#xff0c;先取绝对值&#xff0c;再进行操作。 100转7…

【WINAPI】文件读写操作问题

问题描述 在利用WINAPI中的WriteFile和ReadFile函数进行文件读写操作时&#xff0c;出现无法正常读写文件报错。 分析问题 查阅WINAPI源码&#xff0c;查看参数列表各个参数的数据类型。 发现其中第二个参数&#xff0c;也就是需要写进文件的真实数据&#xff0c;其数据类型…

Visual Studio软件安装包分享(附安装教程)

目录 一、软件简介 二、软件下载 一、软件简介 Visual Studio是微软公司开发的一款集成开发环境&#xff08;IDE&#xff09;&#xff0c;广泛应用于Windows平台上的应用程序和Web应用程序的开发。以下是Visual Studio软件的主要特点和功能&#xff1a; 集成开发环境&#x…

文件夹无法删除?简单3招,轻松解决问题!

“我电脑里有一个文件夹占用了很大的内存&#xff0c;我想将它删除来释放一些内存&#xff0c;但是根本没法删除&#xff0c;为什么会这样呢&#xff1f;文件夹无法删除应该怎么办呢&#xff1f;” 在日常电脑使用中&#xff0c;有时候会遇到文件夹无法删除的情况&#xff0c;这…

IDEA如何打jar包

IntelliJ IDEA如何打jar包 1、无maven打jar包 1、编写好Java项目后&#xff0c;点击File --> Project Structure&#xff0c;然后按照以下图示步骤进行打包操作 若项目还存在一些额外的文件&#xff0c;可通过以下方式&#xff0c;将文件添加到jar包中。 //如果我们将项目…

如何在VR头显端实现低延迟的RTSP或RTMP播放

技术背景 VR&#xff08;虚拟现实技术&#xff09;给我们带来身临其境的视觉体验&#xff0c;广泛的应用于城市规划、教育培训、工业仿真、房地产、水利电力、室内设计、文旅、军事等众多领域&#xff0c;常用的行业比如&#xff1a; 教育行业&#xff1a;VR头显可以用于教育…

淘宝API技术解析,实现按图搜索淘宝商品

淘宝提供了开放平台接口&#xff08;API&#xff09;来实现按图搜索淘宝商品的功能。您可以通过以下步骤来实现&#xff1a; 1. 获取开放平台的访问权限&#xff1a;首先&#xff0c;您需要在淘宝开放平台创建一个应用&#xff0c;获取访问淘宝API的权限。具体的申请步骤和要求…

前端开发之Element Plus的分页组件el-pagination显示英文转变为中文

前言 在使用element的时候分页提示语句是中文的到了element-plus中式英文的&#xff0c;本文讲解的就是怎样将英文转变为中文 效果图 解决方案 如果你的element-plus版本为2.2.29以下的 import { createApp } from vue import App from ./App.vue import ElementPlus from …

最新本地大模型进展#Chinese-LLaMA-2支持16k长上下文

‍‍ Hi&#xff0c;今天为大家介绍最新的本地中文语言模型进展。 [2023/08/25] Chinese-LLaMA-2发布了新的更新&#xff1a; 长上下文模型Chinese-LLaMA-2-7B-16K和Chinese-LLaMA-2-13B-16K&#xff0c;支持16K上下文&#xff0c;并可通过NTK方法进一步扩展至24K。 这意味着在…

uniapp 实现地图距离计算

在uniapp中实现地图距离计算可以借助第三方地图服务API来实现。以下是一种基本的实现方式&#xff1a; 注册地图服务API账号&#xff1a;你可以选择使用高德地图、百度地图等提供地图服务的厂商&#xff0c;注册一个开发者账号并获取API密钥。 安装相关插件或SDK&#xff1a;根…

区块链BaaS篇

区块链BaaS&#xff08;Blockchain as a Service&#xff09;区块链即服务&#xff1b;感觉5年前做的BaaS和现在做的BaaS没啥区别&#xff0c;换了批人重复造轮子&#xff0c;BaaS做的越来越乱&#xff0c;也越来越中心化。BaaS是方便区块链调用的工具&#xff0c;工具是方便使…

人力资源小程序的设计方案与实现

随着互联网的发展&#xff0c;人才招聘已经成为许多企业的一项重要任务。为了提高招聘效率和便利求职者&#xff0c;许多企业开始采用小程序作为招聘平台。本文将为大家介绍一个搭建本地人才招聘网小程序的实用指南。 首先&#xff0c;我们需要登录【乔拓云】制作平台&#xff…

checkstyle检查Java编程样式:识别应该被定义为final的类

介绍 总体说明 checkstyle可以使用FinalClass检查应该被定为final的类。如果违反了&#xff0c;就会报违反项&#xff1a; https://checkstyle.sourceforge.io/checks/design/finalclass.html checkstyle规则集文件对FinalClass模块的配置&#xff1a; 哪些类可以被定义fi…

React笔记(二)JSX

一、JSX JSX是javascript XML的简写&#xff0c;实际上是javascript的扩展&#xff0c;既有javascript的语法结构&#xff0c;又有XML的结构 1、JSX的规则要求 jsx必须要有一个根节点 如果不想产生无用的根标签&#xff0c;但是还要遵守JSX的语法的要求&#xff0c;可以使用…

Docker harbor 私有仓库的部署和管理

目录 一、什么是Harbor 二、Harbor的特性 三、Harbor的构成 四、部署配置Docker Harbor 1. 首先需要安装 Docker-Compose 服务 2.部署 Harbor 服务 3.使用harbor仓库 &#xff08;1&#xff09;项目管理 &#xff08;2&#xff09;用户管理 一、什么是Harbor Harbor …

飞桨中的李宏毅课程中的第一个项目——PM2.5的预测

所谓的激活函数&#xff0c;就是李宏毅老师讲到的sigmoid函数 和 hard sigmoid函数 &#xff0c;ReLU函数那些 现在一点点慢慢探索&#xff0c;会成为日后想都做不到的经历&#xff0c;当你啥也不会的时候&#xff0c;才是慢慢享受探索的过程。 有一说一&#xff0c;用chatGP…

安卓版yolo-fastest

安卓版本yolofastest效果测试 安卓配置OPENCV4ANDROID&#xff0c;见我的博客一篇文章opencv4dandroid配置 这个不需要使用JNI&#xff0c;十分简单的配置 说真的&#xff0c;其实只调用OPENCV的函数&#xff0c;自己写的代码不多&#xff0c;使用OPENCV4ANDROID和JNI的时间差…

项目经理常用工具01

主要工具 表达工具—SCRTV方法 情境 Scene&#xff1a;明确问题&#xff1a;是什么&#xff1f;冲突 Confilict&#xff1a;提出疑问&#xff1a;怎么了?原因 Reason&#xff1a;分析原因&#xff1a;为什么&#xff1f;策略 Tactics&#xff1a;进行决策&#xff1a;怎么办…

数据建模在MES管理系统中的作用,以及合理设计

随着信息化的快速发展&#xff0c;MES系统解决方案在企业中的应用越来越广泛。作为实现生产过程数字化的重要组成部分&#xff0c;MES系统扮演着监控、控制和优化生产运营的关键角色。而在MES系统中&#xff0c;数据建模是实现高效生产管理的重要环节之一。本文将探讨数据建模在…

自定义node-red节点中,如何编写节点的配置信息弹窗

前言 最近有读者通过博客向我咨询,在自定义node-red节点时,如何编写该节点的配置页面,就是我们通常见到的,双节节点打开的信息弹窗。如下图: 上面两张图,展示了inject节点与mqtt in 节点的配置弹窗。 在弹窗中,除了上面的删除,取消,完成,和下面的失效按钮。 中间…