Big Data(六)用户权限实操&HDFS-API实操
创建用户实操
1.创建用户god
- useradd god
- passwd god
2.设置ssh免密
- ssh-copy-id -i id_dsa node02
3.修改hdfs-site.xml中的ssh路径,并且分发
4.god
- start-dfs.sh
用户权限实操
- node01:
- su god
- hdfs dfs -mkdir /temp
- hdfs dfs -chown god:ooxx /temp
- hdfs dfs -chmod /temp
- node04:
- root:
- useradd good
- groupadd ooxx
- usermod -a -G ooxx good
- id good
- su good
- hdfs dfs -mkdir /temp/abc <失败
- hdfs groups
- good: <因为hdfs已经启动了,不知道你操作系统又偷偷摸摸创建了用户和组
- *node01:
- root:
- useradd good
- groupadd ooxx
- usermod -a -G ooxx good
- su god
- hdfs dfsadmin -refreshUserToGroupsMappings
- node04:
- good:
- hdfs groups
- good : good ooxx
HDFS-API实操
1.添加环境变量
- HADOOP_USER_NAME god
2.启动IDEA,创建一个Maven Project
Maven网址
- https://mvnrepository.com/
hdfs的pom文件:
- hadoop是由common,hdfs,yarn,mapreduce组成,maven中导包2.6.5版本
实际测试:
- package com.littlepage.hadoop.hdfs;
- import org.apache.hadoop.conf.Configuration;
- import org.apache.hadoop.fs.*;
- import org.apache.hadoop.io.IOUtils;
- import org.junit.After;
- import org.junit.Before;
- import org.junit.Test;
- import java.io.*;
- import java.net.URI;
- public class TestHDFS {
- public Configuration conf=null;
- public FileSystem fs=null;
- @Before
- public void conn(){
- try {
- conf=new Configuration(true);//true,为加载配置文件
- //fs=FileSystem.get(conf);
- //fs返回是参考了fs.defaltFS标签中的值,去环境变量取一个HADOOP_USER_NAME取一个值
- fs=FileSystem.get(URI.create("hdfs://mycluster/"),conf,"root");
- } catch (IOException e) {
- e.printStackTrace();
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- @Test
- public void mkdir() throws IOException {
- Path dir=new Path("/cccc");
- fs.mkdirs(dir);
- System.out.println("ok");
- }
- @Test
- public void update() throws IOException {
- InputStream is= new BufferedInputStream(new FileInputStream(new File("data/hello.txt")));
- Path path=new Path("/xxx/out.txt");
- FSDataOutputStream outFile = fs.create(path);
- IOUtils.copyBytes(is,outFile,conf,true);
- }
- @Test
- public void block() throws IOException {
- //获得区块
- Path file=new Path("/data.txt");
- FileStatus fsta=fs.getFileStatus(file);
- ; BlockLocation[] bl=fs.getFileBlockLocations(fsta,,fsta.getLen());
- for (BlockLocation b:bl) {
- System.out.println(b);
- }
- //这里可以进行计算,计算向数据移动
- FSDataInputStream in=fs.open(file);
- in.seek(bl.length);
- for(int i=;i<;i++){
- System.out.print((char)in.readByte());
- }
- }
- @After
- public void close(){
- try {
- fs.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- }
Big Data(六)用户权限实操&HDFS-API实操的更多相关文章
- CentOS7学习笔记(六) 用户权限管理
用户.用户组与文件的关系 在了解权限管理之前先创建一些用户和用户组便于后续学习,在root用户下操作: # 创建两个用户组 [root@localhost data]# groupadd kaifa ...
- Linux运维六:用户管理及用户权限设置
Linux 系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统.用户的账号一方面可以帮助系统管理员对使用系统的用户进行 ...
- 2_MVC+EF+Autofac(dbfirst)轻型项目框架_用户权限验证
前言 接上面两篇 0_MVC+EF+Autofac(dbfirst)轻型项目框架_基本框架 与 1_MVC+EF+Autofac(dbfirst)轻型项目框架_core层(以登陆为例) .在第一篇中介 ...
- MySQL三层结构、用户权限、索引设计原则
一.守护进程是什么? Linux Daemon(守护进程)是运行在后台的一种特殊进程.它独立于控制终端并且周期性地执行某种任务或等待处理某些发生的事件.它不需要用户输入就能运行而且提供某种服务,不是对 ...
- hive的用户和用户权限
HiverServer2支持远程多客户端的并发和认证,支持通过JDBC.Beeline等连接操作.hive默认的Derby数据库,由于是内嵌的文件数据库,只支持一个用户的操作访问,支持多用户需用mys ...
- HDFS文件系统基操--Java实现
Java实现对HDFS文件系统的基本操作 1.准备好jar包 2.创建一个类 1. 测试连接 @Test //测试是否连接成功 public void test() { //添加配置 ==> c ...
- Oracle 表空间和用户权限管理
一. 表空间 Oracle数据库包含逻辑结构和物理结构. 数据库的物理结构指的是构成数据库的一组操作系统文件. 数据库的逻辑结构是指描述数据组织方式的一组逻辑概念以及它们之间的关系. 表空间是数据库逻 ...
- Asp.Net Core 项目实战之权限管理系统(7) 组织机构、角色、用户权限
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
- 简单的Linux的用户权限管理
企业生产环境用户权限集中管理方案案例 建立中要添加如下的项目经验: 在了解公司业务流程后,提出权限整改解决方案,改进公司超级用户Root权限泛滥的问题. 我首先写好方案后,给老大看,取得老大的支持后, ...
随机推荐
- 浏览器端-3WSchool-JavaScript:JavaScript Boolean 对象
ylbtech-浏览器端-3WSchool-JavaScript:JavaScript Boolean 对象 1.返回顶部 1. Boolean 对象 Boolean 对象表示两个值:"tr ...
- JS - neo4j-browser 初始化时运行命令的逻辑分析
背景 最近需要改点 neo4j-browser 的代码做个 demo,分析初始化时运行命令的代码时花了很多时间,记录一下. 目的 找出 dispatch SINGLE_COMMAND_QUEUED a ...
- Android共享元素场景切换动画的实现
安卓5.0系统引入了共享元素,能做出非常炫酷的场景切换效果,这让人非常兴奋同时非常蛋疼,因为低版本没法使用啊,所以今天就跟大家分享一下自己写的一个库,其实只有2个文件而已就可以兼容安卓5.0以下的版本 ...
- 三十二:数据库之SQLAlchemy.query函数可查询的数据和聚合函数
准备工作 from sqlalchemy import create_engine, Column, Integer, String, Floatfrom sqlalchemy.ext.declara ...
- unittest 和 pytest 对比
一.用例编写规则 1.unittest提供了test cases.test suites.test fixtures.test runner相关的类,让测试更加明确.方便.可控.使用unittest编 ...
- Java学习之==>JDBC
一.概述 官方解释: JDBC(Java DataBase Connectivity,java数据库连接)是一种用于执行SQL语句的 Java API,可以为多种关系型数据库提供统一访问,它由一组用 ...
- 2018.04.02 matplotlib 图名,图例,轴标签,轴边界,轴刻度,轴刻度标签
import numpy as np import pandas as pd import matplotlib.pyplot as plt df = pd.DataFrame(np.random.r ...
- HTTP Status 500 ? Internal Server Error
getWriter()和getOutputStream()不能同时调用 HTTP Status 500 ? Internal Server Error Type Exception Report Me ...
- 慕课网_Java Socket应用---通信是这样练成的
第1章 网络基础知识 1-1 网络基础简介 (10:21) 第2章 Java 中网络相关 API 的应用 2-1 Java 中的 InetAddress 的应用 (08:10) import java ...
- [转载]jsp上传文件
JSP 可以与 HTML form 标签一起使用,来允许用户上传文件到服务器.上传的文件可以是文本文件或图像文件或任何文档. 本章节我们使用 Servlet 来处理文件上传,使用到的文件有: uplo ...