>백엔드 개발 >PHP 튜토리얼 >Symfony 모니터링 라이브러리 구현

Symfony 모니터링 라이브러리 구현

Linda Hamilton
Linda Hamilton원래의
2024-12-08 16:52:11836검색

지난 몇 달 동안 저는 Symfony 개발자의 모니터링 경험을 혁신하기 위해 많은 노력을 기울였습니다. Symfony 모니터링 라이브러리는 Inspector 고객들 사이에서 두 번째로 인기 있는 라이브러리입니다. 첫 번째는 Laravel 패키지입니다.

최신 버전의 프레임워크 출시로 앱 모니터링 환경을 이전보다 훨씬 쉽게 만들 수 있는 기회가 생겼습니다.

이 기사에서는 이러한 변경 사항이 무엇인지, 그리고 Inspector의 모니터링 경험에 미치는 영향에 대해 자세히 설명하겠습니다.

더 많은 기술 관련 기사를 보려면 Linkedin이나 X에서 저를 팔로우하세요.

교리 3.x와의 호환성

Symfony에서 가장 중요한 ORM의 최신 메이저 버전이 올해 초 출시되었습니다. 그리고 새로운 "미들웨어 아키텍처"를 위해 SQL 로거에 대한 지원을 중단했습니다.

우리는 애플리케이션이 그에 따라 SQL 로거 또는 미들웨어를 삽입하기 위해 사용하는 Doctrine 버전을 확인하기 위해 번들 내부에 검사를 구현했습니다.

경로 이름 수집

Symfony 모니터링 라이브러리의 첫 번째 구현은 경로 이름을 사용하여 Symfony 애플리케이션에 대한 http 트래픽을 모니터링하는 것이었습니다.

Symfony monitoring library implementation

기본적으로 Symfony에서 새 경로를 구현할 때 컨트롤러 메서드의 속성을 통해 이를 선언할 수 있습니다.

Route 객체는 두 번째 매개변수로 경로 이름을 가져오므로 경로를 작성하는 대신 해당 이름을 사용하여 애플리케이션 내에서 이 경로를 참조할 수 있습니다. 이를 통해 나중에 언급된 모든 코드 줄에서 URL 패턴을 변경할 필요 없이 URL 패턴을 변경할 수 있습니다.

모니터링 라이브러리에서 그 중 하나를 무시하려면 Inspector yaml 구성 파일에 경로 이름을 나열해야 했습니다.

라이브러리의 첫 번째 버전을 구축하는 데 도움을 준 첫 번째 개발자는 실제 URL 패턴을 수집하는 방법을 찾지 못했기 때문에 작업을 차단하지 않기 위해 이 구현을 계속했습니다.

그러나 경로 이름을 사용하여 HTTP 트래픽을 모니터링하는 데에는 몇 가지 단점이 있습니다.

경로 이름 문제

먼저 경로 이름은 선택사항입니다. Symfony에서는 URL을 이름과 매핑할 필요가 없습니다. 너무 많은 개발자가 이름을 사용하지 않았기 때문에 라이브러리는 대체 데이터로 /users/12/profile과 같은 최종 경로를 수집했습니다.

더 나쁜 것은 누군가가 애플리케이션의 일부에만 이름을 사용하고 대시보드에서 혼합 형식의 트랜잭션 목록을 보았는데, 일부 엔드포인트는 경로 이름을 사용하여 모니터링되고 다른 엔드포인트는 URL이 포함된 엔드포인트를 보았습니다.

두 번째 문제는 앱의 특정 부분에서 모니터링을 끄기 위해 URL을 무시하는 기능이었습니다. Symfony 애플리케이션은 일반적으로 URL 패턴을 사용하여 분할됩니다. 개발자는 /admin/[other sub urls] 와 같은 기본 URL 아래에 모든 관리 엔드포인트를 그룹화하는 경향이 있습니다. 와일드카드를 사용하여 앱의 일부를 무시하려는 경우 이러한 자연스러운 연결(/users*)로 인해 URL을 참조할 수 있으면 더 쉬울 수 있습니다. 경로 이름에서 보다 일관된 패턴을 찾는 것이 더 까다롭습니다.

또한 경로 이름이 존재하지 않는 경우를 대비해 수집된 대체 데이터는 /users/12/profile과 같은 실제 URL이었습니다. 따라서 엔드포인트가 다른 ID로 호출될 때마다 트랜잭션 목록에 새 줄이 생성되었습니다. 모니터링 데이터에 노이즈가 너무 많이 발생합니다.

경로 패턴 수집
경로 패턴은 사용자가 호출하는 실제 URL과 다릅니다. Symfony 앱에 있는 대부분의 URL은 기본적으로 /users/{id}/profile

과 같이 매개변수화됩니다.

Symfony 컨트롤러의 일반적인 구현은 다음과 같습니다.

그리고 이것이 실제 URL 대신 거래 목록에 보고해야 하는 것입니다. 왜냐하면 ID가 변경되더라도 항상 실행되는 코드는 동일하기 때문입니다.

Symfony monitoring library implementation

이 변경으로 인해 Inspector 구성 파일에서 와일드카드 문자를 사용하여 특정 URL뿐만 아니라 앱의 전체 부분도 더 쉽게 무시할 수 있습니다.

더 많은 기술 관련 기사를 보려면 Linkedin이나 X에서 저를 팔로우하세요.

Symfony 애플리케이션을 무료로 모니터링하세요

Inspector는 소프트웨어 개발자를 위해 특별히 설계된 코드 실행 모니터링 도구입니다. 인프라에 아무것도 설치할 필요가 없습니다. Symfony 패키지만 설치하면 바로 사용할 수 있습니다.

HTTP 모니터링, 데이터베이스 쿼리 통찰력, 경고 및 알림을 선호하는 메시징 환경으로 전달하는 기능을 찾고 있다면 Inspector를 무료로 사용해 보세요. 계정을 등록하세요.

또는 웹사이트(https://inspector.dev)에서 자세히 알아보세요

Symfony monitoring library implementation

위 내용은 Symfony 모니터링 라이브러리 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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