linux及hadoop修改權限

inux下修改文件權限:

在shell環境裏輸入:ls -l 或者 ls -lh

drwxr-xr-x 2 nsf users 1024 12-10 17:37 下載文件備份
對應:
文件屬性 連接數 文件擁有者 所屬羣組 文件大小 文件修改時間 文件名

 

例如:
  d   rwx   r-x  r-x 
第一個字符指定了文件類型。在通常意義上,一個目錄也是一個文件。如果第一個字符是橫線,表示是一個非目錄的文件。如果是d,表示是一個目錄。
第二段是文件擁有者的屬性
第三段是文件所屬羣組的屬性
第四段是對於其它用戶的屬性


這裏r是可讀,w可寫,x 可執行,其中文件屬性分爲四段,---- --- --- 10個位置

r: 對應數值4
w: 對應數值2
x:對應數值1
-:對應數值0

將rwx看成二進制數,如果有則有1表示,沒有則有0表示,那麼rwx r-x r- -則可以表示成爲:

111 101 100

再將其每三位轉換成爲一個十進制數,就是754。

修改權限:


  確定了一個文件的訪問權限後,用戶可以利用Linux系統提供的chmod命令來重新設定不同的訪問權限。也可以利用chown命令來更改某個文件或目錄的所有者。利用chgrp命令來更改某個文件或目錄的用戶組。


chmod 命令
  功能:chmod命令是非常重要的,用於改變文件或目錄的訪問權限.用戶用它控制文件或目錄的訪問權限.
  語法:該命令有兩種用法。一種是包含字母和操作符表達式的文字設定法;另一種是包含數字的數字設定法。
  1. 文字設定法
  chmod [who] [+ | - | =] [mode] 文件名?
  參數:
  操作對象who可是下述字母中的任一個或者它們的組合:
  u 表示“用戶(user)”,即文件或目錄的所有者。
  g 表示“同組(group)用戶”,即與文件屬主有相同組ID的所有用戶。
  o 表示“其他(others)用戶”。
  a 表示“所有(all)用戶”。它是系統默認值。
  操作符號可以是:
  + 添加某個權限。
  - 取消某個權限。
  = 賦予給定權限並取消其他所有權限(如果有的話)。

  設置mode所表示的權限可用下述字母的任意組合:
  r 可讀。
  w 可寫。
  x 可執行。
  X 只有目標文件對某些用戶是可執行的或該目標文件是目錄時才追加x 屬性。
  s 在文件執行時把進程的屬主或組ID置爲該文件的文件屬主。方式“u+s”設置文件的用         戶ID位,“g+s”設置組ID位。
  t 保存程序的文本到交換設備上。
  u 與文件屬主擁有一樣的權限。
  g 與和文件屬主同組的用戶擁有一樣的權限。
  o 與其他用戶擁有一樣的權限。
  文件名:以空格分開的要改變權限的文件列表,支持通配符。
  在一個命令行中可給出多個權限方式,其間用逗號隔開。例如:chmod g+r,o+r example
  使同組和其他用戶對文件example 有讀權限。


chgrp命令
  功能:改變文件或目錄所屬的組。
  語法:chgrp [選項] group filename?
  該命令改變指定指定文件所屬的用戶組。其中group可以是用戶組ID,也可以是/etc/group文件中用戶組的組名。文件名是以空格分開的要改變屬組的文件列表,支持通配符。如果用戶不是該文件的屬主或超級用戶,則不能改變該文件的組。
  參數:
  - R 遞歸式地改變指定目錄及其下的所有子目錄和文件的屬組。
  例1:$ chgrp - R book /opt/local /book
  改變/opt/local /book/及其子目錄下的所有文件的屬組爲book。


chown 命令
  功能:更改某個文件或目錄的屬主和屬組。

  這個命令也很常用。例如root用戶把自己的一個文件拷貝給用戶xu,爲了讓用戶xu能夠存取這個文件,root用戶應該把這個文件的屬主設爲xu,否則,用戶xu無法存取這個文件。
  語法:chown [選項] 用戶或組 文件
  說明:chown將指定文件的擁有者改爲指定的用戶或組。用戶可以是用戶名或用戶ID。組可以是組名或組ID。文件是以空格分開的要改變權限的文件列表,支持通配符。
  參數:
  - R 遞歸式地改變指定目錄及其下的所有子目錄和文件的擁有者。
  - v 顯示chown命令所做的工作。
  例1:把文件shiyan.c的所有者改爲wang。
  $ chown wang shiyan.c
  例2:把目錄/his及其下的所有文件和子目錄的屬主改成wang,屬組改成users。
  $ chown - R wang.users /his

 

 

sudo addgroup hadoop#添加一個hadoop組

sudo usermod -a -G hadoop larry#將當前用戶加入到hadoop組

sudo gedit etc/sudoers#將hadoop組加入到sudoer

在root ALL=(ALL) ALL後 hadoop ALL=(ALL) ALL

 

修改hadoop目錄的權限 sudo chown -R larry:hadoop /home/larry/hadoop<所有者:組 文件>

sudo chmod -R 755 /home/larry/hadoop

 

修改hdfs的權限 sudo bin/hadoop dfs -chmod -R 755 / sudo bin/hadoop dfs -ls /

 

修改hdfs文件的所有者

sudo bin/hadoop fs -chown -R larry /

sudo bin/hadoop dfsadmin -safemode leave #解除hadoop的安全模式

hadoop fs -copyFromLocal <localsrc> URI#拷貝本地文件到hdfs

hadoop fs -cat file:///file3 /user/hadoop/file4#將路徑指定文件的內容輸出到stdout

hadoop fs -chgrp [-R] GROUP URI#改變文件的所屬組

hadoop fs -chmod [-R] 755 URI#改變用戶訪問權限

hadoop fs -chown [-R] [OWNER][:[GROUP]] URI [URI ]#修改文件的所有者

hadoop fs -copyToLocal URI localdst#拷貝hdfs文件到本地

hadoop fs -cp URI [URI …] <dest>#拷貝hdfs文件到其它目錄

hadoop fs -du URI [URI …]#顯示目錄中所有文件的大小

hadoop fs -getmerge <src> <localdst> [addnl]#合併文件到本地目錄

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章