当前位置: 首页 > news >正文

做羊毛毡的网站做网站要会写什么

做羊毛毡的网站,做网站要会写什么,乌兰察布做网站公司,几分钟弄清楚php做网站目录 写在前面一、 HDFS概述1.1 HDFS简介1.2 HDFS优缺点1.2.1 优点1.2.2 缺点 1.3 HDFS组成架构1.4 HDFS文件块大小 二、HDFS的Shell操作#xff08;开发重点#xff09;2.1 基本语法2.2 命令大全2.3 常用命令实操2.3.1 上传2.3.2 下载2.3.3 HDFS直接操作 三、HDFS的API操作3… 目录 写在前面一、 HDFS概述1.1 HDFS简介1.2 HDFS优缺点1.2.1 优点1.2.2 缺点 1.3 HDFS组成架构1.4 HDFS文件块大小 二、HDFS的Shell操作开发重点2.1 基本语法2.2 命令大全2.3 常用命令实操2.3.1 上传2.3.2 下载2.3.3 HDFS直接操作 三、HDFS的API操作3.1 配置Windows3.2 HDFS的API案例实操3.2.1 HDFS文件上传3.2.2 HDFS文件下载3.2.3 HDFS文件更名和移动3.2.4 HDFS删除文件和目录3.2.5 HDFS文件详情查看3.2.6 HDFS文件和文件夹判断 写在最后 写在前面 如今数据正以指数级增长各行各业都在追求更多的数据存储、高效的数据处理和可靠的数据基础来驱动业务的发展。Hadoop Distributed File SystemHDFS作为Hadoop生态系统的核心组件之一成为构建可靠的大数据基础的不二选择之一。本文将深入剖析HDFS的架构与优势。 一、 HDFS概述 1.1 HDFS简介 HDFSHadoop分布式文件系统是Apache Hadoop框架的一部分设计用于存储和处理大规模数据集的分布式文件系统。HDFS产生的背景主要是为了满足处理大规模数据的需求。 在过去传统的文件系统难以处理大规模数据集因为它们通常只能在单个服务器上存储和操作数据。随着大数据时代的到来企业和组织面临着巨大的数据规模和复杂性。为了应对这个挑战HDFS被开发出来作为一个高度可靠和高容量的分布式文件系统。 HDFS的设计目标是能够在廉价的硬件上运行并且能够容纳上千台机器的集群。它通过将数据切分成多个块并将其分散存储在不同的计算节点上实现了高吞吐量的数据访问和处理能力。此外HDFS还提供了故障容错功能能够自动处理存储节点的故障。 简而言之HDFS是为了解决大规模数据处理问题而设计的它提供了高可靠性、高扩展性和高吞吐量的分布式文件系统解决方案。 1.2 HDFS优缺点 1.2.1 优点 高容错、高可用、高扩展 数据冗余多副本、副本丢失后自动恢复NameNode HA、安全模式10K节点规模通过横向扩展来增加存储容量和处理能力。 海量数据存储高容量 典型文件大小GB~TB百万以上文件数量PB甚至EB以上数据规模 构建成本低、安全可靠 构建在廉价的商用服务器上降低了存储成本和维护成本。通过多副本机制提高可靠性提供了容错和恢复机制 适合大规模离线批处理 流式数据访问数据位置暴露给计算框架 1.2.2 缺点 不适合低延迟数据访问 对于实时数据访问和低延迟要求较高的场景HDFS的性能可能不够理想 不适合大量小文件存储 元数据会占用NameNode大量存储空间磁盘寻道时间超过读取时间 不支持并发写入 一个文件同时只能有一个写不允许多个线程同时写 不支持文件随机修改 仅支持数据追加 1.3 HDFS组成架构 NameNodenn NameNode是HDFS的主节点Master负责管理整个文件系统的命名空间和数据块的元数据信息。它维护文件系统的目录结构、文件的安全权限信息和数据块的位置信息等。NameNode还处理客户端的文件系统操作请求如文件的读写和块的创建、复制和删除等。 DataNodedn DataNode是HDFS的工作节点Slave负责实际存储文件数据和执行文件系统操作的任务。每个DataNode负责管理一定数量的数据块并定期向NameNode报告数据块的存储信息。DataNode还处理来自客户端和其他DataNode的读取和写入请求以及数据块的复制和恢复等。 客户端Client 客户端是使用HDFS的应用程序。它们通过与Namenode和DataNode进行通信来读取和写入文件。客户端向NameNode请求文件的元数据信息根据元数据信息确定所需数据块的位置并从DataNode获取数据。客户端还负责处理文件系统的操作如创建、删除、重命名和移动文件等。 1.4 HDFS文件块大小 HDFS中的文件在物理上是分成一个个数据块Block存储的块的大小可以通过配置参数dfs.blocksize来规定文件块默认大小是128M。 HDFS文件块的大小选择是根据以下考虑因素 吞吐量较大的文件块大小在处理大文件时可以提供更高的吞吐量。这是因为较大的文件块减少了磁盘寻道和网络传输的开销使得数据读取和写入能够更加高效。 空间利用较大的文件块可以减少存储元数据的开销。在HDFS中每个文件块都有一条元数据记录较小的文件块可能会导致元数据记录数量增加增加了存储的开销。 并行性较大的文件块可以提高数据的并行处理能力。在HDFS中数据块是独立存储和处理的较大的文件块能够在不同的计算节点上并行处理从而减少整个作业的执行时间。 较大的文件块适合存储大型文件和批量处理任务但对于小型文件和实时数据处理较小的文件块可能更加适合。 Q:为什么HDFS文件块的大小不能太大也不能设置太小呢 A 文件块设置太小会增加寻址的时间设置太大会导致数据处理非常慢。 HDFS文件块的大小设置取决于磁盘的传输速率 二、HDFS的Shell操作开发重点 2.1 基本语法 hadoop fs 具体命令 或者 hdfs dfs 具体命令 2.2 命令大全 [amohadoop102 hadoop-3.2.4]$ bin/hadoop fs Usage: hadoop fs [generic options][-appendToFile localsrc ... dst][-cat [-ignoreCrc] src ...][-checksum src ...][-chgrp [-R] GROUP PATH...][-chmod [-R] MODE[,MODE]... | OCTALMODE PATH...][-chown [-R] [OWNER][:[GROUP]] PATH...][-copyFromLocal [-f] [-p] [-l] [-d] [-t thread count] [-q thread pool queue size] localsrc ... dst][-copyToLocal [-f] [-p] [-crc] [-ignoreCrc] [-t thread count] [-q thread pool queue size] src ... localdst][-count [-q] [-h] [-v] [-t [storage type]] [-u] [-x] [-e] path ...][-cp [-f] [-p | -p[topax]] [-d] [-t thread count] [-q thread pool queue size] src ... dst][-createSnapshot snapshotDir [snapshotName]][-deleteSnapshot snapshotDir snapshotName][-df [-h] [path ...]][-du [-s] [-h] [-v] [-x] path ...][-expunge [-immediate]][-find path ... expression ...][-get [-f] [-p] [-crc] [-ignoreCrc] [-t thread count] [-q thread pool queue size] src ... localdst][-getfacl [-R] path][-getfattr [-R] {-n name | -d} [-e en] path][-getmerge [-nl] [-skip-empty-file] src localdst][-head file][-help [cmd ...]][-ls [-C] [-d] [-h] [-q] [-R] [-t] [-S] [-r] [-u] [-e] [path ...]][-mkdir [-p] path ...][-moveFromLocal [-f] [-p] [-l] [-d] localsrc ... dst][-moveToLocal src localdst][-mv src ... dst][-put [-f] [-p] [-l] [-d] [-t thread count] [-q thread pool queue size] localsrc ... dst][-renameSnapshot snapshotDir oldName newName][-rm [-f] [-r|-R] [-skipTrash] [-safely] src ...][-rmdir [--ignore-fail-on-non-empty] dir ...][-setfacl [-R] [{-b|-k} {-m|-x acl_spec} path]|[--set acl_spec path]][-setfattr {-n name [-v value] | -x name} path][-setrep [-R] [-w] rep path ...][-stat [format] path ...][-tail [-f] [-s sleep interval] file][-test -[defswrz] path][-text [-ignoreCrc] src ...][-touch [-a] [-m] [-t TIMESTAMP (yyyyMMdd:HHmmss) ] [-c] path ...][-touchz path ...][-truncate [-w] length path ...][-usage [cmd ...]]Generic options supported are: -conf configuration file specify an application configuration file -D propertyvalue define a value for a given property -fs file:///|hdfs://namenode:port specify default filesystem URL to use, overrides fs.defaultFS property from configurations. -jt local|resourcemanager:port specify a ResourceManager -files file1,... specify a comma-separated list of files to be copied to the map reduce cluster -libjars jar1,... specify a comma-separated list of jar files to be included in the classpath -archives archive1,... specify a comma-separated list of archives to be unarchived on the compute machinesThe general command line syntax is: command [genericOptions] [commandOptions] 2.3 常用命令实操 创建一个文件夹用来操作命令 [amohadoop102 hadoop-3.2.4]$ hadoop fs -mkdir /amoxilinhelp输出这个命令参数 [amohadoop102 hadoop-3.2.4]$ hadoop fs -help rm2.3.1 上传 -moveFromLocal从本地剪切粘贴到HDFS # 创建一个测试文件 test.txt并输入一些内容 [amohadoop102 hadoop-3.2.4]$ vim test.txt# 使用 moveFromLocal 命令将test.txt文件移动到 HDFS [amohadoop102 hadoop-3.2.4]$ hadoop fs -moveFromLocal ./test.txt /amoxilin-copyFromLocal从本地文件系统中拷贝文件到HDFS路径去 [amohadoop102 hadoop-3.2.4]$ vim test1.txt [amohadoop102 hadoop-3.2.4]$ hadoop fs -copyFromLocal test1.txt /amoxilin-put等同于copyFromLocal生产环境更习惯用put [amohadoop102 hadoop-3.2.4]$ hadoop fs -put test1.txt /amoxilin-appendToFile追加一个文件到已经存在的文件末尾 # 创建一个文件test2.txt 并输入内容 123 [amohadoop102 hadoop-3.2.4]$ vim test2.txt# 将文件 test2.txt 追加到test.txt文件末尾 [amohadoop102 hadoop-3.2.4]$ hadoop fs -appendToFile test2.txt /amoxilin/test.txt2.3.2 下载 -copyToLocal 从HDFS拷贝到本地 # 将 HDFS 中的test.txt文件copy下来 [amohadoop102 hadoop-3.2.4]$ hadoop fs -copyToLocal /amoxilin/test.txt ./ [amohadoop102 hadoop-3.2.4]$ ls # 查看文件是否拷贝成功 文件夹中有 test.txt拷贝成功 bin etc lib LICENSE.txt NOTICE.txt sbin test1.txt test.txt wcoutput data include libexec logs README.txt share test2.txt wcinput [amohadoop102 hadoop-3.2.4]$ -get 等同于copyToLocal生产环境更习惯用get # 将 HDFS 中的test.txt文件copy下来并起一个其他的名字比如123.txt [amohadoop102 hadoop-3.2.4]$ hadoop fs -get /amoxilin/test.txt ./123.txt [amohadoop102 hadoop-3.2.4]$ ls 123.txt etc libexec NOTICE.txt share test.txt bin include LICENSE.txt README.txt test1.txt wcinput data lib logs sbin test2.txt wcoutput [amohadoop102 hadoop-3.2.4]$ 2.3.3 HDFS直接操作 -ls: 显示目录信息 # 查看 HDFS 里amoxilin文件夹的目录结构 [amohadoop102 hadoop-3.2.4]$ hadoop fs -ls /amoxilin Found 2 items -rw-r--r-- 3 amo supergroup 9 2024-03-07 23:33 /amoxilin/test.txt -rw-r--r-- 3 amo supergroup 49 2024-03-07 23:29 /amoxilin/test1.txt-cat 显示文件内容 # 查看某个文件的详细信息 [amohadoop102 hadoop-3.2.4]$ hadoop fs -cat /amoxilin/test.txt test 123-chgrp、-chmod、-chown Linux文件系统中的用法一样修改文件所属权限 # 修改文件的权限 [amohadoop102 hadoop-3.2.4]$ hadoop fs -chmod 666 /amoxilin/test.txt [amohadoop102 hadoop-3.2.4]$ hadoop fs -ls /amoxilin Found 2 items -rw-rw-rw- 3 amo supergroup 9 2024-03-07 23:33 /amoxilin/test.txt -rw-r--r-- 3 amo supergroup 49 2024-03-07 23:29 /amoxilin/test1.txt # 修改文件的group [amohadoop102 hadoop-3.2.4]$ hadoop fs -chown amo:amo/amoxilin/test.txt [amohadoop102 hadoop-3.2.4]$ hadoop fs -ls /amoxilin Found 2 items -rw-rw-rw- 3 amo amo 9 2024-03-07 23:33 /amoxilin/test.txt -rw-r--r-- 3 amo supergroup 49 2024-03-07 23:29 /amoxilin/test1.txt -mkdir 创建路径 # 创建文件夹 [amohadoop102 hadoop-3.2.4]$ hadoop fs -mkdir /csdn-cp 从HDFS的一个路径拷贝到HDFS的另一个路径 # 复制文件 [amohadoop102 hadoop-3.2.4]$ hadoop fs -cp /amoxilin/test1.txt /csdn-mv 在HDFS目录中移动文件 # 移动文件 [amohadoop102 hadoop-3.2.4]$ hadoop fs -mv /amoxilin/test.txt /csdn-tail 显示一个文件的末尾1kb的数据 # 查看文件末尾内容 [amohadoop102 hadoop-3.2.4]$ hadoop fs -tail /amoxilin/test1.txt 欲买桂花同载酒终不似少年游 [amohadoop102 hadoop-3.2.4]$ -rm 删除文件或文件夹 # 删除 [amohadoop102 hadoop-3.2.4]$ hadoop fs -rm /amoxilin/test1.txt Deleted /amoxilin/test1.txt-rm -r 递归删除目录及目录里面内容 # 递归删除 [amohadoop102 hadoop-3.2.4]$ hadoop fs -rm -r /amoxilin Deleted /amoxilin-u 统计文件夹的大小信息 # 统计文件夹的大小 [amohadoop102 hadoop-3.2.4]$ hadoop fs -du -s -h /csdn 58 174 /csdn # 58 是文件大小 文件有三个副本就是58*3174 # 统计文件夹内各文件的大小 [amohadoop102 hadoop-3.2.4]$ hadoop fs -du -h /csdn 9 27 /csdn/test.txt 49 147 /csdn/test1.txt-setrep 设置HDFS中文件的副本数量 # 设置hdfs副本数量 [amohadoop102 hadoop-3.2.4]$ hadoop fs -setrep 5 /csdn/test1.txt Replication 5 set: /csdn/test1.txt这里设置的副本数只是记录在NameNode的元数据中是否真的会有这么多副本还得看DataNode的数量。因为目前只有3台设备最多也就3个副本只有节点数的增加到5台时副本数才能达到5。 三、HDFS的API操作 3.1 配置Windows 解压Hadoop安装包到Windows系统 D:\hadoop-3.2.4设置$HADOOP_HOME环境变量指向D:\hadoop-3.2.4配置Path环境变量 %HADOOP_HOME%\bin下载 hadoop.dll 下载地址winutils.exe 下载地址 将 hadoop.dll 和 winutils.exe 放入$HADOOP_HOME/bin 文件夹中 3.2 HDFS的API案例实操 在IDEA中创建一个Maven工程并导入相应的依赖坐标以及日志 dependenciesdependencygroupIdorg.apache.hadoop/groupIdartifactIdhadoop-client/artifactIdversion3.2.4/version/dependencydependencygroupIdjunit/groupIdartifactIdjunit/artifactIdversion4.12/version/dependencydependencygroupIdorg.slf4j/groupIdartifactIdslf4j-log4j12/artifactIdversion1.7.30/version/dependency /dependencies创建HdfsClient类 public class HdfsClient {Testpublic void test() throws IOException, URISyntaxException, InterruptedException {// 1 获取一个客户端实例// 参数1hdfs文件系统地址// 参数2配置文件// 参数3用户FileSystem fs FileSystem.get(new URI(hdfs://hadoop102:8020), new Configuration(), amo);// 2 创建目录fs.mkdirs(new Path(/amxl));// 3 关闭资源fs.close();} }执行程序 3.2.1 HDFS文件上传 编写源代码 // 文件上传 Test public void testCopyFromLocal() throws URISyntaxException, IOException, InterruptedException {// 1 获取一个客户端实例// 参数1hdfs文件系统路径// 参数2配置信息// 参数3用户名FileSystem fs FileSystem.get(new URI(hdfs://hadoop102:8020), new Configuration(), amo);// 2 使用客户端对象操作HDFS// copyFromLocalFile(是否删除源数据是否覆盖目标数据源数据路径目标数据路径)fs.copyFromLocalFile(false, true, new Path(D:\\note.txt),new Path(/amxl));// 3 关闭资源fs.close(); }文件默认的副本为3 将hdfs-site.xml拷贝到项目的resources资源目录下重新上传文件 ?xml version1.0 encodingUTF-8? ?xml-stylesheet typetext/xsl hrefconfiguration.xsl?configurationpropertynamedfs.replication/namevalue1/value/property /configuration在resources目录下自定义配置文件并设置文件副本数为1发现此处配置文件参数的优先级是高于默认配置的文件的 代码中修改配置 Test public void testCopyFromLocal() throws URISyntaxException, IOException, InterruptedException {Configuration configuration new Configuration();// 设置文件副本数为 2configuration.set(dfs.replication,2);FileSystem fs FileSystem.get(new URI(hdfs://hadoop102:8020), configuration, amo);fs.copyFromLocalFile(false, true, new Path(D:\\note.txt),new Path(/amxl));fs.close(); }重新上传文件发现文件的副本数为2 小结 参数优先级排序客户端代码中设置的值 resources下的用户自定义配置文件 然后是服务器的自定义配置 服务器的默认配置 3.2.2 HDFS文件下载 // 文件下载 Test public void testCopyToLocal() throws URISyntaxException, IOException, InterruptedException {// 1 获取配置信息以及加载配置 并获取一个客户端实例FileSystem fs FileSystem.get(new URI(hdfs://hadoop102:8020), new Configuration(), amo);// 2 使用客户端对象操作 HDFS 将 note.txt文件下载到本地 D 盘// copyToLocalFile(是否删除源文件下载的文件路径文件下载的目标路径是否开启文件校验)fs.copyToLocalFile(false,new Path(/amxl/note.txt),new Path(D:\\),true);// 3 关闭资源fs.close(); }3.2.3 HDFS文件更名和移动 // 文件移动和重命名 Test public void testRename() throws IOException, URISyntaxException, InterruptedException {// 1 获取配置信息以及加载配置 并获取一个客户端实例FileSystem fs FileSystem.get(new URI(hdfs://hadoop102:8020), new Configuration(), amo);// 2 文件重命名// rename(源文件名目标文件名)fs.rename(new Path(/amxl/note.txt), new Path(/amxl/note1.txt));// 文件移动// rename(源文件路径目标文件路径)fs.rename(new Path(/csdn/test1.txt), new Path(/amxl/test.txt));// 3 关闭资源fs.close(); }移动前 移动后 3.2.4 HDFS删除文件和目录 // 删除文件和文件夹 Test public void testDelete() throws IOException, URISyntaxException, InterruptedException {// 1 获取配置信息以及加载配置 并获取一个客户端实例FileSystem fs FileSystem.get(new URI(hdfs://hadoop102:8020), new Configuration(), amo);// 2 文件删除// delete(路径)// delete(路径是否递归)fs.delete(new Path(/amxl/note1.txt), false);fs.delete(new Path(/csdn), true);// 3 关闭资源fs.close(); }删除前 删除后 3.2.5 HDFS文件详情查看 查看文件名称、权限、长度、块信息 // 查看文件详细信息 Test public void testGetFileStatus() throws IOException, URISyntaxException, InterruptedException {// 1 获取配置信息以及加载配置 并获取一个客户端实例FileSystem fs FileSystem.get(new URI(hdfs://hadoop102:8020), new Configuration(), amo);// 2 文件详细信息// listStatus(路径)// listStatus(路径是否递归)RemoteIteratorLocatedFileStatus listedFiles fs.listFiles(new Path(/amxl), true);while (listedFiles.hasNext()) {LocatedFileStatus next listedFiles.next();System.out.println(next.getPath());System.out.println(next.getPermission());System.out.println(next.getOwner());System.out.println(next.getGroup());System.out.println(next.getLen());System.out.println(next.getModificationTime());System.out.println(next.getReplication());System.out.println(next.getBlockSize());// 获取块信息BlockLocation[] blockLocations next.getBlockLocations();System.out.println(Arrays.toString(blockLocations));}// 3 关闭资源fs.close(); }// -----------------------------------------------------------------------------------------// 输出 hdfs://hadoop102:8020/amxl/test.txt rw-r--r-- amo supergroup 49 1709910523258 5 134217728 [0,49,hadoop104,hadoop103,hadoop102]3.2.6 HDFS文件和文件夹判断 // 判断文件夹和文件 Test public void testListFiles() throws IOException, URISyntaxException, InterruptedException {// 1 获取配置信息以及加载配置 并获取一个客户端实例FileSystem fs FileSystem.get(new URI(hdfs://hadoop102:8020), new Configuration(), guo);// 2 判断文件夹和文件// listStatus(路径)FileStatus[] fileStatuses fs.listStatus(new Path(/));for (FileStatus fileStatus : fileStatuses) {// 判断是否是文件if(fileStatus.isFile()) {System.out.println(文件 fileStatus.getPath().getName());}else {System.out.println(文件夹 fileStatus.getPath().getName());}} // FileStatus[] fileStatuses fs.listStatus(new Path(/)); // // for (FileStatus fileStatus : fileStatuses) { // // 判断是否是文件夹 // if (fileStatus.isFile()) { // System.out.println(文件: fileStatus.getPath().getName()); // } // if (fileStatus.isDirectory()) { // System.out.println(文件夹: fileStatus.getPath().getName()); // } // }// 3 关闭资源fs.close(); }写在最后 总的来说HDFS架构的优势和基本操作使其成为构建可靠的大数据基础的理想选择。它的高可靠性、高扩展性和高效的数据访问方式为处理大规模数据提供了强大的支持并通过Shell操作和API操作方便用户管理和操作存储在HDFS中的数据。
http://www.pierceye.com/news/327780/

相关文章:

  • 做网站的过程做网站公司广州
  • 女人动漫做受网站wordpress如何作页面
  • 做网站导航栏素材图建筑设计网站制作
  • 淘宝的网站建设方案国家为何要求所有网站均须备案
  • 企业网站模板下载哪家公司强温州建设公司网站
  • 网站编辑能在家做wordpress 做的商城
  • 空间信息网站开发公司工程项目质量安全管理体系
  • 网站流量被黑包装回收网站建设
  • 网站拒绝被百度收录成品网站1688特色
  • 深圳住房和建设局网站官网打不开WordPress 斗鱼
  • 纯文本网站连接西宁圆井模板我自己做的网站
  • 职业院校专题建设网站wordpress文章版权投诉
  • 网站改版好吗如何解决旅游网站建设问题
  • 爱站网使用的是什么网站模仿网站页面违法吗
  • 做民宿的网站wordpress 短信平台
  • 婚恋网站上认识人 带你做原油交易怎么用手机创造网站
  • 网站建设投标书服务方案范本天津北京网站建设公司
  • 网站建设好评公司微企点建站怎么样
  • 某网站开发项目成本估计推广普通话作文500字
  • 制作网站需要哪些工作网站建设佰金手指科杰十三
  • 外贸哪家做网站wordpress excel搜索
  • 苏州做网站推广的英文搜索网站
  • 政务微网站建设方案深圳市易捷网络科技有限公司
  • 云南网站建设哪家好长沙网站建设营销
  • 四川省建设厅注册中心网站网站管理内容
  • 百度提交网站wordpress广告设置
  • 余姚市城乡建设局网站石家庄上门足疗
  • 深圳工程造价建设信息网站php网站建设题目
  • 龙岗网站制作织梦整合wordpress
  • 代做效果图网站哪家好汉中市建设局网站