Microsoft MVP성태의 닷넷 이야기
Linux: 67. WSL 환경 + mlocate(locate) 도구의 /mnt 디렉터리 검색 문제 [링크 복사], [링크+제목 복사],
조회: 14081
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 11개 있습니다.)
개발 환경 구성: 303. Windows 10 Bash Shell - 한글 환경을 영문으로 바꾸고 싶다면?
; https://www.sysnet.pe.kr/2/0/11058

개발 환경 구성: 554. WSL 인스턴스 export/import 방법 및 단축 아이콘 설정 방법
; https://www.sysnet.pe.kr/2/0/12569

개발 환경 구성: 556. WSL 인스턴스 초기 설정 명령어
; https://www.sysnet.pe.kr/2/0/12573

개발 환경 구성: 581. Windows에서 WSL로 파일 복사 시 root 소유권으로 적용되는 문제
; https://www.sysnet.pe.kr/2/0/12718

Linux: 46. WSL 환경에서 find 명령을 사용해 파일을 찾는 방법
; https://www.sysnet.pe.kr/2/0/12864

개발 환경 구성: 617. 윈도우 WSL 환경에서 같은 종류의 리눅스를 다중으로 설치하는 방법
; https://www.sysnet.pe.kr/2/0/12878

개발 환경 구성: 619. Windows Server에서 WSL을 위한 리눅스 배포본을 설치하는 방법
; https://www.sysnet.pe.kr/2/0/12882

Linux: 47. WSL - shell script에서 설정한 환경 변수가 스크립트 실행 후 반영되지 않는 문제
; https://www.sysnet.pe.kr/2/0/12918

Windows: 207. Windows Server 2022에 도입된 WSL 2
; https://www.sysnet.pe.kr/2/0/13073

개발 환경 구성: 694. Windows 디렉터리 경로를 WSL의 /mnt 포맷으로 구하는 방법
; https://www.sysnet.pe.kr/2/0/13484

Linux: 67. WSL 환경 + mlocate(locate) 도구의 /mnt 디렉터리 검색 문제
; https://www.sysnet.pe.kr/2/0/13503




WSL 환경 + mlocate(locate) 도구의 /mnt 디렉터리 검색 문제

mlocate 도구를 설치하면,

$ sudo apt install mlocate
Reading package lists... Done
...[생략]...
Initializing mlocate database; this may take some time...
Progress: [ 60%] [################################################################............................................]

WSL 환경의 경우 위와 같이 일정 수준의 진도에서 한참 동안 멈춰있을 것입니다. 왜냐하면, 윈도우의 C, D 드라이브 등에 매핑된 /mnt 디렉터리로 인해 인덱싱 시간이 오래 걸리기 때문인데요, 게다가 그 이후 검색에서도 원치 않게 /mnt 디렉터리를 포함한 결과를 출력하는 문제가 있습니다.

따라서, (find 명령에서 /mnt를 제외한 것처럼) mlocate에게 /mnt를 제외해야 하는데요, 이에 대해서는 /etc/updatedb.conf 파일을 직접 편집하면 됩니다.

$ cat /etc/updatedb.conf
PRUNE_BIND_MOUNTS="yes"
£ PRUNENAMES=".git .bzr .hg .svn"
PRUNEPATHS="/tmp /var/spool /media /var/lib/os-prober /var/lib/ceph /home/.ecryptfs /var/lib/schroot"
PRUNEFS="NFS afs autofs binfmt_misc ceph cgroup cgroup2 cifs coda configfs curlftpfs debugfs devfs devpts devtmpfs ecryptfs ftpfs fuse.ceph fuse.cryfs fuse.encfs fuse.glusterfs fuse.gvfsd-fuse fuse.mfs fuse.rozofs fuse.sshfs fusectl fusesmb hugetlbfs iso9660 lustre lustre_lite mfs mqueue ncpfs nfs nfs4 ocfs ocfs2 proc pstore rpc_pipefs securityfs shfs smbfs sysfs tmpfs tracefs udev udf usbfs"

이 파일에서 PRUNEPATHS에 다음과 같이 /mnt를 추가해 줍니다.

PRUNEPATHS="/mnt /tmp /var/spool /media /var/lib/os-prober /var/lib/ceph /home/.ecryptfs /var/lib/schroot"

이후 변경 사항을 반영하기 위해 updatedb를 관리자 권한으로 재실행합니다.

$ updatedb
updatedb: can not open a temporary file for `/var/lib/mlocate/mlocate.db'

$ sudo updatedb




그런데, 달리 생각해 보면 locate의 /mnt 검색을 그냥 또 다른 윈도우 명령어 Shell의 기능처럼 받아들일 수도 있습니다. 인덱싱 크기도,

// /mnt 포함했을 때,

$ ls -l /var/lib/mlocate/mlocate.db
-rw-r----- 1 root mlocate 187268412 Dec 27 14:00 /var/lib/mlocate/mlocate.db

// /mnt 제외했을 때,

$ ls -l /var/lib/mlocate/mlocate.db
-rw-r----- 1 root mlocate 5681370 Dec 26 19:27 /var/lib/mlocate/mlocate.db

미포함했을 때의 5MB에 비해 180MB 정도로 크긴 하지만 그래도 뭐 저 정도면 요즘 시대의 외장 스토리지에서는 크게 부담스러운 수준은 아닙니다.

참고로, updatedb 명령의 인자를 보면 --add-prunepaths 옵션이 있는데요,

$ sudo updatedb --add-prunepaths "/mnt"

직관적으로는 저 명령어가 /etc/updatedb.conf에 /mnt 예외를 추가할 것처럼 느껴지겠지만, 실제로 하는 일은 /var/lib/mlocate/mlocate.db 인덱스 파일에서 /mnt 경로에 대한 인덱싱을 제거하는 역할만 합니다. (따라서 conf 파일의 변경이 없으므로 이런 경우에는 "sudo udpatedb" 명령어를 내려 다시 인덱싱을 하면 add-prunepaths 옵션 전의 상황으로 바뀝니다.)




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 12/27/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
14014정성태9/17/202563닷넷: 2364. C# - stun.l.google.com을 사용해 공용 IP 주소와 포트를 알아내는 방법파일 다운로드1
14013정성태9/14/2025533닷넷: 2363. C# - Whisper.NET Library를 이용해 음성을 텍스트로 변환 및 번역하는 예제파일 다운로드1
14012정성태9/9/2025868닷넷: 2362. C# - Windows.Media.Ocr: 윈도우 운영체제에 포함된 OCR(Optical Character Recognition)파일 다운로드1
14011정성태9/7/20251500닷넷: 2361. C# - Linux 환경의 readlink 호출
14010정성태9/1/20251544오류 유형: 983. apt update 시 "The repository 'http://deb.debian.org/debian buster Release' does not have a Release file." 오류
14009정성태8/28/20251999닷넷: 2360. C# 14 - (11) Expression Tree에 선택적 인수와 명명된 인수 허용파일 다운로드1
14008정성태8/26/20252322닷넷: 2359. C# 14 - (10) 복합 대입 연산자의 오버로드 지원파일 다운로드1
14007정성태8/25/20252684닷넷: 2358. C# - 현재 빌드에 적용 중인 컴파일러 버전 확인 방법 (#error version)
14006정성태8/23/20252863Linux: 121. Linux - snap 패키지 관리자로 설치한 소프트웨어의 디렉터리 접근 제한
14005정성태8/21/20252348오류 유형: 982. sudo: unable to load /usr/libexec/sudo/sudoers.so: libssl.so.3: cannot open shared object file: No such file or directory
14004정성태8/21/20252649오류 유형: 981. dotnet 실행 시 No usable version of the libssl was found
14003정성태8/21/20252880닷넷: 2357. C# 14 - (9) 새로운 지시자 추가 (Ignored directives)
14002정성태8/20/20252883오류 유형: 980. C# - appsettings.json 파일의 설정값이 적용 안 된다면?
14001정성태8/19/20256152닷넷: 2356. .NET SDK 10 - 단일 소스 코드 파일을 빌드/실행하는 기능을 "dotnet" 명령어에 추가 [1]
14000정성태8/18/20252985오류 유형: 979. ERROR: failed to solve: failed to read dockerfile: open Dockerfile: no such file or directory
13999정성태8/15/20252944닷넷: 2355. C# 14 - (8) null 조건부 연산자 개선 - 대입문에도 사용 가능파일 다운로드1
13998정성태8/14/20252892닷넷: 2354. C# 14 - (7) 확장 메서드에 정적 메서드와 속성 지원을 위한 전용 구문 추가파일 다운로드1
13997정성태8/14/20253016Linux: 120. docker 컨테이너로 매핑된 볼륨에 컨테이너 측의 사용자 ID를 유지하면서 복사하는 방법
13996정성태8/13/20252439오류 유형: 978. Unable to find the requested .Net Framework Data Provider.
13995정성태8/13/20252620개발 환경 구성: 754. Visual C++ - 리눅스 빌드를 위한 Ubuntu 18 docker 컨테이너 설정
13994정성태8/12/20252342오류 유형: 977. SQL Server - User, group, or role '...' already exists in the current database. (Microsoft SQL Server, Error: 15023)
13993정성태8/11/20253162오류 유형: 976. Microsoft.ML.OnnxRuntimeGenAI 패키지 사용 시 "cublasLt64_12.dll" which is missing. (Error 126: "The specified module could not be found.") 오류
13992정성태8/11/20253105닷넷: 2353. C# - Foundry Local을 이용한 gpt-oss-20b 모델 사용파일 다운로드1
13991정성태8/9/20252845오류 유형: 975. winget - Foundry Local 패키지 업데이트가 안 되는 문제
13990정성태8/8/20252356Windows: 283. Time zone 설정이 없는 Windows Server 2025
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...