목차
1. 웹 서버 Nginx 권한
二、php的权限配置
三、MySQL服务的权限配置
" >nginx.conf 구성의 사용자임을 알 수 있습니다. nginx, php-fpm 및 mysql에 대한 사용자 권한을 구성하는 방법
운영 및 유지보수 엔진스 nginx, php-fpm 및 mysql에 대한 사용자 권한을 구성하는 방법

nginx, php-fpm 및 mysql에 대한 사용자 권한을 구성하는 방법

May 24, 2023 pm 08:01 PM
mysql php nginx

nginx, php-fpm 및 mysql에 대한 사용자 권한을 구성하는 방법

일반적으로 우리가 웹 애플리케이션을 실행하는 서버에는 CentOS, Ubuntu, Debian 등과 같은 Linux 배포판이 포함됩니다. 이때 서비스 아키텍처를 형성하는 데 필요한 Nginx, PHP, MySQL 및 기타 애플리케이션의 권한 제어는 매우 중요합니다. 각 서비스에는 코드 디렉토리에 대한 권한 요구 사항이 다르므로 특정 권한이 없으면 서비스를 수행할 수 없습니다. 읽기, 쓰기 또는 실행을 수행하면 권한 요구 사항이 낮아지고 침입 및 수정 위험이 발생합니다.

1. 웹 서버 Nginx 권한

PHP의 운영 프레임워크는 일반적으로 Nginx와 결합하여 LNMP를 구성하거나 Apache와 결합하여 LAMP 아키텍처를 구성합니다. 여기서는 Nginx를 예로 들어 Nginx 서비스를 실행하는 데 필요한 권한을 설명합니다.
우리는 Nginx 자체가 PHP 구문을 구문 분석할 수 없다는 것을 알고 있으므로 Nginx는 정적 파일(예: HTML 등)에 대해 직접 구문 분석하고 결과를 반환하지만, PHP 파일의 경우 Nginx는 처리를 위해 이를 PHP 인터프리터 php-fpm으로 전송합니다. 처리 후 클라이언트 브라우저에 응답을 반환합니다.

따라서 Nginx 및 PHP 서비스에 필요한 권한을 코드 디렉터리에 통합해야 합니다.

① 루트 사용자를 일률적으로 사용하는 경우 일반 게스트 계정은 애플리케이션에 액세스할 수 없습니다. nginx를 루트로 실행하도록 구성하면 공격을 받으면 루트 ID를 획득하여 수행하게 됩니다. 시스템의 모든 작업.

코드 디렉터리의 권한을 rwxrwxrwx로 일률적으로 설정하면 사용자가 브라우저를 통해 코드 디렉터리를 직접 수정할 수 있는 위험이 숨어 있습니다.

그래서 가장 좋은 방법은 이들을 새로운 사용자 그룹으로 분류하고 Nginx 및 PHP를 실행하는 데 필요한 권한을 사용자 그룹에 할당하여 웹 애플리케이션의 권한 디렉터리 관리를 달성하는 것입니다. 대부분의 경우 팀에서는 www 사용자 그룹을 사용하여 코드 디렉터리 권한을 관리하고 사용자 www를 균일하게 관리합니다.

Nginx 구성 파일 nginix.conf에 구분된 실행 권한이 www 사용자 아래에 구성되어 있는 것을 볼 수 있으므로 Nginx 하위 프로세스도 www 사용자에 의해 실행되며, 이는 www 사용자에 의해 실행될 수 있습니다. ps aux | grep nginx 보기: nginix.conf里面划分的运行权限就是配置到了www用户下,因此Nginx的子进程也是由www用户执行,可以通过ps aux | grep nginx来查看:

nginx, php-fpm 및 mysql에 대한 사용자 권한을 구성하는 방법

可以看到nginx的主进程是root,其余子进程均是www的用户

nginx.conf的配置:

nginx, php-fpm 및 mysql에 대한 사용자 권한을 구성하는 방법

二、php的权限配置

同样的,php的运行方式也是由主进程root运行,在子进程池(pool)里面配置由www用户执行,具体配置在php根目录下的etcphp-fpm.conf下,添加两行:

user = www
 group = www
로그인 후 복사

即可,同样用ps aux | grep php可以查看进程使用的用户身份:

nginx, php-fpm 및 mysql에 대한 사용자 권한을 구성하는 방법

三、MySQL服务的权限配置

通过ps aux | grep mysql

nginx , php-fpm 및 mysql의 사용자 권한 구성 방법

nginx, php-fpm 및 mysql에 대한 사용자 권한을 구성하는 방법nginx의 기본 프로세스는 루트이고 다른 하위 프로세스는 모두 www

nginx.conf 구성의 사용자임을 알 수 있습니다. nginx, php-fpm 및 mysql에 대한 사용자 권한을 구성하는 방법

2. PHP 권한 구성

마찬가지로 PHP는 기본 프로세스 루트에 의해 실행되며, www 사용자가 실행하도록 하위 프로세스 풀(풀)에 구성됩니다. 구체적인 구성은 etcphp에 있습니다. -fpm.conf를 PHP 루트 디렉토리에 추가하세요.

user www www;
로그인 후 복사

또한 ps aux | grep php를 사용하여 프로세스에서 사용하는 사용자 ID를 볼 수도 있습니다. 🎜 mysql 사용자로 MySQL 서비스가 실행되고 있는 것을 볼 수 있습니다. 이 서비스에서는 mysql 사용자 이름만 가져오면 됩니다. PHP 코드가 mysql에 연결될 때 비밀번호를 입력해야 합니다. 기본 데이터의 보안을 보장하기 위해 데이터 레이어를 비즈니스 로직 레이어와 격리해야 하기 때문에 www로 통합할 필요가 없습니다. mysql의 인증은 주로 새로운 사용자를 추가하고 mysql 서비스에서 권한을 나누는 것입니다. 이는 데이터 보안을 보장하기 위해 다양한 PHP 비즈니스가 다양한 권한 범위를 가진 ID와 연결하도록 제어하는 ​​데 사용됩니다. 🎜🎜🎜🎜🎜🎜🎜 IV. 요약 🎜🎜🎜nginx 구성: 🎜
user = www
group = www
로그인 후 복사
🎜php-fpm: 🎜🎜
drwxr-xr-x 就是755
로그인 후 복사
🎜디렉토리: 🎜🎜rrreee

위 내용은 nginx, php-fpm 및 mysql에 대한 사용자 권한을 구성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Navicat Premium을 만드는 방법 Navicat Premium을 만드는 방법 Apr 09, 2025 am 07:09 AM

Navicat Premium을 사용하여 데이터베이스 생성 : 데이터베이스 서버에 연결하고 연결 매개 변수를 입력하십시오. 서버를 마우스 오른쪽 버튼으로 클릭하고 데이터베이스 생성을 선택하십시오. 새 데이터베이스의 이름과 지정된 문자 세트 및 Collation의 이름을 입력하십시오. 새 데이터베이스에 연결하고 객체 브라우저에서 테이블을 만듭니다. 테이블을 마우스 오른쪽 버튼으로 클릭하고 데이터 삽입을 선택하여 데이터를 삽입하십시오.

MySQL : 쉽게 학습하기위한 간단한 개념 MySQL : 쉽게 학습하기위한 간단한 개념 Apr 10, 2025 am 09:29 AM

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) 데이터베이스 및 테이블 작성 : CreateAbase 및 CreateTable 명령을 사용하십시오. 2) 기본 작업 : 삽입, 업데이트, 삭제 및 선택. 3) 고급 운영 : 가입, 하위 쿼리 및 거래 처리. 4) 디버깅 기술 : 확인, 데이터 유형 및 권한을 확인하십시오. 5) 최적화 제안 : 인덱스 사용, 선택을 피하고 거래를 사용하십시오.

Navicat에서 MySQL에 새로운 연결을 만드는 방법 Navicat에서 MySQL에 새로운 연결을 만드는 방법 Apr 09, 2025 am 07:21 AM

응용 프로그램을 열고 새로운 연결 (Ctrl n)을 선택하여 Navicat에서 새로운 MySQL 연결을 만들 수 있습니다. "MySQL"을 연결 유형으로 선택하십시오. 호스트 이름/IP 주소, 포트, 사용자 이름 및 비밀번호를 입력하십시오. (선택 사항) 고급 옵션을 구성합니다. 연결을 저장하고 연결 이름을 입력하십시오.

PHP의 미래 : 적응 및 혁신 PHP의 미래 : 적응 및 혁신 Apr 11, 2025 am 12:01 AM

PHP의 미래는 새로운 기술 트렌드에 적응하고 혁신적인 기능을 도입함으로써 달성 될 것입니다. 1) 클라우드 컴퓨팅, 컨테이너화 및 마이크로 서비스 아키텍처에 적응, Docker 및 Kubernetes 지원; 2) 성능 및 데이터 처리 효율을 향상시키기 위해 JIT 컴파일러 및 열거 유형을 도입합니다. 3) 지속적으로 성능을 최적화하고 모범 사례를 홍보합니다.

다른 데이터베이스 시스템에서 열을 추가하기위한 구문의 차이점은 무엇입니까? 다른 데이터베이스 시스템에서 열을 추가하기위한 구문의 차이점은 무엇입니까? Apr 09, 2025 pm 02:15 PM

MySQL : MySQL : Alter Table_Name ADD CORMEN_NAME DATY_TYPE; POSTGRESQL : ALTER TABLE_NAME ADD CORMENT CORMENT CORMEN_NAME DATY_TYPE; ORACLE : ALTER TABLE_NAME ADD (column_name Data_Type); SQL 서버 : Alter Table_Name Data_name Data_name ADD

PHP vs. Python : 차이점 이해 PHP vs. Python : 차이점 이해 Apr 11, 2025 am 12:15 AM

PHP와 Python은 각각 고유 한 장점이 있으며 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1.PHP는 간단한 구문과 높은 실행 효율로 웹 개발에 적합합니다. 2. Python은 간결한 구문 및 풍부한 라이브러리를 갖춘 데이터 과학 및 기계 학습에 적합합니다.

Navicat에서 데이터베이스를 가져 오는 방법 Navicat에서 데이터베이스를 가져 오는 방법 Apr 09, 2025 am 06:27 AM

Navicat에서 데이터베이스를 가져 오는 단계에는 다음이 포함됩니다. 데이터베이스 서버에 연결하십시오. 데이터베이스 이름을 마우스 오른쪽 버튼으로 클릭하고 마법사 가져 오기를 선택하십시오. 데이터 소스 유형을 선택하십시오. 데이터 소스 설정을 지정하십시오. 데이터 파일 형식을 선택하십시오. 찾아보고 데이터 파일을 선택하십시오. 가져 오기 옵션 구성 (테이블 맵, 문자 세트, 데이터 유형). 수입 및 모니터링 진행 상황을 수행하십시오.

Navicat의 Local MySQL에 연결하는 방법 Navicat의 Local MySQL에 연결하는 방법 Apr 09, 2025 am 07:45 AM

Navicat을 사용하여 로컬 MySQL 데이터베이스에 연결하려면 : 연결을 만들고 연결 이름, 호스트, 포트, 사용자 이름 및 비밀번호를 설정하십시오. 연결을 테스트하여 매개 변수가 올바른지 확인하십시오. 연결을 저장하십시오. 연결 목록에서 새 연결을 선택하십시오. 연결하려는 데이터베이스를 두 번 클릭하십시오.

See all articles