Linux의 chroot 명령: 격리된 공간에서 애플리케이션을 실행하고 테스트하는 방법
Linux 매니아라면 시스템에 다양한 애플리케이션이나 서비스를 설치하거나 제거해야 하는 경우가 종종 있습니다. 하지만 모든 애플리케이션이나 서비스가 다른 소프트웨어 패키지에서 제공하는 일부 공유 개체 파일에 의존한다는 사실을 알고 계셨습니까? 이러한 개체 파일이 없거나 손상된 경우 응용 프로그램이나 서비스가 제대로 작동하지 않거나 시작되지 않을 수도 있습니다. 따라서 격리된 공간에서 애플리케이션이나 서비스를 실행하고 테스트하는 방법을 아는 것은 Linux 시스템을 유지 관리하고 최적화하는 데 도움이 될 수 있는 매우 유용한 기술입니다. 이 기사에서는 chroot라는 강력한 명령줄 도구를 소개합니다. 이 도구를 사용하면 Linux에서 독립적인 환경을 만들고 그 안에서 애플리케이션이나 서비스를 실행하고 테스트할 수 있습니다.
Linux에서 chroot가 무엇인가요?
chroot를 자세히 살펴보고 그 이점, 사용 시나리오, Linux 시스템에서 설정하는 방법, 필요한 경우 환경에서 벗어나는(chroot) 방법을 이해해 보겠습니다.
chroot는 사용자가 애플리케이션과 서비스를 안전하게 격리할 수 있게 해주는 가장 간단하고 오래된 컨테이너화 소프트웨어 중 하나인 변경 루트입니다. 컴퓨팅 용어에서 격리는 미리 정의된 리소스를 사용하여 프로그램을 제한된 공간에 가두는 것입니다.
Docker와 작동 방식에 익숙하다면 chroot를 훨씬 단순화된 버전으로 생각할 수 있습니다. chroot는 프로그램의 루트 디렉터리를 변경하고 액세스 및 가시성을 제한하여 추가 격리 및 보안 계층을 제공합니다.
기본적으로 별도의 디렉터리를 만들고 프로그램의 모든 종속성을 새 디렉터리에 복사한 다음 chroot 명령을 실행합니다. 이를 통해 기본 파일 시스템에 대한 액세스 권한을 잃어도 프로그램이 정상적으로 실행될 수 있습니다.
프로그램을 chroot 환경으로 설정하는 것은 실제 시스템 파일을 변경하지 않고 안전한 공간에서 안정성을 테스트할 수 있는 좋은 방법입니다. 또한 chroot 환경에서는 손상된 소프트웨어 패키지로 인해 발생하는 보안 위험을 줄일 수 있습니다. chroot 환경에서는 손상된 소프트웨어 패키지가 민감한 시스템 파일에 액세스하거나 수정할 수 없기 때문입니다.
이 프로그램은 "chroot 감옥"이라고도 알려진 chroot 디렉토리로 가져온 파일에만 액세스하고 볼 수 있습니다. 이렇게 하면 프로그램과 해당 하위 프로세스가 기본 시스템의 작동을 방해하는 것을 방지할 수 있습니다.
츄루트 감옥이 무엇인가요?
chroot 감옥은 chroot 프로그램이 실행되고 실행되는 격리된 환경입니다. chroot 감옥이라는 용어는 chroot 환경 내의 프로세스와 해당 하위 프로세스가 기본 파일 시스템에 액세스하거나 볼 수 없으며 chroot용으로 예약된 리소스로 제한된다는 개념에서 유래되었습니다.
이제 chroot의 개념을 명확하게 이해했으므로 chroot Jail을 만들고 그 안에서 프로그램을 실행하는 방법을 직접 배워보겠습니다.
chroot 감옥을 만들고 그 안에서 프로그램을 실행하는 방법
chroot 감옥은 기본적으로 프로그램이 제대로 실행되는 데 필요한 모든 리소스, 파일, 바이너리 및 기타 종속성을 포함하는 디렉터리입니다.
그러나 일반 Linux 환경과 달리 chroot Jail의 환경은 엄격히 제한되어 있으며 프로그램은 외부 또는 추가 파일 및 시스템 리소스에 접근할 수 없습니다.
예를 들어 chroot 감옥에서 Bash 셸을 실행하려면 Bash 바이너리와 모든 종속 항목을 chroot 디렉터리에 복사해야 합니다.
chroot Jail을 생성하고 Bash 쉘을 생성하는 단계는 다음과 같습니다.
1. 프로그램을 성공적으로 실행하려면 모든 종속성을 chroot 감옥 디렉터리에 복사해야 합니다. which 및 ldd 명령을 사용하여 바이너리(이 경우 Bash) 및 모든 종속 항목의 위치를 찾아보겠습니다.
으아아아
2. 이제 바이너리의 위치와 종속성을 알았으므로 chroot 감옥으로 변환하려는 디렉터리에 복사하세요. mkdir 명령을 사용하여 필요한 디렉터리를 만들고 cp 명령을 사용하여 모든 파일을 해당 디렉터리에 복사합니다.
mkdir bin lib lib64 && cp -r /lib/ * ./lib && cp -r /lib64/* ./lib64/ && cp /bin/bash /bin/

3、最后,当程序和它的依赖项复制完成后,你可以使用 sudo 前缀以提升的权限运行 chroot 命令,在所选择的目录中生成 chroot 环境。默认情况下,它将生成一个Bash shell。下面是要输入的命令:
linuxmi@linuxmi:~$ sudo chroot www.linuxmi.com

这就是生成chroot监狱并在其中运行程序的所有步骤。
如何逃离chroot监狱
虽然 chroot 监狱对于测试不稳定的软件很有用,但在处理 SSH 连接时也很有用,因为将连接的用户设置为 chroot 环境是保护 SSH 服务器的众多方法之一。
另一方面,如果你是一名渗透测试人员,并且已登录到目标的 SSH 服务器,发现它是一个 chroot 环境,可能会感到沮丧,感觉走投无路。
然而,有很多方法可以逃离错误配置的 chroot 狱,有些方法需要 C 编程技巧,而其他方法可以使用工具自动化。一些简单的 chroot 逃逸方法包括:
- 嵌套的 chroot 调用
- 带有保存的文件描述符的嵌套 chroot 调用
- 根目录挂载方法
- procfs 逃逸
- ptrace 逃逸
请注意,要使用这些方法之一进行 chroot 逃逸,你需要在系统中具有升级的特权。通过访问 chw00t 的 GitHub 存储库,你可以了解更多关于这些逃逸方法的信息,那是一个 chroot 逃逸自动化工具。
现在你应该对 Linux 中的 chroot 了如指掌了
通过本文的介绍,我们了解了chroot是什么、它是如何工作的以及如何实现它,我们还学习了如何创建chroot监狱并在其中执行应用程序或服务,以及如何逃离chroot监狱。chroot是一个简单而强大的工具,可以让你在安全和隔离的空间中运行和测试应用程序或服务。请记住,chroot并不是一个完美的安全解决方案,它有一些局限性和缺陷,因此你应该谨慎地使用它,并结合其他的沙盒或虚拟化技术来提高你的系统的安全性和稳定性。
위 내용은 Linux의 chroot 명령: 격리된 공간에서 애플리케이션을 실행하고 테스트하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

LinuxoffersmoredeveloperTools, 특히 Open-SourcendCommand-line-line-line-line-whilewslagsinsomeareas.linuxcelsinopen-sourcetools, command-lineefficiency, andsystemopertizationsfocusedontheseaseaseaseasseass.w

이 기사는 Windows와 같은 데스크톱 경험을 제공하는 최고의 Linux 배포판을 살펴 봅니다. Windows, 특히 Windows 10 (2015 년 7 월 29 일 출시) 및 후속 Windows 11 (2021 년 10 월 5 일)에서의 전환은 종종 사용자가 고려합니다.

Linux Management에서 10 년 이상의 경험을 가진 관리자로서 저의 주요 책임은 항상 Linux 서버의 보안 관리입니다. 방화벽은 Linux 시스템 및 네트워크 보안을 보호하는 데 중요한 역할을합니다. 이들은 내부 및 외부 네트워크 사이의 경비원과 같습니다. 사전 정의 된 규칙에 따라 네트워크 트래픽을 제어하고 관리합니다. 이러한 방화벽 규칙은 법적 연결을 허용하고 지정되지 않은 연결을 차단합니다. 요즘에는 많은 오픈 소스 방화벽 애플리케이션이 있으며 귀하의 요구에 맞는 적절한 응용 프로그램을 선택하는 것은 어려울 수 있습니다. 이 기사에서는 2024 년에 Linux 서버를 보호하는 데 도움이되는 10 가지 가장 인기있는 오픈 소스 방화벽을 살펴 보겠습니다. iptables /

이 기사는 GUI 기반 Linux 명령의 이전 커버리지를 확장하여 추가로 귀중한 X 기반 Linux 명령 및 프로그램을 살펴 봅니다. XwinInfo : 공개 창 세부 사항 XwinInfo는 포괄적 인 정보를 제공하는 명령 줄 유틸리티입니다

NetData : Linux 시스템에서 MySQL 데이터베이스의 성능을 쉽게 모니터링하는 강력한 도구 NetData는 Linux, FreeBSD 및 MACOS와 같은 UNIX와 같은 시스템에 적합한 무료 및 오픈 소스 실시간 시스템 성능 및 건강 모니터링 애플리케이션입니다. 다양한 메트릭을 수집하고 시각화하여 시스템 작동을 실시간으로 모니터링 할 수 있습니다. NetData는 현재 시스템 상태를 모니터링하고 MySQL 데이터베이스 서버 등과 같은 응용 프로그램 및 서비스를 실행할 수있는 다양한 플러그인을 지원합니다. 이 기사에서는 RHEL 기반 배포판에서 NetData를 사용하여 MySQL 데이터베이스 서버의 성능을 모니터링하는 방법을 안내합니다. 읽은 후에는 NetData의 웹 인터페이스를 살펴볼 수 있습니다.

Linux Diff3 명령 : 세 파일을 비교하고 병합하기위한 강력한 도구 DIFF3 명령은 Linux의 강력한 도구로 세 가지 파일을 비교하고 차이점을 보여줍니다. 이는 종종 동일한 파일의 여러 버전을 다루는 프로그래머 및 시스템 관리자에게 매우 유용하며 이러한 버전을 병합하거나 다른 버전 간의 변경 사항을 식별해야합니다. 이 기사는 Diff3 명령의 기본 사용법, 공통 옵션 및 Linux에서 작동 방식을 이해하는 데 도움이되는 몇 가지 예를 소개합니다. diff3 명령은 무엇입니까? DIFF3은 세 가지 파일을 라인별로 비교하는 도구로 차이점을 인식하고 이해하기 쉬운 형식으로 표시합니다. 사용될 수 있습니다. 세 기사를 찾으십시오

이 안내서는 Linux 서버에 오픈 소스 SMS 관리 소프트웨어 인 Playsms를 설치하기위한 포괄적 인 연습을 제공합니다. 효율적인 SMS 커뮤니케이션 관리를위한 강력한 도구입니다. 시스템 요구 사항 : 시작하기 전에 S를 확인하십시오

Clementine : Linux, MacOS 및 Windows 용 다목적 및 사용자 친화적 인 음악 플레이어 Clementine은 특히 Linux 시스템에서 사용하기 쉽도록 설계된 현대적이고 가벼운 음악 연주자입니다. Amarok에서 영감을 얻은 Clementine은 전임자를 능가합니다


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경