찾다
PHP 프레임워크Laravel호스트 파일 구성 오류로 인해 애플리케이션 지연이 발생함(Laravel-Sail 개발 환경)

튜토리얼 칼럼에서 소개합니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다! 오늘은 프로젝트의 소스 코드를 풀고 새로운 Laravel-Sail 개발 환경을 사용했습니다. 이전 Homestead 개발 환경은 이제 백업일 뿐입니다. 처음에는 종속성 설치, 컨테이너 시작 및 데이터 마이그레이션을 포함하여 모든 것이 순조롭게 진행되었습니다. 그런 다음 개발 도메인 이름을 호스트 파일에 구성했습니다.

127.0.0.1 devocus.test
브라우저를 열고 다음을 방문하세요. http://devocus .test: 8016, 모든 것이 잘 진행되고 있다고 생각했지만 페이지가 항상 로드되고 전체 인터페이스가 로드되는 데 거의 30초가 걸리는 것을 발견했으며 다른 여러 프로젝트와도 혼란스러웠습니다. 사용되는 Laravel-Sail 개발 환경은 거의 항상 몇 초 안에 시작됩니다.

그런 다음 브라우저 개발자 도구를 열었고 모든 요청이 30초 이상 걸리는 것을 발견했습니다. 파일 IO 문제가 발생했나요? 하지만 내 프로젝트는 Ubuntu 하위 시스템에 배치됩니다. 네트워크 문제인가요? 다른 항목은 완전히 정상입니다. 파일 권한 변경, 래더 닫기, 컨테이너 삭제 및 재생성 등 가능한 모든 솔루션을 시도했지만 소용이 없었습니다.

그래서 Telescope를 설치하고 각 요청의 세부 사항을 확인했습니다. Telescope를 여는 것도 매우 느렸고 약 1분 정도 기다렸다가 마침내 Telescope 인터페이스가 로드되었습니다. 그러나 쿼리 결과는 매우 놀랐습니다. http://devocus.test:8016,本以为一切顺利,但是却发现页面一直处于加载状态,隔了差不多 30 秒才将完整的界面加载出来,我百思不得其解,其他几个项目我都是用的 Laravel-Sail 开发环境,几乎都是秒开,这个项目是肿么了?

然后我打开浏览器开发者工具,发现所有的请求都需要 30 秒以上,难道遇到了文件 IO 问题?但是我项目是放在 Ubuntu 子系统中的呀。网络问题?那其他几个项目又完全正常呀。我尝试着各种可能的解决办法,改文件权限、关闭ladder、删除并重新创建容器等等,一顿折腾下来,毫无结果。

于是安装了 Telescope,查看每个请求的详细情况,打开 Telescope 速度也非常慢,我等待了大概一分钟,Telescope 的界面终于加载出来了。但是查询结果令我非常意外:

记一次 hosts 文件配置错误导致的应用卡顿问题

Telescope 显示,每个请求的处理速度都很快,数据查询也很快,我佛了…

于是找同事的电脑试一下,开发环境都是 Laravel-Sail 没想到他的电脑上访问也同样十分缓慢,这直接将我们的思维引导到 “项目代码有问题” 这个方向上,于是我花了一上午时间仔细对比检查各种配置文件、env文件,升级了 laravel 以及各种依赖的版本。但是当我每次满怀期待的在浏览器打开应用时,还是卡的让我怀疑人生,而且日志记录一切正常。然后使用搜索引擎尝试搜索这个问题的解决方案,中文搜索、英文搜索都没有结果。一个上午过去了,还是没有搞定这个问题,甚至一股绝望感涌上心头。

最后还是决定去吃午饭,先让自己放松下来。吃完饭回来的路上,我又一次思考这个问题,脑袋里各种搜索出来的答案一条一条闪过,突然一个单词从我眼前“飞过”:hosts
回到工位上我打开电脑,想着先用 ip 直接访问应用看看情况,于是在浏览器输入http://127.0.0.1:8016,界面被急速打开,我大概有点眉目了,于是打开 hosts 文件,想着换个域名试试:

# 127.0.0.1 devocus.test
127.0.0.1 ifocus-dev.test

然后打开浏览器,输入http://ifocus-dev.test:8016,应用被快速打开,非常流畅,问题就这样莫名其妙的解决了。
但是问题出在哪里呢?我再次打开 hosts 文件,仔细检查,发现之前做过的同一个域名的解析静静地躺在 hosts 文件里面,我将开发环境由 Homestead 迁移到 Laravel-Sail时,忘记修改 hosts 文件了:

...
192.168.10.10 devocus.test
...
# 127.0.0.1 devocus.test
127.0.0.1 ifocus-dev.test

在 hosts 文件中,同一个域名解析到两个 ip 会发生什么情况呢?我去搜索引擎上搜索了一下,找到了答案:

电脑在hosts文件中是由上往下查找 IP,相同的域名取第一个 IP,如果第一个IP受阻,那么会转向第二个IP,乃至第N个,但是这种方式达不到负载均衡的效果,但可以增大打开网站的几率。

由于我将 devocus.test解析到了两个IP地址:192.168.10.10 及127.0.0.1,当我在浏览器中打开http://devocus.test

호스트 파일 구성 기억하기 error 🎜🎜Telescope로 인한 애플리케이션 지연으로 인해 각 요청의 처리 속도가 매우 빠른 것으로 나타났으며, 데이터 쿼리도 매우 빠릅니다. 놀랐습니다...🎜🎜그래서 동료 컴퓨터에서 시도해 보았습니다. 개발 환경은 라라벨(Laravel)이었습니다. Sail은 자신의 컴퓨터에서 접속 속도도 매우 느리다고는 예상하지 못했고, 이는 바로 "프로젝트 코드에 문제가 있습니다"라는 방향으로 우리의 생각을 이끌었기 때문에 오전 내내 신중하게 비교하고 검토했습니다. 다양한 구성 파일, env 파일 확인, Laravel 및 다양한 종속 버전 업그레이드. 하지만 큰 기대를 안고 브라우저에서 애플리케이션을 열 때마다 여전히 멈춰서 내 삶을 의심하게 만들고 로그 기록은 모두 정상입니다. 그런 다음 검색 엔진을 사용하여 이 문제에 대한 해결책을 검색해 보세요. 중국어나 영어로 검색해도 결과가 없습니다. 아침이 지나도 나는 여전히 이 문제를 해결하지 못했고 절망감마저 들었습니다. 🎜🎜마침내 먼저 긴장을 풀기 위해 점심 먹으러 가기로 결정했습니다. 저녁 식사를 마치고 돌아오는 길에 나는 이 질문에 대해 다시 생각했다. 머릿속에서 검색했던 여러 가지 대답이 하나 둘 번쩍이더니 갑자기 내 눈앞에 hosts라는 단어가 떠올랐다.
워크 스테이션으로 돌아와서 컴퓨터를 켜고 상황을 확인하기 위해 IP를 사용하여 애플리케이션에 직접 접속할 생각이 있어서 http://127.0.0.1:8016을 입력했습니다. 브라우저가 열리자 인터페이스가 빠르게 표시되었습니다. 조금 혼란스러울 수도 있어서 호스트 파일을 열고 다른 도메인 이름을 시도해 볼 생각을 했습니다: 🎜rrreee🎜 그런 다음 브라우저를 열고 http:/를 입력했습니다. /ifocus-dev.test:8016, 그리고 응용 프로그램은 빠르고 원활하게 열리며 문제는 설명할 수 없이 해결되었습니다.
근데 뭐가 문제인가요? 다시 호스트 파일을 열어서 자세히 확인해 보니 이전에 했던 것과 동일한 도메인 이름의 해결이 호스트 파일에 조용히 누워 있는 것을 발견했습니다. 호스트 파일: 🎜rrreee🎜 호스트 파일에서 동일한 도메인 이름이 두 개의 IP로 확인되면 어떻게 되나요? 검색엔진에 검색해서 답을 찾았습니다. 🎜
🎜 컴퓨터는 호스트 파일에서 위에서 아래로 IP를 검색합니다. 동일한 도메인 이름에 대해 첫 번째 IP가 차단되면 다음입니다. 두 번째 IP로 전환하거나 심지어 N번째 IP로 전환하게 됩니다. 그러나 이 방법은 로드 밸런싱 효과를 얻을 수는 없지만 웹 사이트를 열 확률을 높일 수 있습니다. 🎜
🎜 http://devocus를 열 때 devocus.test를 두 개의 IP 주소(192.168.10.10 및 127.0.0.1)로 구문 분석했기 때문입니다. , 처음에 192.168.10.10 에 접속했는데 홈스테드가 닫혀있어서 접속이 안됐나봐요. 이 과정이 30초 정도 지속됐고, 이후 시스템은 계속해서 호스트 파일에서 다른 IP를 찾아 접속했습니다. 웹페이지는 127.0.0.1에서만 열렸습니다. 모든 요청이 이런 과정을 거쳐야 하기 때문에 시스템이 많이 정체된 느낌이 듭니다. 이 시점에서 제가 고민했던 문제가 해결되었습니다. 🎜

그래서 다들 프로젝트를 개발할 때 이러한 미묘한 문제에 더 주의를 기울여야 합니다. 나처럼 독선적인 베테랑도 작은 문제로 인해 큰 문제가 발생할 수 있습니다. 소프트웨어 산업은 정말 끊임없이 구덩이를 밟고, 구덩이를 파고, 구덩이를 채워야 하는 실용적인 산업입니다.

근데 생각해보니 당시 홈스테드 환경이 열려 있었다면 더욱 고민이 되었을 것 같아요. ㅋㅋㅋ                      

위 내용은 호스트 파일 구성 오류로 인해 애플리케이션 지연이 발생함(Laravel-Sail 개발 환경)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 learnku에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Laravel In Action : 실제 응용 프로그램 및 예제Laravel In Action : 실제 응용 프로그램 및 예제Apr 16, 2025 am 12:02 AM

laravelcanbeefectically-Worldapplicationsforlybuildingscaleberquentorm.2) laravel'secosystem, Enhancesdevelopment.3) eTaddressespesperformance를 포함하여

Laravel의 주요 기능 : 백엔드 개발Laravel의 주요 기능 : 백엔드 개발Apr 15, 2025 am 12:14 AM

백엔드 개발에서 Laravel의 핵심 기능에는 라우팅 시스템, eloquentorm, 마이그레이션 기능, 캐시 시스템 및 큐 시스템이 포함됩니다. 1. 라우팅 시스템은 URL 매핑을 단순화하고 코드 구성 및 유지 보수를 향상시킵니다. 2. ELOQUENTORM은 객체 지향 데이터 작업을 제공하여 개발 효율성을 향상시킵니다. 3. 마이그레이션 함수는 버전 제어를 통해 데이터베이스 구조를 관리하여 일관성을 보장합니다. 4. 캐시 시스템은 데이터베이스 쿼리를 줄이고 응답 속도를 향상시킵니다. 5. 큐 시스템은 대규모 데이터를 효과적으로 처리하고, 사용자 요청을 차단하지 않으며, 전반적인 성능을 향상시킵니다.

Laravel의 백엔드 기능 : 데이터베이스, 논리 등Laravel의 백엔드 기능 : 데이터베이스, 논리 등Apr 14, 2025 am 12:04 AM

Laravel은 백엔드 개발에서 강력하게 수행되며 Eloquentorm, 컨트롤러 및 서비스 클래스를 통해 데이터베이스 작업을 단순화하고 대기열, 이벤트 및 기타 기능을 제공합니다. 1) Eloquentorm은 쿼리를 단순화하기 위해 모델을 통해 데이터베이스 테이블을 맵핑합니다. 2) 비즈니스 로직은 모듈성 및 유지 관리를 향상시키기 위해 컨트롤러 및 서비스 클래스에서 처리됩니다. 3) 큐 시스템과 같은 다른 기능은 복잡한 요구를 처리하는 데 도움이됩니다.

Laravel의 다양성 : 간단한 사이트에서 복잡한 시스템에 이르기까지Laravel의 다양성 : 간단한 사이트에서 복잡한 시스템에 이르기까지Apr 13, 2025 am 12:13 AM

Laravel Development Project는 다양한 크기와 복잡성의 요구에 맞게 유연성과 힘으로 인해 선정되었습니다. Laravel은 간단한 블로그에서 복잡한 엔터프라이즈 수준 시스템에 이르기까지 라우팅 시스템, Eloquentorm, Artisan Command Line 및 기타 기능을 제공합니다.

Laravel (PHP) vs. Python : 개발 환경 및 생태계Laravel (PHP) vs. Python : 개발 환경 및 생태계Apr 12, 2025 am 12:10 AM

개발 환경과 생태계에서 Laravel과 Python의 비교는 다음과 같습니다. 1. Laravel의 개발 환경은 간단하며 PHP와 작곡가 만 필요합니다. Laravelforge와 같은 풍부한 확장 패키지를 제공하지만 확장 패키지 유지 보수는시기 적절하지 않을 수 있습니다. 2. 파이썬의 개발 환경도 간단하며 파이썬과 PIP 만 필요합니다. 생태계는 거대하고 여러 분야를 다루지 만 버전 및 종속성 관리는 복잡 할 수 있습니다.

Laravel 및 백엔드 : 파워링 웹 응용 프로그램 논리Laravel 및 백엔드 : 파워링 웹 응용 프로그램 논리Apr 11, 2025 am 11:29 AM

Laravel은 백엔드 논리에서 어떻게 중요한 역할을합니까? 라우팅 시스템, eloquentorm, 인증 및 승인, 이벤트 및 청취자, 성능 최적화를 통해 백엔드 개발을 단순화하고 향상시킵니다. 1. 라우팅 시스템은 URL 구조의 정의 및 요청 처리 로직을 정의 할 수 있습니다. 2. eloquentorm은 데이터베이스 상호 작용을 단순화합니다. 3. 인증 및 인증 시스템은 사용자 관리에 편리합니다. 4. 이벤트와 리스너는 느슨하게 결합 된 코드 구조를 구현합니다. 5. 성능 최적화는 캐싱 및 대기열을 통한 응용 프로그램 효율성을 향상시킵니다.

Laravel이 왜 그렇게 인기가 있습니까?Laravel이 왜 그렇게 인기가 있습니까?Apr 02, 2025 pm 02:16 PM

Laravel의 인기에는 단순화 된 개발 프로세스, 쾌적한 개발 환경 및 풍부한 기능이 포함됩니다. 1) PHP의 유연성을 결합하여 Rubyonrails의 설계 철학을 흡수합니다. 2) 개발 효율성을 향상시키기 위해 Eloquentorm, Blade Template Engine 등과 같은 도구를 제공하십시오. 3) MVC 아키텍처 및 종속성 주입 메커니즘은 코드를보다 모듈화적이고 테스트 가능하게 만듭니다. 4) 캐싱 시스템 및 모범 사례와 같은 강력한 디버깅 도구 및 성능 최적화 방법을 제공합니다.

어느 것이 더 낫습니까, 장고 또는 라벨?어느 것이 더 낫습니까, 장고 또는 라벨?Mar 28, 2025 am 10:41 AM

Django와 Laravel은 모두 풀 스택 프레임 워크입니다. Django는 Python 개발자 및 복잡한 비즈니스 논리에 적합한 반면 Laravel은 PHP 개발자 및 우아한 구문에 적합합니다. 1. Django는 파이썬을 기반으로하며 빠른 개발 및 높은 동시성에 적합한 "배터리 완성"철학을 따릅니다. 2. Laravel은 PHP를 기반으로하며 개발자 경험을 강조하며 중소형 프로젝트에 적합합니다.

See all articles

핫 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. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구