Rumah  >  Artikel  >  Operasi dan penyelenggaraan  >  Keizinan Linux yang anda mesti faham (perkongsian ringkasan)

Keizinan Linux yang anda mesti faham (perkongsian ringkasan)

WBOY
WBOYke hadapan
2022-01-06 18:15:482366semak imbas

Artikel ini membawa anda pengetahuan tentang kebenaran Linux, termasuk cara menukar sifat kebenaran saya harap ia akan membantu semua orang.

Keizinan Linux yang anda mesti faham (perkongsian ringkasan)

Dalam proses menggunakan Linux, kami akan menghadapi beberapa masalah tentang pengguna dan kumpulan, seperti yang paling biasa ialah anda ingin berada dalam sesuatu Mesej ralat ini sering muncul apabila melaksanakan arahan tertentu di bawah laluan.

permission denied

Bagaimanapun, saya berkemungkinan besar melihat ralat ini apabila menggunakan FTP untuk memindahkan fail Setelah menunggu lama, peratusan pemindahan masih sifar. Mengapa ia tidak dihantar? Sebenarnya saya tidak tahu, ini disebabkan oleh isu kebenaran.

Cara biasa saya untuk membetulkannya ialah dengan memberikan 777 kebenaran terus, atau log masuk terus menggunakan pentadbir su. . . . . .

Anda mungkin tidak tahu apa yang saya maksudkan, dan sesetengah lelaki besar mungkin menganggap pendekatan saya terlalu rendah, jika anda menghadapi masalah seperti ini, ini bermakna anda tidak mempunyai kebenaran yang mencukupi ? Seterusnya kita perlu mengenali pengguna dan kumpulan dalam Linux.

Pengguna dan Kumpulan

Di Linux, terdapat tiga kategori pemilik fail iaitu pemilik fail, kumpulan dan Lain-lain milik, berikut adalah mengikut tiga konsep yang dijelaskan masing-masing

  • Pemilik Fail

Linux ialah sistem Multi-tugas berbilang pengguna, berbilang pengguna bermaksud sama ada fail yang dibuat oleh sesetengah pengguna boleh dilihat oleh pengguna lain Ini adalah isu keterlihatan, dan ia juga merupakan isu privasi Untuk mengambil kira privasi semua orang, Linux mereka bentuk pemilikan fail sebagai peranan pengarang. Jika anda mempunyai beberapa maklumat dan fail yang sangat peribadi, anda boleh menetapkan fail kepada "kelihatan kepada saya sahaja".

  • Kumpulan

Konsep kumpulan digunakan dalam pembangunan pasukan dan ia lebih berguna untuk projek Tetapkan kebenaran . Contohnya, jika anda bekerja di jabatan penyumberan luar bank, dan anda dan jabatan penyumberan luar yang lain bersama-sama berkhidmat di bank tertentu, dan semua kumpulan penyumberan luar menggunakan satu pelayan, ini akan melibatkan isu kebenaran kumpulan anda berkembang Jika anda tidak mahu jabatan penyumberan luar lain melihat projek, anda akan menetapkan projek itu untuk dilihat kepada kumpulan. Walau bagaimanapun, bank adalah orang yang bertanggungjawab secara keseluruhan, dan semua bank mempunyai kebenaran untuk melihat semua projek jabatan penyumberan luar anda. Oleh itu, anda juga perlu menetapkan kebenaran bank.

  • Orang lain kepunyaan

Orang lain dan kumpulan itu relatif, dan orang lain di luar kumpulan, Izin hubungan di mana tiada kebenaran untuk melihat fail dalam kumpulan.

Selain ketiga-tiga konsep di atas, terdapat juga bos yang mempunyai tahap autoriti tertinggi iaitu root ini mempunyai autoriti tertinggi.

Kebenaran fail Linux

Selepas bercakap tentang konsep pengguna dan kumpulan di atas, mari kita bercakap tentang kebenaran fail Persoalan bagaimana untuk menetapkannya up adalah sangat penting kerana ia adalah kunci untuk menyelesaikan masalah kebenaran yang dinafikan.

Atribut kebenaran

Mula-mula log masuk ke sistem Linux, gunakan su - untuk bertukar kepada identiti akar, kemudian jalankan ls -al dan anda akan melihat yang berikut

Keizinan Linux yang anda mesti faham (perkongsian ringkasan)

Terdapat tujuh lajur kandungan secara keseluruhan Kandungan tujuh lajur ini adalah seperti yang ditunjukkan dalam rajah di bawah.

Keizinan Linux yang anda mesti faham (perkongsian ringkasan)

Anda boleh menggunakan root terus semasa belajar, kerana arahan chgrp, chown dan lain-lain yang berikutnya memerlukan root untuk diproses, tetapi amat disyorkan untuk tidak menggunakan kebenaran root di tempat kerja.

Gunakan exit untuk keluar sebagai root.

Dalam arahan di atas, ls bermaksud senarai, yang bermaksud penyenaraian, dan pilihan -al bermaksud kebenaran dan atribut fail terperinci.

Kebenaran Lajur pertama mewakili kebenaran diwakili oleh 10 aksara secara keseluruhannya Mari kita bawa pulang kebenaran sebagai contoh untuk menyenaraikan makna setiap aksara

Keizinan Linux yang anda mesti faham (perkongsian ringkasan)

Watak pertama mewakili jenis fail Terdapat banyak jenis fail Secara amnya, [d] mewakili direktori Anda boleh menggunakan arahan cd untuk memasuki direktori ini. Anda boleh melihat bahawa hampir semua dalam gambar adalah direktori.

Keizinan Linux yang anda mesti faham (perkongsian ringkasan)

Jika ia [-] ia bermaksud fail, jika ia [l] ia bermakna fail pautan, jika ia [b] ia bermakna peranti capaian rawak dalam fail peranti , jika ia [c], ia bermakna peranti membaca sekali sahaja (papan kekunci, tetikus) dalam fail peranti.

接下来的九个字符分为三组,三个一组,分别表示所属人、所属群组、其他所有者权限,每组内的权限都是三个 rwx 的组合,[r] 表示可读,[w]表示可写,[x] 表示可执行,这里需要注意的是,如果没有权限,就会变为 -号。

链接,这一列表示有多少文件名链接到这个节点(i-node)上,每个文件都会将它的权限和属性记录到文件系统的 i-node 上,不过,我们使用的目录树却是使用文件名来记录的,因此每个文件名都会关联到一个 i-node ,所以这个属性就是记录有多少文件链接到了同一个 i-node 上。

什么是 i-node ?

i-node 的描述方式很像是我们之前聊过的 Socket,Socket 就是一个四元组,有时会加上协议类型变为五元组,如果你不太清楚我说的是什么,可以看下我的这篇文章 原来这才是 Socket!

我们知道,磁盘的最小存储单位是扇区,操作系统在读取扇区时,不会一个扇区接着一个扇区这样读取,因为效率太低,而是以块为单位进行读取,块是由多个扇区组成的。

文件中的数据都存储在扇区中,但是我们并不知道哪一块数据是我们需要的,为了存储一些文件的元信息,比如文件的创建者,创建日期,文件的大小,开发人员提出了 i-node ,也就是索引节点。一般来说,i-node 具有如下内容

Keizinan Linux yang anda mesti faham (perkongsian ringkasan)

具体关于 i-node 的内容,我们后面还会再说。

然后第三列表示这个文件的所属人,由图可见,大部分文件的所属人都是 root 用户。

第四列表示这个文件的所属群组,在 Linux 系统下,你登录的账号会添加到一个或者多个所有人群组中,这一栏就表示对应的群组权限。

第五列表示文件大小,默认单位为字节(Bytes)。

第六列为创建这个文件的日期和最近修改日期,从图中可以看到,这个日期格式有可能不是我们想要的,如果要显示完整的日期格式,可以使用 ls -l --full-time,包括年、月、日、时间。

如果想要让系统默认的语系变为英文的话,那么你可以修改系统配置文件 /etc/locale.conf,首先我们可以查看一下系统都支持哪些语言。

Keizinan Linux yang anda mesti faham (perkongsian ringkasan)

修改默认语言,输入

vi /etc/profile

在文档的最后输入

export LANG="en_US.UTF-8"

就可以切换成为英文,如果想使用中文,可以输入

export LANG="zh_CN.GB18030"

然后使用 esc + :wq 保存,保存之后使用

source /etc/profile

即可完成设置。

第七列为文件名,有一类特殊的文件名,它表示着隐藏文件,如果文件名之前多一个 . ,那就表示隐藏文件。

权限的重要性

提供系统保护:非权限用户不能操作具有某些权限的功能和数据。

适合团队开发和数据共享:团队所有组成员和个人所属能够共享项目。

如果没有恰当的设置系统权限,可能会造成某些泄密事件或者其他不可忽视的后果,所以权限问题大家要引起重视,下面我们就来聊一聊如何设置系统权限。

改变系统权限和属性

我们现在知道文件权限对于一个系统安全的重要性了,现在就要聊一聊如何修改文件权限了。常用的修改文件权限的指令有

  • chgrp :改变文件所属群组

  • chown:改变文件所有者

  • chmod:改变文件权限

chgrp

chgrp 就是 change group 的缩写,我觉得李纳斯把缩写用到了极致,这也许是我们现在对于缩写这么流行的原因。chgrp 能够改变文件群组,不过,要改变群组的话,要被改变的群组名称要在 /etc/group 文件内存在才行,否则就会显示错误。

chown

既然 chgrp 能够改变文件群组,那么 chown 能够改变文件所有者,同样也需要注意的是,文件所有者必须是系统中存在的账号,也就是在 /etc/passwd 这个文件中有记录的使用者名称才可改变。除此之外,chown 还可以直接修改群组名称。

chmod

变更文件权限使用的是 chmod 这个指令,但是,权限的设置有两种方式,可以分别使用数字或者符号进行权限变更。

使用数字改变文件权限

Linux 文件基本权限有 9 种,分别是 owner/group/others 三种身份加自己的 read/write/execute 权限,这九个权限三个为一组,我们可以使用数字表示各个权限。

一般 r 表示 4;w 表示 2;x 表示 1,每种身份各自的权限是需要累加的,比如 rwx 就表示 4 + 2 + 1 = 7。比如我们最常见的 chmod 777 它就表示赋予所有的权限,也就是说谁都能看/写/执行,所以这种文件也存在极大的安全问题。使用数字改变文件权限是我们最常用的一种方式。

使用符号改变文件权限

九种文件权限分别对应着:(1) user (2) group (3) others,所以我们可以借由 u,g,o 来代表三种身份的权限。除此之外,a 代表 all 即全部的身份。

比如我们想要给 -rwxr-xr-x 设置权限,那么我们所使用的命令应该是

chmod u=rwx,go=rx .filename

如果我们想要给所有人增加写入权限,就可以这么操作

chmod a+w .filename

如果我们想给所有人去掉写入权限,就可以这么写入指令

chmod a-w .filename

我们上面列出了三种指令,分别是 =、+、- 号,= 号表示赋值指定权限,+ 号表示增加权限,- 号表示去掉某些权限,在 + 和 - 的状态下,只要没找到指令的项目,那么该权限不会发生变动。

Linux 目录和文件权限

我们上面聊的都是文件权限,文件是容纳数据的地方,这些文件包括一般文本文件、数据库文件、二进制文件等,权限对于文件的意义在于

  • r(read):可以读取文件的实际内容,比如读取文本文件的文字内容

  • w(write):可以新增、编辑或者修改文件中的内容(不包括删除文件)

  • x(execute):使文件具有被文件系统执行的权限。

Windows 下面判断文件是否能够执行的因素是看文件扩展名, 比如 .exe, .bat, .com 等等,但是在 Linux 中,判断文件是否具有可执行权限是直接判断文件有没有 x 这个权限,和文件名无关。

但是在 Linux 中,不只有文件具有权限,目录也有权限,文件是存放实际数据的地方,而目录是记录文件所在位置的清单,我们只有通过目录才能找到文件放在哪里!权限对于不同的目录,也代表着不同的概念。

r (read contents in directory):表示具有读取目录结构清单的权限,所以如果你具有读取一个目录的权限时,就代表你可以查询目录下的文件,所以你就可以使用 ls 将目录的内容显示出来。

w(modify contents of directory):写入权限表示你具有对文件目录和目录中的文件进行修改的操作,主要包括

  • 删除已经存在的文件和目录。

  • 创建新的文件和目录。

  • 将已存在的文件或目录进行改名。

  • 移动目录内文件、目录位置。

x(access directory):这执行权限有啥用?总不能目录也能够被执行把?其实并不是这样,执行权限表示着你有没有权限进入到指定目录下,也就是 cd(change directory) 。

Linux 文件种类和扩展名

想必大家都听说过这样一句话:任何设备在 Linux 下都是文件,但是文件也分为多种,除了上面介绍过的一般文件(-) 和目录文件(d) 之外,还包括下面这些文件类型

常规文件(regular file):常规文件就是我们使用 ls -al 所显示出来的属性,也就是上面我们列出的第一个字符,

Keizinan Linux yang anda mesti faham (perkongsian ringkasan)

文件类型又可以分为

纯文本文件(ASCII),这是 Linux 系统中最多的一种文件类型,纯文本文件是我们能够直接看到的数据,你可以使用 cat 来直接看到这部分内容。比如我们最常用的设置 Linux 静态 ip 的文件 ens33 ,就可以使用 cat 命令来输出

cat ifcfg-ens33

Keizinan Linux yang anda mesti faham (perkongsian ringkasan)

二进制文件,在 Linux 中,查看二进制文件可以使用 xxd 或者 od 进行格式化输出

数据格式文件,数据文件直接使用 cat 读取会显示乱码,但是它能够通过 last 指令进行输出

  • 目录,目录没什么好说的,就是表示一个文件清单,目录的表示就是 [d],也就是 directory。

  • 链接文件(link),链接文件就是某些程序执行时需要和这些链接文件进行链接才能执行的一种文件类型。

  • Peranti dan fail peranti (peranti), peranti di bawah Linux dibahagikan kepada dua jenis, peranti blok dan peranti aksara:

Peranti blok ialah storan peranti Peranti dengan maklumat blok saiz tetap yang menyokong membaca dan (sebagai pilihan) menulis data dalam blok, sektor atau kelompok bersaiz tetap. Setiap blok mempunyai alamat fizikalnya sendiri. Biasanya saiz blok adalah antara 512 - 65536. Semua maklumat yang dipindahkan akan berada dalam blok berturut-turut. Ciri asas peranti blok ialah setiap blok adalah bebas dan boleh dibaca dan ditulis secara bebas. Peranti blok biasa termasuk pemacu keras, cakera Blu-ray dan pemacu USB.

Peranti sekat biasanya terletak di bawah /dev/sda, dan atribut pertamanya ialah [b].

Satu lagi jenis peranti I/O ialah peranti aksara. Peranti aksara menghantar atau menerima aliran aksara dalam unit aksara, tanpa mengira sebarang struktur blok. Peranti aksara tidak boleh dialamatkan dan tidak melakukan sebarang operasi mencari. Peranti aksara biasa termasuk pencetak, peranti rangkaian, tetikus dan kebanyakan peranti lain yang berbeza daripada cakera.

Ciri terbesar peranti aksara ialah ia boleh dibaca sekali dan output tidak boleh dipotong Contohnya, anda tidak boleh melompat tetikus ke tempat lain sekaligus, tetapi menggunakan peranti Aksara yang pertama atribut ialah [c].

  • Fail antara muka data (soket): Seperti namanya, fail antara muka data menggunakan soket untuk menjalankan data rangkaian Atributnya ialah [s], yang biasanya terdapat dalam /run atau direktori /tmp tiba.

  • Fail pemindahan data (FIFO, paip): FIFO juga merupakan jenis fail khas Tujuan utamanya adalah untuk menyelesaikan masalah ralat yang disebabkan oleh berbilang program mengakses fail pada masa yang sama . , atribut pertamanya ialah [p].

Sambungan Linux

Bercakap tentang sambungan ini sebenarnya tidak ada sambungan dalam Linux. tetapi terdapat beberapa kaedah penamaan sambungan, yang sangat memalukan, jadi mari kita panggil ia jenis sambungan buat masa ini. Secara amnya, terdapat jenis berikut:

  • *.sh Ini ialah skrip pelaksanaan atau skrip kumpulan Ia juga dipanggil skrip shell .

  • .tar, .tar.gz, .zip, *.tgz, jenis sambungan ini ialah fail termampat berpakej dan terdapat jenis sambungan yang berbeza mengikut kaedah pembungkusan yang berbeza

  • .html, .php: fail berkaitan halaman web, masing-masing mewakili fail halaman web dalam sintaks HTML dan PHP.

Cadangan berkaitan: "Tutorial Video Linux"

Atas ialah kandungan terperinci Keizinan Linux yang anda mesti faham (perkongsian ringkasan). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:juejin.im. Jika ada pelanggaran, sila hubungi admin@php.cn Padam