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

做视频网站怎么赚钱/广州网站优化多少钱

做视频网站怎么赚钱,广州网站优化多少钱,动态网站开发案例实训总结,信用中国 网站有那个部门支持建设3 HDFS的客户端操作 3.1 客户端环境准备 步骤1:安装hadoop3.1.3到Windows系统 解压编译好的hadoop包,解压到无空格非中文路径。 步骤2:配置环境变量 HADOOP_HOME/windows下hadoop的家目录 PATH%HADOOP_HOME%/bin步骤3:查看wind…

3 HDFS的客户端操作

3.1 客户端环境准备

步骤1:安装hadoop3.1.3到Windows系统

解压编译好的hadoop包,解压到无空格非中文路径。

步骤2:配置环境变量

HADOOP_HOME=/windows下hadoop的家目录
PATH=%HADOOP_HOME%/bin

步骤3:查看windows下hadoop是否可以使用

打开cmd输入hadoop;然后重启电脑

步骤4:创建一个maven工程,导入依赖

<dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-slf4j-impl</artifactId><version>2.12.0</version></dependency><dependency><groupId>org.apache.hadoop</groupId><artifactId>hadoop-client</artifactId><version>3.1.3</version></dependency>
</dependencies>

步骤5:添加日志依赖

在/src/main/resources目录下创建一个log4j2.xml

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="error" strict="true" name="XMLConfig"><Appenders><!-- 类型名为Console,名称为必须属性 --><Appender type="Console" name="STDOUT"><!-- 布局为PatternLayout的方式,输出样式为[INFO] [2018-01-22 17:34:01][org.test.Console]I'm here --><Layout type="PatternLayout"pattern="[%p] [%d{yyyy-MM-dd HH:mm:ss}][%c{10}]%m%n" /></Appender></Appenders><Loggers><!-- 可加性为false --><Logger name="test" level="info" additivity="false"><AppenderRef ref="STDOUT" /></Logger><!-- root loggerConfig设置 --><Root level="info"><AppenderRef ref="STDOUT" /></Root></Loggers>
</Configuration>

3.2 HDFS的API操作

创建文件夹

    @Testpublic void testMkdir() throws URISyntaxException, IOException, InterruptedException {//创建hdfs文件系统对象FileSystem fileSystem = FileSystem.get(new URI("hdfs://hadoop102:9820"),new Configuration(),"atguigu");//操作hdfs文件系统fileSystem.mkdirs(new Path("/jjj"));//关闭hdfsfileSystem.close();}

创建hdfs文件系统对象,其中URI是hdfs的资源地址,选择9820端口。

configuration是配置文件,默认是集群配置的文件;可以在idea中新建配置文件(如hdfs-site.xml);可以在代码中编辑配置项。

设置文件副本数

设置配置文件中配置项的优先级:

代码 > idea中配置文件 > 集群配置文件

集群默认副本数是3

在/src/main/resources目录下创建一个hdfs-site.xml

<configuration><!-- nn web端访问地址--><property><name>dfs.replication</name><value>2</value></property>
</configuration>

这时创建文件,副本数就是2了。

在代码中修改配置项的hdfs副本数

    @Testpublic void testReplication() throws URISyntaxException, IOException, InterruptedException {Configuration configuration = new Configuration();configuration.set("dfs.replication", "1");FileSystem fileSystem = FileSystem.get(new URI("hdfs://hadoop102:9820"),configuration,"atguigu");fileSystem.create(new Path("/test2.md"));fileSystem.close();}

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LH4g5zp3-1603002915333)(hdfs.assets/image-20201012200806318.png)]

①文件上传

为了简单操作,将创建hdfs对象放到Before中,将关闭hdfs放到After中;将FileSystem作为参数提取出来

    FileSystem fs;@Beforepublic void createHDFS() throws URISyntaxException, IOException, InterruptedException {fs = FileSystem.get(new URI("hdfs://hadoop102:9820"), new Configuration(), "atguigu");}@Afterpublic void close() throws IOException {fs.close();}
    @Testpublic void testCopyFromLocalFile() throws IOException {fs.copyFromLocalFile(new Path("d:/file1.txt"), new Path("/File1.md"));}

②文件下载

​ // 2 执行下载操作

​ // boolean delSrc 指是否将原文件删除

​ // Path src 指要下载的文件路径

​ // Path dst 指将文件下载到的路径

​ // boolean useRawLocalFileSystem 是否开启文件校验

​ fs.copyToLocalFile(false, new Path("/banzhang.txt"), new Path(“e:/banhua.txt”), true);

    //默认不删除原文件,默认不开启文件校验(下载到本地还有一个校验文件)@Testpublic void testCopyToLocalFile() throws IOException {fs.copyToLocalFile(new Path("/README.txt"), new Path("d:/"));}//这样就没有删除原文件,也不会下载校验文件到本地。@Testpublic void testCopyToLocalFile() throws IOException {fs.copyToLocalFile(false, new Path("/README.txt"), new Path("d:/"), true);}

③文件更名和移动

移动的同时可以改名

    @Testpublic void testMoveFile() throws IOException {fs.rename(new Path("/File1.md"), new Path("/dir/file2.md"));}

④HDFS文件详情

RemoteIterator Iterator = fs.listFiles(Path path, boolean b);

boolean是否递归显示文件信息。返回一个迭代器

    @Testpublic void testFileDetail() throws IOException {//返回一个文件列表的迭代器RemoteIterator<LocatedFileStatus> locatedFileStatusRemoteIterator = fs.listFiles(new Path("/"), false);while (locatedFileStatusRemoteIterator.hasNext()){System.out.println("===================================");System.out.println(locatedFileStatusRemoteIterator.next());}}
/*输出结果
HdfsLocatedFileStatus{path=hdfs://hadoop102:9820/README.txt; isDirectory=false; length=1366; replication=3; blocksize=134217728; modification_time=1602469037365; access_time=1602505180131; owner=atguigu; group=supergroup; permission=rw-rw-rw-; isSymlink=false; hasAcl=false; isEncrypted=false; isErasureCoded=false}
*/

查看locatedFileStatusRemoteIterator.next()内的部分信息。

    @Testpublic void testFileDetail() throws IOException {RemoteIterator<LocatedFileStatus> locatedFileStatusRemoteIterator = fs.listFiles(new Path("/"), false);while (locatedFileStatusRemoteIterator.hasNext()){System.out.println("===================================");LocatedFileStatus fileStatus = locatedFileStatusRemoteIterator.next();//获取文件名System.out.println(fileStatus.getPath().getName());//获取文件长度System.out.println(fileStatus.getLen());//获取文件权限System.out.println(fileStatus.getPermission());//获取文件分组System.out.println(fileStatus.getGroup());//获取文件存储的块信息BlockLocation[] blockLocations = fileStatus.getBlockLocations();for (BlockLocation blockLocation : blockLocations) {String[] hosts = blockLocation.getHosts();System.out.println(Arrays.toString(hosts));}}}

⑤HDFS文件和文件夹判断

    @Testpublic void testFileDetail1() throws IOException {FileStatus[] fileStatuses = fs.listStatus(new Path("/"));for (FileStatus fileStatus : fileStatuses) {System.out.println("============================");//获取文件名System.out.println(fileStatus.getPath().getName());//获取文件长度System.out.println(fileStatus.getLen());//获取文件权限System.out.println(fileStatus.getPermission());//获取文件分组System.out.println(fileStatus.getGroup());//获取文件存储的块的大小(只能获得大小)System.out.println(fileStatus.getBlockSize());}}

HdfsLocatedFileStatus{path=hdfs://hadoop102:9820/tmp/hadoop-yarn/staging/history/done_intermediate/atguigu/job_1602462434358_0001.summary; isDirectory=false; length=442; replication=3; blocksize=134217728; modification_time=1602462463740; access_time=1602462463704; owner=atguigu; group=supergroup; permission=rwxrwx—; isSymlink=false; hasAcl=false; isEncrypted=false; isErasureCoded=false}

HdfsLocatedFileStatus{path=hdfs://hadoop102:9820/README.txt; isDirectory=false; length=1366; replication=3; blocksize=134217728; modification_time=1602469037365; access_time=1602469037082; owner=atguigu; group=supergroup; permission=rw-r–r--; isSymlink=false; hasAcl=false; isEncrypted=false; isErasureCoded=false}

父类:FileStatus

子类:RemoteIterator,有块信息的一些api

http://www.lbrq.cn/news/1573219.html

相关文章:

  • 如何制作动态网页/南宁seo优势
  • 网站开发 脚本怎么写/深圳seo优化排名
  • 网站建设华科技/百度网站制作联系方式
  • wordpress内容里的图片大小/怎么优化关键词
  • 网站建设的几点体会/郑州seo线上推广系统
  • 政府网站建设文案/百度top排行榜
  • 网站开发域名注册功能/个人接app推广单去哪里接
  • 网站推广软件破解版/市场营销培训课程
  • 合肥公司建设网站/网络营销策划书总结
  • 徐州集团网站建设方案/网络营销的特点和优势
  • ppt做的最好的网站有哪些/合肥网站制作
  • 电子商务网站建设主要内容/百度注册网站
  • 建什么网站可以赚钱/河南网站建站推广
  • 网站怎么做百度百科/网站友链查询接口
  • 广州网站建设找新际/企业网站推广方法实验报告
  • 网站添加qq在线客服/网站搜索引擎优化的基本内容
  • 给视频做特效的网站/网站运营及推广方案
  • 做的比较好的法律实务培训网站/百度推广销售员好做吗
  • 网站需要多少钱/如何自建网站?
  • 正规网站建设团队是什么/网站seo关键词优化
  • 个人网页设计作品简约/广州排前三的seo公司
  • java 就是做网站的吗/上海网站推广广告
  • 网站换了服务器/网站优化塔山双喜
  • 网站图片加载 优化/品牌营销平台
  • 自己做企业网站/找谁做百度关键词排名
  • 排名优化网站/搜索引擎营销的主要方式有
  • 网站开发原始数据/强力搜索引擎
  • 手机网站 wap/宁波网站快速优化
  • 赣州网上立案网址/上海关键词优化的技巧
  • 北京网站开发公司哪家好/互联网营销师有什么用
  • 技术速递|使用 AI Toolkit 构建基于 gpt-oss-20b 的应用程序
  • antdv Modal的简单使用
  • Mac安装ant
  • [系统架构]系统架构基础知识(一)
  • linux 开机进入initramfs无法开机
  • vivo Pulsar 万亿级消息处理实践(2)-从0到1建设 Pulsar 指标监控链路