TSSN-소프트웨어 아키텍처

이 장에서는 통신 스위칭 시스템 및 네트워크의 소프트웨어 아키텍처에 대해 알아 봅니다.

SPC 시스템의 소프트웨어는 더 나은 이해를 위해 두 가지로 분류 할 수 있습니다. System SoftwareApplication Software. 소프트웨어 아키텍처는 언어 프로세서를 포함한 SPC의 시스템 소프트웨어 환경을 다룹니다. 통화 처리와 함께 많은 기능은 운영 및 관리 기능이 수행되는 운영 체제의 일부입니다.

Call Processing은 이벤트 지향적 인 주요 처리 기능입니다. 가입자의 회선 또는 트렁크에서 발생하는 이벤트가 통화 처리를 트리거합니다. 통화 설정은 교환에서 하나의 연속 처리 순서로 수행되지 않습니다. 이 전체 프로세스는 수십 또는 수백 밀리 초 동안 지속되는 많은 기본 프로세스와 일치하며 많은 호출이 동시에 처리되며 각 호출은 별도의Process. 프로세스는program in execution, 때로는 task.

다중 프로그래밍 환경에서의 프로세스

이 섹션에서는 다중 프로그래밍 환경에서 프로세스가 무엇인지 알아 봅니다. 다중 프로그래밍 환경의 프로세스는 다음 중 하나 일 수 있습니다.

  • Running
  • Ready
  • Blocked

프로세스의 상태는 현재 활동과 실행하는 프로세스 및 상태가 겪는 전이에 의해 정의됩니다.

  • 프로세스는 running, 명령이 현재 프로세서에서 실행중인 경우.

  • 프로세스는 ready 다음 프로세스 실행 명령이 대기 중이거나 시간 초과 된 명령이있는 경우

  • 프로세스는 blocked, 진행하기 전에 어떤 이벤트가 발생하기를 기다리는 경우.

다음 그림은 실행 중, 준비 및 차단 간의 전환을 보여주는 프로세스를 나타냅니다.

일부 프로세스는 실행 중 상태에 있고 일부는 준비 상태에 있고 다른 프로세스는 차단됩니다. 준비 목록의 프로세스는 우선 순위를 따릅니다. 차단 된 프로세스는 순서가 지정되지 않으며 이벤트가 발생하기를 기다리는 순서대로 차단 해제됩니다. 프로세스가 실행되지 않고 다른 명령이나 리소스를 기다리는 경우 해당 프로세스를 준비 목록으로 푸시하여 프로세서 시간을 절약하고 우선 순위가 높을 때 차단 해제됩니다.

공정 제어 블록

프로세스 제어 블록은 운영 체제의 각 프로세스를 나타냅니다. PCB는 프로세스에 대한 다음 정보를 포함하는 데이터 구조입니다.

  • 프로세스의 현재 실행 상태

  • 준비 상태에있는 프로세스 우선 순위

  • CPU 스케줄링 매개 변수

  • 프로세스가 중단 될 때 CPU의 내용을 저장합니다.

  • 프로세스에 대한 메모리 할당

  • 번호, CPU 사용량 등과 같은 프로세스 세부 정보가 있습니다.

  • 프로세스와 관련된 이벤트 및 I / O 리소스의 상태

PCB는 CPU를받을 때 다음에 실행될 프로세스에 대한 모든 정보를 가지고 있습니다. CPU 레지스터에는Program Status Word (PSW)에는 실행할 다음 명령어의 주소, 현재 활성화 또는 비활성화 된 인터럽트 유형 등이 포함됩니다.

CPU가 일부 프로세스를 실행하는 동안 현재 실행중인 프로세스가 차단되거나 우선 순위가 높은 프로세스를 트리거하는 이벤트 또는 인터럽트가 발생하면 해당 프로세스를 전환해야합니다. 그런 상황을Process Switching라고도합니다. Context Switching. 이러한 인터럽트 우선 순위 메커니즘은 다음 그림에 설명되어 있습니다.

프로세스 A특정 가입자 회선을 스캔하여 사용 가능하다고 판단한 다음 프로세스는 해당 가입자와 통화를 설정합니다. 그러나 다른 프로세스 B가 우선 순위를 주장하고 동시에 동일한 가입자와 통화를 설정하면 두 프로세스가 동시에 동일한 가입자에게 전화를 걸어야하는데 이는 제안 할 수 없습니다. 다른 공유 테이블 및 파일에서도 유사한 문제가 발생할 수 있습니다.

교환 자원 (트렁크, 레지스터 등) 및 현재 사용률에 대한 정보는 테이블 형식으로 유지됩니다. 필요한 경우 이러한 테이블은 다른 프로세스에서 공유됩니다. 두 개 이상의 프로세스가 동시에 동일한 테이블을 선택할 때 문제가 발생합니다. 이 문제는 공유 테이블에 대한 각 프로세스에 대한 액세스 권한을 부여하여 해결할 수 있습니다.

자원 공유

프로세스가 공유 테이블 또는 공유 리소스를 사용할 때마다 동일해야하는 다른 모든 프로세스는 대기 상태로 유지됩니다. 실행중인 프로세스가 리소스 사용을 마치면 대기중인 첫 번째 우선 순위가 지정된 준비 프로세스에 할당됩니다. 이 공유 자원 사용 프로세스를Mutual Exclusion. 공유 리소스에 액세스하는 프로세스는Critical Section 또는 Critical Region. 상호 배제는 주어진 공유 리소스에 대한 모든 인스턴스의 중요 영역에 하나의 프로세스 만있을 수 있음을 의미합니다. 중요 섹션에있는 프로세스의 코딩은 무한 루프가 없도록 매우 신중하게 수행됩니다. 이것은 차단되지 않는 프로세스에 도움이됩니다. 수행 된 작업이 더 정확하고 효율적입니다. 이것은 대기중인 다른 프로세스를 돕습니다.

세마포어의 두 프로세스가 공통 리소스를 공유해야하는 경우 특정 시간 간격 동안 두 프로세스가 공유합니다. 하나는 리소스를 사용하는 동안 다른 하나는 기다립니다. 이제 기다리는 동안 다른 것과 동기화하기 위해 그때까지 작성된 작업을 읽습니다. 즉, 해당 프로세스의 상태는 0이 아니어야하며 계속 증가해야하며 그렇지 않으면 차단 목록으로 전송됩니다. 차단 목록에있는 프로세스는 서로 겹쳐지며 우선 순위에 따라 리소스를 사용할 수 있습니다.

다음 그림은 프로세스가 어떻게 작동하는지 보여줍니다-

세마포어에있는 둘 이상의 프로세스가 리소스를 무기한 대기하고 0이되지 않아 블록 상태로 돌아 가지 않는 반면 다른 프로세스는 동일한 리소스를 사용하기 위해 차단 된 상태에서 대기하고 아무도 리소스를 사용할 수는 없지만 대기하는 경우 상태는 Deadlock State.

이 기술은 교착 상태 방지, 회피, 감지 및 복구를 위해 개발되었습니다. 따라서 이들은 프로세서 스위칭을위한 운영 체제의 두드러진 특징을 다룹니다.

소프트웨어 생산

SPC 소프트웨어 생산은 긴 작업 수명과 신뢰성, 가용성 및 이식성과 함께 소프트웨어의 복잡성과 크기 때문에 중요합니다.

소프트웨어 생산은 복잡한 시스템을위한 대규모 소프트웨어의 생산 및 유지 관리에서 발생하는 문제를 다루는 소프트웨어 엔지니어링의 한 분야입니다. 소프트웨어 엔지니어링의 실무는 4 단계로 분류됩니다. 이 단계는 소프트웨어 시스템의 생산을 구성합니다.

  • 기능 사양
  • 공식적인 설명 및 상세 사양
  • 코딩 및 검증
  • 테스트 및 디버깅

스위칭 시스템의 응용 소프트웨어는 호 처리 소프트웨어, 관리 소프트웨어 및 유지 관리 소프트웨어로 나눌 수 있습니다. 스위칭 시스템의 애플리케이션 소프트웨어 패키지는 모듈 식 구성을 사용합니다.

Stored Program Control의 도입으로 가입자는 새롭거나 향상된 서비스를 호스트 할 수 있습니다. 단축 다이얼링, 녹음 된 번호 통화 또는 다이얼링 없음 통화, 무료시 콜백, 착신 전환, 교환 원 응답, 통화 번호 기록, 통화 대기, 상담 보류, 회의 통화, 자동 알람, STD 차단, 악성 통화와 같은 다양한 종류의 향상된 서비스 추적 등은 모두 전화 통신의 이러한 변화와 함께 도입되었습니다.

다단계 네트워크

다단계 네트워크는 크로스바 스위칭 시스템보다 더 많은 가입자 간의 연결을 더 효율적으로 제공하도록 구축 된 네트워크입니다.

앞에서 설명한 크로스바 스위칭 네트워크에는 아래에 설명 된 몇 가지 제한 사항이 있습니다.

  • Crosspoint의 수는 연결된 스테이션 수의 제곱이므로 큰 스위치의 경우 비용이 많이 듭니다.

  • Crosspoint가 실패하면 Crosspoint가 연결된 두 가입자와의 연결이 차단됩니다.

  • 연결된 모든 장치가 활성 상태 인 경우에도 Crosspoint는 거의 사용되지 않습니다.

이러한 단점을 보완 할 해결책을 찾기 위해 다단 공간 분할 스위치가 구축되었습니다. 크로스바 스위치를 더 작은 단위로 분할하고 상호 연결함으로써 더 적은 수의 크로스 포인트로 다단계 스위치를 구축 할 수 있습니다. 다음 그림은 다단계 스위치의 예를 보여줍니다.

위와 같은 다단계 스위치는 크로스바 스위칭에 필요한 것보다 적은 수의 크로스 포인트를 필요로합니다. 위의 예에 따르면 8 (입력) 및 8 (출력) 다양한 가입자 (호출 및 호출 가입자 모두)에 대해 일반 크로스바 네트워크에서 필요한 Crosspoint는 64 인 제곱이됩니다. 다단계 크로스바 네트워크, 40 개의 크로스 포인트만으로 충분합니다. 이것은 위의 다이어그램에 표시된 것과 같습니다. 대형 다단계 크로스바 스위치에서는 감소가 더 중요합니다.

다단계 네트워크의 장점

다단계 네트워크의 장점은 다음과 같습니다.

  • 크로스바의 수가 감소합니다.
  • 연결 경로의 수는 더 많을 수 있습니다.

다단계 네트워크의 단점

다단계 네트워크의 단점은 다음과 같습니다.

  • 다단계 스위치로 인해 Blocking.

  • 중간 스위치의 수나 크기를 늘리면이 문제를 해결할 수 있지만 이에 따라 비용이 증가합니다.

블로킹

차단은 교차점 수를 줄입니다. 다음 다이어그램은 더 나은 방법으로 차단을 이해하는 데 도움이됩니다.

4 개의 입력과 2 개의 출력이있는 위 그림에서 가입자 1은 라인 3에 연결되고 가입자 2는 라인 4에 연결되었습니다. 빨간색 선은 연결을 나타냅니다. 그러나 더 많은 요청이 올 것입니다. 호출을 설정할 수 없으므로 가입자 3 및 가입자 4의 호출 요청을 처리 할 수 ​​없습니다.

위의 다이어그램에 표시된 것처럼 위 블록의 구독자도 동일한 문제에 직면합니다. 한 번에 두 개의 블록 만 연결할 수 있습니다. 두 개 이상의 입력 또는 모든 입력을 연결할 수 없습니다 (존재하는 출력 수에 따라 다름). 따라서 여러 연결을 동시에 설정할 수 없으며 이는 통화가 차단되는 것으로 이해됩니다.