비원시 재고 관리를 고려할 때 고려 사항

맞춤화는 가능한 한 복잡하지 않게 유지합니다.
재고 조직이 얼마나 균일한지, 1sku와 총 가용 재고량인지 또는 고려해야 하는 다른 속성이 있는지 여부.

재고 정보가 매우 일정한 경우(예: sku 및 총 가용 수량), 실시간에 가까운 옵션이 확장됩니다. 실시간에 가까운 개념은 소스에서 인벤토리를 수집한 다음 요청에 응답할 수 있도록 스토리지 엔진을 채우는 백그라운드 작업을 의미합니다. 이를 위해 Redis, Mongo 또는 기타 비관계형 데이터베이스와 같은 것을 사용할 수 있습니다. 이러한 옵션은 매우 빠르고 키/값 쌍에 적합합니다. 데이터가 좀 더 복잡한 경우 상거래 애플리케이션 내부 또는 외부에서 관계 데이터베이스를 사용해야 할 수 있습니다. 상거래 데이터베이스에서 이 항목을 오프로드함으로써 핵심 상거래 응용 프로그램을 이러한 거래에서 격리시킵니다. 또 다른 이점은 상거래 애플리케이션, CPU, RAM 등의 I/O를 사용하지 못하도록 하는 것입니다. Adobe Commerce 애플리케이션 서버의 리소스를 사용하는 대신 새 API를 사용하여 오프사이트 스토리지에서 데이터를 가져옵니다. 여기에는 모든 데이터를 변환하는 데 도움이 되는 미들웨어가 필요할 수 있습니다. 그런 다음 호출 응용 프로그램이 예상대로 결과를 얻을 수 있는지 확인합니다. API 메쉬와 함께 App Builder Adobe을 사용하면 데이터를 변환하고 적절한 형식으로 반환할 수 있습니다.

여러 인벤토리 소스가 있는 경우 API 메시와 함께 App Builder Adobe 를 사용하는 것도 좋은 옵션입니다.

실행 논리를 프로세스 외부 위치로 이동

Adobe Developer App Builder은 Adobe 솔루션을 확장하기 위해 사용자 지정 경험을 통합하고 만들기 위한 통합 타사 확장성 프레임워크를 제공합니다. Adobe Commerce은 Adobe Developer App Builder을 사용할 수 있습니다. 이는 핵심 애플리케이션에서 일반적으로 발생하는 일부 기능을 확장하고 오프사이트로 이동하는 데 유용한 사용 사례입니다. Commerce 애플리케이션에서 기능을 제거하면 Commerce 애플리케이션의 모듈 수와 복잡성이 줄어듭니다. 따라서 처리 중인 사용자 지정 횟수가 적으면 업그레이드 및 유지 관리의 복잡성이 줄어듭니다.

이를 수행하는 방법에 대한 영감을 얻기 위해 Adobe 팀은 뛰어난 영감 소스일 수 있는 몇 가지 설명서를 만들고 작업 코드 샘플을 제공합니다. 쇼핑객이 장바구니에 제품을 추가하면 서드파티 재고 관리 시스템이 해당 품목의 재고 여부를 확인합니다. 있는 경우 제품을 추가할 수 있도록 허용합니다. 그렇지 않으면 오류 메시지를 표시합니다. 코드 샘플 및 추가 정보는 Webhook 사용 사례로 이동하십시오.

인벤토리 검사 시기

인벤토리가 아직 사용 가능한지 확인하는 시점은 결국 비즈니스 이해 당사자인 소프트웨어 설계자가 다른 주요 관련자로부터 일부 정보를 제공받아 결정합니다. 몇 가지 적절한 시간에는 장바구니에 품목을 추가할 때와 체크아웃 워크플로우를 시작할 때가 포함됩니다. 다른 모든 이벤트는 필요하지 않을 경우 백엔드 시스템에 로드를 추가하기만 합니다. 가장 중요할 때만 재고 문제를 파악하는 것이 목표라는 점을 명심한다. 다른 검사를 하는 것이 좋을 수 있지만 재고 상태 검사의 전체 목표에 영향을 줄 수 있는 경우에는 비즈니스 이해 당사자나 다른 사람이 백엔드 시스템의 추가 로드에 대한 잠재적 위험을 알고 있는 경우에만 신중하게 고려하여 허용해야 합니다.

인벤토리 소스 조사

외부 재고원에 대한 종합적인 조사가 필요하다. 평가해야 하는 항목은 사용 가능한 API 옵션, GraphQL 지원 및 예상 응답 시간입니다. 인벤토리 소스에 제한된 연결 대역폭이 있거나 실시간 요청에서 사용할 의도가 없는 경우 사용 기능이 제외되므로 설계자는 대신 실시간에 가깝게 고려해야 합니다. API 요청 시간이 정의된 매개 변수를 초과하는 경우 이 역시 실행 가능한 옵션에서 제외됩니다. 예를 들어 API 응답은 한 번에 200MS®이지만 중간 로드 하에서는 500~900MS®까지 가능합니다. 이 문제는 더 많은 로드와 실시간 인벤토리 호출을 사용할 수 없도록 하는 규칙으로 인해 더 악화될 수 있습니다.

라이브 웹 사이트의 예상 트래픽과 유사한 높은 볼륨뿐만 아니라 간단한 요청으로 API 응답 시간을 테스트해야 합니다. 실제 시나리오를 시뮬레이션하려면 상업의 모든 영역을 동시에 테스트해야 합니다. 제품 페이지에서 실시간 인벤토리 호출이 예상될 경우 장바구니를 보고 편집할 때 및 체크아웃 중에 로드 테스트가 이러한 모든 작업을 동시에 시뮬레이션하여 실제 고객 동작과 스토어에 대한 예상치를 모방해야 합니다.

대체 옵션

인벤토리 소스가 다운되고 모니터링을 사용할 수 있는 경우 Adobe Commerce의 기본 기능을 사용하는 것이 좋습니다. 그러나 적절한 모니터링을 통해 실시간 인벤토리 검사의 손실을 반영하도록 고객 환경이 동적으로 변경될 수 있습니다. 이는 판매 또는 이벤트가 조기에 취소되거나 초과 판매를 방지하기 위해 디스플레이에서 제거됨을 의미할 수 있습니다. 어떤 이유로든 재고 출처가 다운되었을 때 어떻게 해야 하는지에 대한 기대는 매장 소유자와 함께 고려되고 논의되어야 하며, 그래서 모든 사람은 그러한 불행한 상황에서 접수되는 모든 자동 프로세스를 인지합니다.

결론

실시간 재고 조사를 하기로 한 결정은 중요한 것입니다. 웹 사이트 소유자, 개발 팀 및 기타 사용자가 충분한 교육을 받고 모든 이익과 잠재적인 위험을 개발자 리더 또는 설계자에게 인지하도록 합니다. 사유와 대체 프로세스를 다루는 사려 깊은 계획을 제공하는 것은 성공의 핵심입니다.

실시간 인벤토리 검사는 수행할 수 있지만 QA 주기 동안 테스트 및 유효성 검사에 대한 조사 및 고려가 필요합니다. 로드 테스트와 엔드 투 엔드 자동화된 테스트를 확인하는 것은 모든 잠재적 문제를 포착하고 평가하는 데 도움이 됩니다.

모니터링에서 외부 시스템에 대한 실패한 호출의 추세를 감지하거나 응답 시간이 허용 가능한 임계값을 초과하는 경우 수행할 작업을 고려하여 사이트를 온라인 상태로 유지하여 고객에게 가장 적은 양의 자극을 제공할 수 있습니다. 대체 옵션은 외부 인벤토리 검사를 끄고 기본 기능을 사용하는 것만큼 간단하거나, 프로모션을 사용하지 않도록 설정하여 에스컬레이션되는 문제를 개발팀에 알리거나 가능한 경우 요청을 두 번째 또는 세 번째 백엔드 시스템으로 다시 라우팅하는 것만큼 간단할 수 있습니다. 모든 통합에는 특정 시점에 문제가 있으므로 폴백 메커니즘이 어떻게 적용되는지 실제 구현으로 생각해 보십시오. 자동화되었거나 수동 작업이 필요한 모든 사항은 명확하게 문서화해야 합니다.

이전 페이지주문 상태 관리
다음 페이지회사 계정 관리

Commerce