How to make a file readable, writable, and read-only under Linux?
In the process of Linux operation and maintenance, we often encounter that the storage directory of an application is full, without any planning in advance, and the directory or disk cannot be expanded. At this time, our common solution is to make a soft link, through ln, soft link the originally stored directory to a directory in another large disk to achieve the purpose.
The disadvantage of soft links is that after multiple layers of soft links, they will be stunned, which can easily cause misoperation. Today I will introduce a method
mount –bind
The mount command operation and maintenance friends should be familiar with it, so I won’t introduce it in too much
Let’s first look at the introduction in man

You can remount the file directory structure through mount –bind and connect two directories. It mounts the former directory to the latter directory. All access to the latter directory is actually access to the previous directory. Access to a directory
example
Let’s look at the example, create two different directories, and create different files in the two different directories

View the inode of the file

Mount test1 to test2 through mount –bind, and recheck the inode and directory contents

You can see that the inode number and file are both test1
Then access and modify the files in the test2 directory. In fact, what is changed is the test1 directory. Under our test, create the file in the test2 directory

After contacting mount, we will check the contents of the next two directories

You can see that the test1 directory remains in the modified state, and the test2 directory files still exist and remain unchanged
principle
Take mount –bind test1 test2 as an example. When the mount –bind command is executed, Linux will record the directory entry of the mounted directory ( is also the block of the directory file and records the information of the lower-level directory) Shielding, that is, the lower-level path of test2 is hidden (Note that it is just hiding but not deleting, the data has not changed, it is just inaccessible). At the same time, the kernel records the directory entry of the mounting directory (test1) in an s_root object in the memory. When the mount command is executed, VFS will create a vfsmount object. This object contains all the mount information of the entire file system, among which It will also include the information in this mount. This object is a HASH value correspondence table (the HASH value is calculated by calculating the path string). The table contains the HASH value correspondence between the two directories /test1 to /test2
After the command is executed, when accessing files under /test2, the system will inform that the directory entry of /test2 is blocked, and automatically go to the memory to find VFS, and learn the corresponding relationship between /test2 and /test1 through vfsmount. , thereby reading the inode of /test1, so that all files read under /test2 are files in the /test1 directory
Notice
The corresponding relationship between the two directories exists in the memory. Once restarted, the mounting relationship will be gone, so the mounting relationship needs to be written to /etc/fstab
Advanced usage
-
Temporary configuration file reading test
In some application scenarios, it is necessary to modify the configuration file for testing, but it cannot affect the running business. If you are not sure and are unwilling to modify the original configuration file directly, we can modify it in /tmp and other directories. , write a test configuration file, mount it to the configuration file reading directory through mount –bind, and run the program to read the temporary configuration file. After the test is completed, you only need to umount, which does not affect the original configuration
-
Read-only mount
In some scenarios, for example, if you need to give developers permission to view some configurations, but do not allow them to modify the configurations, you can mount a read-only directory through mount –bind,ro. The original directory is writable and can be mounted The loaded directory is read-only. You only need to give the developer the read-only directory permission
The above is the detailed content of How to make a file readable, writable, and read-only under Linux?. For more information, please follow other related articles on the PHP Chinese website!


For years, Linux software distribution relied on native formats like DEB and RPM, deeply ingrained in each distribution's ecosystem. However, Flatpak and Snap have emerged, promising a universal approach to application packaging. This article exami

The differences between Linux and Windows in handling device drivers are mainly reflected in the flexibility of driver management and the development environment. 1. Linux adopts a modular design, and the driver can be loaded and uninstalled dynamically. Developers need to have an in-depth understanding of the kernel mechanism. 2. Windows relies on the Microsoft ecosystem, and the driver needs to be developed through WDK and signed and certified. The development is relatively complex but ensures the stability and security of the system.

The security models of Linux and Windows each have their own advantages. Linux provides flexibility and customizability, enabling security through user permissions, file system permissions, and SELinux/AppArmor. Windows focuses on user-friendliness and relies on WindowsDefender, UAC, firewall and BitLocker to ensure security.

Linux and Windows differ in hardware compatibility: Windows has extensive driver support, and Linux depends on the community and vendors. To solve Linux compatibility problems, you can manually compile drivers, such as cloning RTL8188EU driver repository, compiling and installing; Windows users need to manage drivers to optimize performance.

The main differences between Linux and Windows in virtualization support are: 1) Linux provides KVM and Xen, with outstanding performance and flexibility, suitable for high customization environments; 2) Windows supports virtualization through Hyper-V, with a friendly interface, and is closely integrated with the Microsoft ecosystem, suitable for enterprises that rely on Microsoft software.

The main tasks of Linux system administrators include system monitoring and performance tuning, user management, software package management, security management and backup, troubleshooting and resolution, performance optimization and best practices. 1. Use top, htop and other tools to monitor system performance and tune it. 2. Manage user accounts and permissions through useradd commands and other commands. 3. Use apt and yum to manage software packages to ensure system updates and security. 4. Configure a firewall, monitor logs, and perform data backup to ensure system security. 5. Troubleshoot and resolve through log analysis and tool use. 6. Optimize kernel parameters and application configuration, and follow best practices to improve system performance and stability.

Learning Linux is not difficult. 1.Linux is an open source operating system based on Unix and is widely used in servers, embedded systems and personal computers. 2. Understanding file system and permission management is the key. The file system is hierarchical, and permissions include reading, writing and execution. 3. Package management systems such as apt and dnf make software management convenient. 4. Process management is implemented through ps and top commands. 5. Start learning from basic commands such as mkdir, cd, touch and nano, and then try advanced usage such as shell scripts and text processing. 6. Common errors such as permission problems can be solved through sudo and chmod. 7. Performance optimization suggestions include using htop to monitor resources, cleaning unnecessary files, and using sy


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

WebStorm Mac version
Useful JavaScript development tools

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

SublimeText3 English version
Recommended: Win version, supports code prompts!
