최근 프로젝트 디플로이를 하다가 사진과 같은 문제가 발생했습니다
일반 로그인 인터페이스로는 접근이 가능하지만, 로그인 후 접속 후 주소에서 404에러가 발생한다고 해서 확인하러 갔습니다. 구성 오류가 있었지만 확인 결과 nginx.conf 및 config.js 두 구성 파일의 IP와 포트가 올바른 것으로 나타났습니다.
이 프로젝트는 여러 번 배포되었으며 이러한 오류는 없습니다. 발생했습니다.
이것은 손길이 닿지 않은 원래의 압축 해제된 nginx.conf 소스 파일입니다.
원으로 표시된 영역은 프로젝트 구성에 따라 구성되어야 하는 ip 및 청취 포트
listen에 해당합니다. 포트, server_name은 액세스한 ip
에 해당합니다. 하지만 문제가 해결되지는 않습니다. 다음 문장을 추가해야 합니다.
try_files $uri $uri/ /index.html;추가된 위치는 여기여야 합니다
에 추가합니다. server 아래의 location 섹션에 nginx.exe가 있는 디렉터리에서 cmd
를 입력하면 바로 해당 디렉터리에 액세스할 수 있습니다. cmd를 열지 않고 명령줄을 실행한 다음 해당 디렉터리로 이동합니다.이전에 nginx 서비스를 종료한 적이 없다면 중지한 후 다시 엽니다. 종료된 경우 직접 명령을 입력하여 서비스를 시작할 수 있습니다.
nginx 서비스 중지 명령:
nginx -s stop
nginx 서비스 시작 명령:
start nginx
핫 배포 nignx 서비스 명령:
(그러나 이 명령을 사용하는 것은 권장되지 않습니다. 때때로 이 명령이 작동하지 않을 경우 직접 중지하고 시작하는 것이 좋습니다)
nginx -s reloadnginx를 다시 시작한 후 브라우저가 가장 좋습니다
캐시를 지운 후, 다시 테스트하세요
브라우저 창에서 직접Ctrl+Shift+Del
을 눌러 대화 상자를 열어 캐시를 지울 수 있습니다.보충: Nginx 배포 후 정상적인 클릭에는 문제가 없습니다. 프로젝트가 서버에 배포된 후 404 문제가 발생합니다. 루트 경로 액세스(http:10.10.10.10)에는 문제가 없지만,다시 테스트하면 정상적으로 액세스할 수 있습니다
http:10.10.10.10/test/test/test와 같은 다른 기능을 입력하고 페이지를 새로 고치면 404가 나타납니다. nginx 구성에 리디렉션 점프를 추가하지 않았기 때문에 페이지를 새로 고칩니다.
해결책은 다음 구성을 추가하는 것입니다. try_files $uri $uri/ /index.html;
server { listen 80; server_name 127.0.0.1; location / { root /data/htdocs/FactoryModel/micro-front-end/industrial-internet-platform-main-vue; index index.php index.html index.htm; # add_header Cache-Control; add_header Access-Control-Allow-Origin *; if ( $request_uri ~* ^.+.(js|css|jpg|png|gif|tif|dpg|jpeg|eot|svg|ttf|woff|json|mp4|rmvb|rm|wmv|avi|3gp)$ ){ add_header Cache-Control max-age=7776000; add_header Access-Control-Allow-Origin *; } try_files $uri $uri/ /index.html; } }
이 구성은 URL 경로와 일치할 때 해당 정적 리소스를 찾을 수 없을 때마다 변조가 Go를 점프한다는 것을 의미합니다. index.html 파일에
표시된 대로 여기에 추가하세요
다음 콘텐츠에는 라우터 라우팅의 작동 원리와 nginx 원리에 대한 약간의 지식이 필요합니다
이런 일이 발생하는 이유에 대한 분석(기록 모드에서 라우팅의 경우):
먼저 질문하세요:
1. 페이지 새로고침이 발생하는 이유(구성 없이 홈페이지 루트 디렉토리에서 새로고침되지 않음)2. 점프를 클릭할 때 왜 발생합니까?
이제 문제를 해결해 보겠습니다. : 1. 현재 브라우저에 있다고 가정합니다. 브라우저의 URL은 172.1.2.3:7000/test입니다. 페이지가 새로 고쳐지면 서버(nginx)로 이동하여 해당 정적 리소스를 요청합니다. nginx는 위치 일치 규칙에 따라 dist 폴더에 해당 URL을 가지고 있지 않습니다. / 해당 정적 파일 "test"가 발견되었으므로 404가 반환되며 이는 합리적입니다.1. 푸시는 페이지를 새로 고치지 않고 브라우저의 URL 라우팅 변경만 변경합니다. 구현은 HTML API를 사용합니다. pushState()라고 합니다이 때, index.html 파일로 다시 리디렉션되도록 try_files를 구성합니다. 즉, 홈 페이지 "/"로 돌아갑니다. 이때 페이지가 새로 고쳐졌습니다. vue-router 라우팅이 적용됩니다. 현재 URL 주소에 따라 컴포넌트가 일치하므로 이때 해당 컴포넌트는 URL이고 페이지가 다시 로드되면 완료됩니다.
2. 두 번째 질문은 클릭하면 가끔 점프하지만 가끔은 점프하지 않는 이유입니다. 점프에는 두 가지 상황이 있다는 것을 알아야 합니다. 하나는 페이지가 새로 고쳐지는 것이고(첫 번째 질문에 속함), 다른 하나는 페이지가 새로 고쳐지는 것입니다. 새로고침되지 않습니다. 이는 코드 작성 방법에 따라 다릅니다.
2. 전달하면 페이지가 새로 고쳐지며 이는 a 태그와 동일합니다
브라우저에서 직접 시도해 볼 수 있습니다
클릭하여 점프할 때 코드에서 Push를 사용하는 경우가 있습니다. (새로 고침 없음), 때로는 링크(새로 고침) 태그를 사용하면 이 문제가 발생합니다.
위 내용은 Nginx 404 오류를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

NginxUnit의 목적은 웹 응용 프로그램의 배포 및 관리를 단순화하는 것입니다. 장점은 다음과 같습니다. 1) Python, PHP, Go, Java 및 Node.js와 같은 여러 프로그래밍 언어를 지원합니다. 2) 동적 구성 및 자동 재 장전 기능을 제공합니다. 3) 통합 API를 통해 응용 프로그램 수명주기를 관리합니다. 4) 고 동시성 및 하중 밸런싱을 지원하기 위해 비동기 I/O 모델을 채택하십시오.

Nginx는 2002 년에 시작하여 Igorsysoev가 C10K 문제를 해결하기 위해 개발했습니다. 1.NGINX는 고성능 웹 서버, 이벤트 중심의 비동기 아키텍처로 높은 동시성에 적합합니다. 2. 리버스 프록시,로드 밸런싱 및 캐싱과 같은 고급 기능을 제공하여 시스템 성능 및 신뢰성을 향상시킵니다. 3. 최적화 기술에는 HTTP/2 및 보안 구성을 사용하여 작업자 프로세스 수 조정, GZIP 압축 가능성이 포함됩니다.

Nginx와 Apache의 주요 아키텍처 차이점은 Nginx가 이벤트 중심의 비동기 비 블로킹 모델을 채택하는 반면 Apache는 프로세스 또는 스레드 모델을 사용한다는 것입니다. 1) NGINX는 이벤트 루프 및 I/O 멀티플렉싱 메커니즘을 통해 고유 한 연결을 효율적으로 처리하며, 정적 컨텐츠 및 리버스 프록시에 적합합니다. 2) Apache는 다중 프로세스 또는 다중 스레드 모델을 채택하는데,이 모델은 매우 안정적이지만 자원 소비가 높으며 풍부한 모듈 확장이 필요한 시나리오에 적합합니다.

Nginx는 동시 및 정적 컨텐츠가 높은 반면 Apache는 복잡한 구성 및 동적 컨텐츠에 적합합니다. 1. Nginx는 교통량이 많은 시나리오에 적합한 동시 연결을 효율적으로 처리하지만 동적 컨텐츠를 처리 할 때 추가 구성이 필요합니다. 2. Apache는 복잡한 요구에 적합하지만 동시성 성능이 좋지 않은 풍부한 모듈과 유연한 구성을 제공합니다.

Nginx와 Apache는 각각 고유 한 장점과 단점이 있으며 선택은 특정 요구에 기초해야합니다. 1.NGINX는 비동기 비 블로킹 아키텍처로 인해 높은 동시 시나리오에 적합합니다. 2. Apache는 모듈 식 설계로 인해 복잡한 구성이 필요한 저소성 시나리오에 적합합니다.

NginXunit은 여러 프로그래밍 언어를 지원하고 동적 구성, 제로 다운 타임 업데이트 및 내장로드 밸런싱과 같은 기능을 제공하는 오픈 소스 응용 프로그램 서버입니다. 1. 동적 구성 : 다시 시작하지 않고 구성을 수정할 수 있습니다. 2. 다국어 지원 : Python, Go, Java, PHP 등과 호환됩니다. 3. 제로 다운 타임 업데이트 : 서비스를 중단하지 않는 응용 프로그램 업데이트를 지원합니다. 4. 내장로드 밸런싱 : 요청을 여러 응용 프로그램 인스턴스에 배포 할 수 있습니다.

NginxUnit은 다국어 프로젝트 및 동적 구성 요구 사항에 적합한 Apachetomcat, Gunicorn 및 Node.js 내장 HTTP 서버보다 낫습니다. 1) 여러 프로그래밍 언어를 지원하고, 2) 동적 구성 재 장전을 제공합니다. 3) 확장 성과 신뢰성이 높은 프로젝트에 적합한 내장로드 밸런싱 기능.

NginxUnit은 모듈 식 아키텍처 및 동적 재구성 기능으로 응용 프로그램 성능 및 관리 가능성을 향상시킵니다. 1) 모듈 식 설계에는 마스터 프로세스, 라우터 및 응용 프로그램 프로세스가 포함되어 효율적인 관리 및 확장을 지원합니다. 2) 동적 재구성을 통해 CI/CD 환경에 적합한 런타임시 구성을 완벽하게 업데이트 할 수 있습니다. 3) 다국어 지원은 언어 런타임의 동적로드를 통해 구현되어 개발 유연성을 향상시킵니다. 4) 고성능은 이벤트 중심 모델과 비동기 I/O를 통해 달성되며 높은 동시성에서도 효율적으로 유지됩니다. 5) 응용 프로그램 프로세스를 분리하고 응용 프로그램 간의 상호 영향을 줄임으로써 보안이 향상됩니다.


핫 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 애플리케이션 서버와 통합합니다.

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

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