chmod用法總結
**用來修改某個目錄或文件的訪問權限。**
```
- 普通文件
d 目錄文件
b 塊特殊文件
C 字符特殊文件
l 符號鏈接
f 命名管道
S 套接字文件
```
ls -l
`第一列: 文件類型(共10個字符) + 權限?? -->` `man``find``搜索``type``可看`
**-** : 普通文件(二進制文件)
**d** : 目錄
**l** : 鏈接文件 --> 軟連接
**c** : 字符設備 -->` `/dev/tty`????`例如 USB接口、貓等一些串行端口設備`
**b** : 塊設備?? -->` `/dev``下查找? 例如光驅,硬盤等屬于塊設備
**.** : SELINUX相關
*****

*****
權限范圍:
**u**?:目錄或者文件的當前的用戶
**g**?:目錄或者文件的當前的群組
**o**?:除了目錄或者文件的當前用戶或群組之外的用戶或者群組
**a**?:所有的用戶及群組
權限代號:
**r**?:讀權限,用數字4表示
**w**?:寫權限,用數字2表示
**x**?:執行權限,用數字1表示
**\-**?:刪除權限,用數字0表示
**s**?:特殊權限
該命令有兩種用法。一種是包含字母和操作符表達式的文字設定法;另一種是包含數字的數字設定法。
1).?文字設定法:
chmod?[who]?[+?|?-?|?=]?[mode]?文件名
2).?數字設定法
我們必須首先了解用數字表示的屬性的含義:0表示沒有權限,1表示可執行權限,2表示可寫權限,4表示可讀權限,然后將其相加。所以數字屬性的格式應為3個從0到7的八進制數,其順序是(u)(g)(o)。
例如,如果想讓某個文件的屬主有“讀/寫”二種權限,需要把4(可讀)+2(可寫)=6(讀/寫)。
數字設定法的一般形式為:
chmod?[mode]?文件名
數字與字符對應關系如下:
**r=4,w=2,x=1**
若要rwx屬性則4+2+1=7
若要rw-屬性則4+2=6;
若要r-x屬性則4+1=7。
4.?使用實例:
實例1:增加文件所有用戶組可執行權限
命令:
**chmod?a+x?log2012.log**
輸出:
\[root@localhost?test\]#ls?-al?log2012.log?
\-rw-r--r--?1?root?root?302108?11-13?06:03?log2012.log
\[root@localhost?test\]#chmod?a+x?log2012.log?
\[root@localhost?test\]#ls?-al?log2012.log?
\-rwxr-xr-x?1?root?root?302108?11-13?06:03?log2012.log
\[root@localhost?test\]#
說明:
即設定文件log2012.log的屬性為:文件屬主(u)?增加執行權限;與文件屬主同組用戶(g)?增加執行權限;其他用戶(o)?增加執行權限。
實例2:同時修改不同用戶權限
命令:
**chmod?ug+w,o-x?log2012.log**
輸出:
\[root@localhost?test\]#ls?-al?log2012.log?
\-rwxr-xr-x?1?root?root?302108?11-13?06:03?log2012.log
\[root@localhost?test\]#chmod?ug+w,o-x?log2012.log?
\[root@localhost?test\]#ls?-al?log2012.log?
\-rwxrwxr--?1?root?root?302108?11-13?06:03?log2012.log
說明:
即設定文件text的屬性為:文件屬主(u)?增加寫權限;與文件屬主同組用戶(g)?增加寫權限;其他用戶(o)?刪除執行權限
實例3:刪除文件權限(a-x,u-x...)
命令:
**chmod?a-x?log2012.log**
輸出:
\[root@localhost?test\]#ls?-al?log2012.log?
\-rwxrwxr--?1?root?root?302108?11-13?06:03?log2012.log
\[root@localhost?test\]#chmod?a-x?log2012.log?
\[root@localhost?test\]#ls?-al?log2012.log?
\-rw-rw-r--?1?root?root?302108?11-13?06:03?log2012.log
說明:
刪除所有用戶的可執行權限
實例4:使用“=”設置權限
命令:
**chmod?u=x?log2012.log**
輸出:
\[root@localhost?test\]#ls?-al?log2012.log?
\-rw-rw-r--?1?root?root?302108?11-13?06:03?log2012.log
\[root@localhost?test\]#chmod?u=x?log2012.log?
\[root@localhost?test\]#ls?-al?log2012.log?
\---xrw-r--?1?root?root?302108?11-13?06:03?log2012.log
說明:
撤銷原來所有的權限,然后使擁有者具有可讀權限
實例5:對一個目錄及其子目錄所有文件添加權限
命令:
**chmod?-R?u+x?test4**
輸出:
\[root@localhost?test\]#cd?test4
\[root@localhost?test4\]#ls?-al
總計?312drwxrwxr-x?2?root?root???4096?11-13?05:50?.
drwxr-xr-x?5?root?root???4096?11-22?06:58?..
\-rw-r--r--?1?root?root?302108?11-12?22:54?log2012.log
\-rw-r--r--?1?root?root?????61?11-12?22:54?log2013.log
\-rw-r--r--?1?root?root??????0?11-12?22:54?log2014.log
\[root@localhost?test4\]#cd?..
\[root@localhost?test\]#chmod?-R?u+x?test4
\[root@localhost?test\]#cd?test4
\[root@localhost?test4\]#ls?-al
總計?312drwxrwxr-x?2?root?root???4096?11-13?05:50?.
drwxr-xr-x?5?root?root???4096?11-22?06:58?..
\-rwxr--r--?1?root?root?302108?11-12?22:54?log2012.log
\-rwxr--r--?1?root?root?????61?11-12?22:54?log2013.log
\-rwxr--r--?1?root?root??????0?11-12?22:54?log2014.log
說明:
遞歸地給test4目錄下所有文件和子目錄的屬主分配權限
其他一些實例:
1).?命令:
**chmod?751?file**
說明:
給file的屬主分配讀、寫、執行(7)的權限,給file的所在組分配讀、執行(5)的權限,給其他用戶分配執行(1)的權限
2).?命令:
**chmod?u=rwx,g=rx,o=x?file**?
說明:
上例的另一種形式
3).?命令
**chmod?=r?file**?
說明:
為所有用戶分配讀權限
3).?命令:
**chmod?444?file**
說明:同上例
4).?命令:
**chmod?a-wx,a+r???file**
說明:
同上例
- 空白目錄
- containerd
- php
- php常用函數
- 點語法
- 依賴注入
- 反射
- 迭代器和yield
- array_walk
- str_replace
- openssl_decrypt
- array_merge
- 閉包
- 深拷貝與淺拷貝
- 面向對象
- 魔術方法
- __invoke
- __isset 和 __unset
- __clone
- 常用知識點
- 訪問權限
- 抽象類
- 多態
- php框架
- tp
- tp3
- tp5
- job
- laravel
- 中間件
- laravel閉包
- symfony
- 小工具
- phpexcel
- xlswrite
- 設計模式
- 事件event
- 里氏替換原則
- 借鑒
- RESTful API
- 環境安裝
- 編譯安裝
- 編譯安裝后擴展補充
- php小記錄
- php-fpm
- 容器(Container)
- composer
- composer踩坑
- mysql
- 基礎知識
- 外鍵
- 索引
- 觸發器
- 定時器
- 分表
- 分區
- 連接查詢
- 事務
- 鎖機制
- 視圖
- 存儲過程
- 查詢
- 字符截取
- 批量修改表名(前綴)
- explain
- when_case
- pdo
- mysql優化
- 主從復制
- 權限分配
- 實用例子
- 查詢用戶
- 常見問題
- 5.7group by問題
- 遠程鏈接慢問題
- 查看進程
- 遠程訪問
- 常用小記
- mysqldump
- 備份還原
- 系統盤遷移數據盤
- 安裝sql
- 安裝MariaDB
- docker
- 安裝docker
- 配置centos開發環境
- docker運行程序
- rabbitmq
- 刪除無用鏡像
- 解決Centos firewalld導致的docker容器內無法訪問外網,無法訪問其他容器(host沒辦法解析)
- docker-compose
- docker-selenium
- ports 配置
- docker-compose-settings
- 安裝
- docker-compose常用配置
- docker常用命令
- build
- docker-hub加速
- docker-run
- Dockerfile
- apt-get update 無法升級
- 阿里打標簽
- 打包流程
- docker-network
- ufw 允許 docker 容器聯網
- 安裝containerd
- linux
- centos7
- 常用語法
- chmod
- chown
- find
- grep
- /etc/passwd
- chattr
- In軟連接
- 文件目錄大小
- xargs
- 管道用法
- top
- free
- 端口占用
- 壓縮解壓
- tar
- gzip
- zip
- 2>&1
- 環境變量
- 服務管理
- systemctl
- sed
- shell腳本
- time
- journal
- history
- linux-set
- linux-curl
- cp
- umask
- mkdir
- http狀態碼
- awk
- lsof
- crontab
- supervisor
- 常用命令匯總
- 用戶權限
- 普通用戶添加sudo權限
- sudo su
- 添加用戶
- 查看用戶信息
- 修改用戶信息
- 特殊權限
- 系統命令
- 常用小技巧
- vim小技巧
- 防火墻
- 常用規則
- iptables
- 磁盤清理
- 分區掛載
- linux-sh
- tmux
- 多命令執行
- 常用工具
- telnet
- ip轉發
- nohup
- watch
- dig
- 查看磁盤IO
- ssh
- 修改ssh端口
- ssh免密登錄
- 配置文件
- 公鑰分發
- xsync
- 國內鏡像站
- github加速
- 測網速
- 網卡
- 清理日志備份
- 配置sftp
- shell
- rpm
- 安全
- 安裝openssl
- 安裝openssh
- 禁用selinux和防火墻
- lanp環境安裝
- versionTool
- git
- git基本用法
- Gogs搭建
- git鉤子
- git的習慣配置
- phpStorm設置git bash
- git bash 設置代理
- gitignore 不起作用的解決辦法
- gitea搭建
- 同步主干到fork
- git修改地址
- svn
- svn基本操作
- svn 鉤子應用
- svn多版本操作
- Go語言
- Go語言基礎
- 安裝環境
- linux安裝
- window安裝
- 工具使用教程
- linux終端分屏Screen
- keepass 帳號密碼管理
- phpstorm
- 去掉window換行符
- php_cs
- 自定義快捷模塊
- phpstorm快捷鍵
- curl
- 正則
- 設計架構
- 設計模式的六大原則
- 計算機基礎
- TCP三次握手
- OSI7層
- http狀態返回碼
- 前端框架
- Vue
- Angular
- React
- node
- 服務端渲染(SSR)
- MVVM
- nuxt
- pm2
- js
- Promise
- es6
- 常用站點
- 工具類
- 學習類
- ps常用命令
- nginx
- 緩存
- 配置
- TCP
- 常用配置
- ng優先級
- vhost注意點
- nginx第一層驗證
- 轉發(跨域問題)
- 404
- nginx日志格式化
- 重啟腳本
- 寶塔禁用境外ip訪問
- ng統計
- ng編譯安裝
- 防盜鏈
- 技術相關了解
- ddos
- xss
- mysql防注入
- csrf攻擊
- 郵箱系統原理
- DNS
- python
- Selenium
- 微信
- 公眾號
- 公眾號配置
- 用戶授權
- 小程序
- 公有云
- 華為云
- JAVA
- springboot
- windows
- service
- WSL
- 目錄遷移
- wsl2 踩坑
- NoSql
- mongodb
- 安裝mongodb
- redis
- redis-windows
- redis-linux
- openstack
- ====副業====
- 擼茅臺
- 網絡
- 單位換算
- DB
- clickhouse
- mac