읽기 및 쓰기와 관련된 문제는 항상 존재합니다. 파일 잠금은 실제로 이 문제를 해결하기 위해 고안된 것입니다. 읽기-쓰기 상관관계는 파일을 동시에 읽고 쓰는 경우 발생하는 파일 데이터의 무작위 충돌을 나타냅니다. 파일의 데이터를 변경하거나 읽는 데 언제, 어떤 작업이 사용되었는지 명확하게 알기 위해서는 사용자가 언제 파일에 어떤 데이터가 있는지 정확하게 알 수 있도록 작업을 직렬화, 원자화 및 동기화해야 합니다. 파일 잠금은 이러한 도구 중 하나입니다.
파일 시스템에는 일반적으로 공유 잠금과 배타적 잠금이라는 두 가지 유형의 잠금이 있으며, 이는 읽기 잠금 및 쓰기 잠금이라고도 합니다.
파일 시스템 잠금 기능:
파일을 열 때 하나의 잠금만 가질 수 있습니다. 즉, 동시에 두 개 이상의 잠금을 파일에 할당할 수 없습니다.
잠긴 파일을 읽고 쓰는 사용자는 이 잠금을 보유할 수 있습니다. 즉, 이 잠금을 보유하는 사용자는 파일에 대해 읽기 또는 쓰기와 같은 해당 작업을 수행할 수 있습니다. 사용자는 파일 잠금을 신청할 수 있습니다. 파일이 처음에 잠금 해제되면 시스템은 잠금을 신청하기 전에 파일에 대한 잠금을 생성한 다음 신청자가 이를 보유합니다.
잠금 유지 규칙: 이 파일에 이미 읽기(공유) 잠금이 있는 경우 다른 사용자는 파일에 배타적 잠금이나 읽기 전용 잠금을 할당할 수 없지만 잠금을 유지할 수 있습니다. 다른 사용자는 파일을 읽을 수 있지만 파일이 잠겨 있는 동안에는 어떤 사용자도 파일에 쓸 수 없습니다. 파일에 이미 독점 잠금이 설정되어 있고 사용자가 보유하고 있는 경우 보유자가 잠금을 해제하지 않는 한 어떤 사용자도 잠금을 다시 보유할 수 없습니다.
기억해야 할 중요한 개념이 있습니다. 파일 자체의 작업은 잠금과 관련이 없습니다. 파일이 잠겨 있는지 여부에 관계없이 사용자는 파일에 대한 일반적인 작업을 마음대로 수행할 수 있습니다. , 그러나 작업 시스템은 잠금을 확인하고 상황에 따라 다른 처리를 제공합니다. 예를 들어, 잠금이 없는 상황에서는 누구나 동시에 모든 파일을 읽고 쓸 수 있습니다. 물론 읽고 쓴 내용이 잘못될 가능성이 매우 높습니다. 내용만 잘못되고 작업도 수행됩니다. 틀리지 않을 것입니다. 잠긴 후에는 특정 상황에서 특정 작업이 거부됩니다. 파일 잠금의 기능은 파일과 데이터 자체를 보호하는 것이 아니라 데이터의 동기화를 보장하는 것입니다. 따라서 파일 잠금은 잠금을 보유한 사용자에게만 실제로 효과적이며 모든 사용자가 동일한 것을 사용하는 경우에만 가능합니다. 파일 잠금은 해당 파일에 대해 잠금 제한이 적용되는 경우에만 모든 사용자에게 적용됩니다. 그렇지 않으면 예외가 있는 한 전체 파일 잠금 기능이 해제됩니다. 예를 들어, 모든 사람이 파일 열기, 파일 잠금, 읽기 및 쓰기, 잠금 해제 및 닫기의 단계를 따르면 파일 잠금의 할당 및 유지 원칙에 따라 모든 사람의 작업에 문제가 없습니다. 파일 업데이트는 원자성 작업으로 존재하고 분할할 수 없으므로 동기식이며 안전합니다. 그러나 사람이 이 단계를 수행하지 않으면 읽고 쓸 때 정확하게 읽지 못하거나 쓸 수 없는 등의 문제가 발생하게 됩니다.
위의 원칙을 바탕으로 읽은 데이터가 잠겨 있는지 여부에 대해 이야기해 볼 가치가 있습니다. 일반적으로 배타적 잠금은 파일에 기록된 데이터가 올바른지 확인하는 유일한 작업입니다. 파일이 잠기면 다른 사용자는 잠금을 얻을 수 없으므로 어떤 작업도 수행할 수 없습니다. 읽을 때 상황에 따라 다르지만 대부분의 경우 특히 정확하거나 민감한 데이터가 필요하지 않으면 잠금을 적용하는 데 시간과 리소스가 필요하지 않습니다. 더 많은 문제가 있습니다. 가장 중요한 것은 파일을 업데이트해야 할 경우 읽기 전용 잠금으로 잠겨 있으면 쓰기를 원하는 사용자가 쓰기를 할 수 없다는 것입니다. 동시에 읽기 전용 잠금을 신청하는 사람이 너무 많으면 독점 잠금이 적용되지 않을 수 있습니다. 이는 파일이 오랫동안 기록되지 않을 수 있음을 의미합니다. 매우 느리다. 일반적으로 파일을 쓸 수 있는 기회는 상대적으로 드물고 더 중요하므로 대부분의 경우 읽기 전용 잠금이 필요하지 않습니다. 그렇다면 읽기 전용 잠금은 어디에 사용됩니까? 읽기 전용 잠금은 실제로 사용자 자신에게만 유용합니다. 읽기 전용 잠금은 사용자가 읽은 데이터가 "더티(dirty)"라는 더티 데이터가 아니라 파일에서 읽은 실제 데이터인지 확인합니다. 실제로 이는 여전히 잠금을 사용하지 않는 다른 사용자가 파일을 잘못 조작하는 것을 목표로 하고 있으며, 파일이 잠겨 있는 경우 다른 사용자가 직접 읽고 쓰면 반드시 잠금을 사용할 필요는 없습니다. 해당 작업은 유효하지 않을 수 있습니다. 읽기 잠금을 보유한 사용자는 데이터를 읽을 때 덮어쓴 데이터가 아니라 실제 파일에서 읽은 것임을 확신할 수 있습니다. 동시에.
따라서 이때 데이터가 잘못되지 않도록 쓰기 시에는 배타적 잠금을 적용하는 것이 당연합니다. 공유 잠금을 적용하지 않으면 읽은 데이터가 정확하지 않을 수 있지만 파일 자체에는 영향을 미치지 않습니다. 공유 잠금을 적용한 후 읽은 데이터는 실제 데이터여야 합니다. 데이터의 정확성을 보장하지 않는 경우에는 공유 잠금을 추가할 필요가 없으며 쓰기 위해 다시 읽으면 됩니다. 단독 잠금을 직접 추가하는 것이 더 좋습니다. 공유 잠금을 사용할 필요가 없습니다.
또 강조해야 할 점은 파일 잠금은 규칙에 따라 사용하는 사용자에게만 효과적이라는 것입니다. 그렇지 않으면 일부는 사용하고 일부는 사용하지 않을 것입니다. 엉망이 되어도 오류는 계속 발생합니다. 동일한 파일에 대해 모든 사람이 동일한 규칙을 사용하여 파일 잠금을 사용하는 경우에만 파일을 공유할 때 각 사용자가 읽기 또는 쓰기 오류가 발생하지 않도록 할 수 있습니다.