KR101460554B1 - 닷넷리모팅 기술을 적용한 클라우드db 동기화방법 및 클라우드기반 pos시스템 - Google Patents

닷넷리모팅 기술을 적용한 클라우드db 동기화방법 및 클라우드기반 pos시스템 Download PDF

Info

Publication number
KR101460554B1
KR101460554B1 KR20130092452A KR20130092452A KR101460554B1 KR 101460554 B1 KR101460554 B1 KR 101460554B1 KR 20130092452 A KR20130092452 A KR 20130092452A KR 20130092452 A KR20130092452 A KR 20130092452A KR 101460554 B1 KR101460554 B1 KR 101460554B1
Authority
KR
South Korea
Prior art keywords
server
cloud
sector
sql
store
Prior art date
Application number
KR20130092452A
Other languages
English (en)
Inventor
조상
한태성
홍성웅
김선정
Original Assignee
청주대학교 산학협력단
(주)뉴한시스
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 청주대학교 산학협력단, (주)뉴한시스 filed Critical 청주대학교 산학협력단
Application granted granted Critical
Publication of KR101460554B1 publication Critical patent/KR101460554B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • G06F15/163Interprocessor communication
    • G06F15/173Interprocessor communication using an interconnection network, e.g. matrix, shuffle, pyramid, star, snowflake
    • G06F15/17306Intercommunication techniques
    • G06F15/17325Synchronisation; Hardware support therefor
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/27Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Databases & Information Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Computing Systems (AREA)
  • Data Mining & Analysis (AREA)
  • Mathematical Physics (AREA)
  • Software Systems (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

본 발명은 닷넷리모팅 기술에 관한 것으로, 더욱 상세하게는 서로 다른 프로세스 내의 애플리케이션 도메인 간 혹은 다른 호스트 간에 존재하는 클래스(class)를 접근(통신)하기 위한 닷넷리모팅 기술을 이용하여 클라우드DB를 동기화하는 방법 및 그 동기화방법을 활용한 클라우드기반 POS시스템에 관한 것이다.
본 발명은 DB 동기화방법은 평상시에는 인터넷을 통하여 매장의 섹터서버와 클라우드서버 간 DB 동기화작업이 이루어지는 단계와, 인터넷 장애 발생시 섹터서버에서 매장DB를 독자적으로 운용하고 클라우드서버는 클라우드DB를 독자적으로 운용하지 못하는 단계와, 인터넷 장애 복구시 섹터서버에서 클라우드서버에 자동으로 연결되어 독자적으로 운용하면서 변경한 내역을 클라우드DB에 동기화하는 단계를 포함하여 구성된다.

Description

닷넷리모팅 기술을 적용한 클라우드DB 동기화방법 및 클라우드기반 POS시스템 {Cloud DB synchronization method applied .net remoting technology and cloud-based POS system}
본 발명은 닷넷리모팅 기술에 관한 것이다.
더욱 상세하게는 서로 다른 프로세스 내의 애플리케이션 도메인 간 혹은 다른 호스트 간에 존재하는 클래스(class)를 접근(통신)하기 위한 닷넷리모팅 기술을 이용하여 클라우드DB를 동기화하는 방법 및 그 동기화방법을 활용한 클라우드기반 POS시스템에 관한 것이다.
일반적으로 POS(Point Of Sale)시스템은 판매시점의 데이터를 관리하는 시스템으로, 판매 상품에 부착된 바코드(Bar code)를 스캐닝(Scanning)하여 상품에 대한 수불을 처리하고 판매 데이터를 관리하는 POS 단말기와, 다수개의 POS 단말기와 데이터 통신망을 통해 연결되어 각 POS 단말기를 통해 수집되는 판매이력 정보 등을 포함하는 각종 데이터를 처리하는 호스트 서버로 구성된다.
상기 POS 단말기에는 수불관리, 판매관리, 매출분석 등을 처리하는 프로그램이 탑재되고, 통신망을 통해 호스트 서버와의 연동을 제공한다.
따라서, POS 단말기의 운용자는 바코드 스캐너를 통해 판매 상품에 부착된 바코드를 스캐닝하여 상품의 대금을 용이하게 계산하고, 카드 리더기를 통해 신용카드의 정보를 판독하여 네트워크로 연결되는 금융사 서버(VAN)에 결제승인을 요청함으로써, 구매 상품에 대하여 대금 정산을 실행한다.
그리고 상기한 절차를 통해 판매되는 상품에 대한 판매 정보의 분석으로 전체 판매관리 및 매출분석을 제공한다.
이러한 POS시스템은 유통과 관련된 다양한 데이터 관리 및 판매 업무에 편의성을 제공하고, 점포 내의 경영효율화, 적정 판매가격 설정, 효율적인 인력관리를 가능하게 하며, 소비자에게 정산 대기시간의 단축을 제공하고, 구매 상품의 품목이 명기된 영수증의 출력으로 신뢰성을 제고시킴으로써, 백화점이나 할인매장 등의 대형매장뿐 아니라, 편의점, 일반 소매상점 등의 다양한 장소에서 사용되고 있다.
한편, DB 시스템은 로컬(PC)에 저장하거나 웹 서버에 저장하는 방식으로 이루어진다.
로컬에 저장하는 DB 시스템은 속도가 빠르고 인터넷(네트워크)의 영향을 받지 않는 장점이 있으나 PC의 장애 발생시 데이터 안전성이 보장되지 않는 단점이 존재한다.
웹 서버에 저장하는 시스템은 데이터의 안전성이 보장되며 외부에서도 활용이 가능한 장점이 있지만 인터넷의 속도가 느리거나 장애가 발생한 경우 사용에 제한을 받는 단점이 있다.
공개번호 10-2013-0044080(2013년05월02일)
본 발명은 상술한 문제점을 해결하기 위하여 안출된 것으로서, DB를 로컬과 웹 서버 두 곳에 저장하고 닷넷리모팅 기술을 적용하여 두 DB를 동기화하고, 클라우드DB로 활용 가능한 시스템을 개발할 수 있는 닷넷리모팅 기술을 적용한 클라우드DB 동기화방법 및 클라우드기반 POS시스템을 제공하는데 그 목적이 있다.
본 발명이 제공하는 다른 목적은 로컬 내에서 DB 사용시 네트워크의 영향이 없이 빠른 속도로 사용가능하며, 로컬의 PC 장애가 발생하여도 웹 서버에 저장한 내용으로 데이터 안전성 보장 및 외부에서 데이터 활용할 수 있는 닷넷리모팅 기술을 적용한 클라우드DB 동기화방법 및 클라우드기반 POS시스템을 제공하는데 있다.
상술한 목적을 달성하기 위한 본 발명의 실시예에 따른 닷넷리모팅 기술을 적용한 클라우드DB 동기화방법은 클라우드서버, 매장의 섹터서버 간에 닷넷리모팅 기술을 적용하여 클라우드DB를 동기화하는 방법에 있어서,
클라우드서버와 섹터서버에서 각각 프로그램을 실행하여 클라우드서버와 섹터서버를 구동하는 단계;
섹터서버에서 클라우드서버에 접속을 시도하고, 클라우드서버에 접속을 허용하여 서로 네트워크 연결이 되는 단계;
사용자PC를 이용해 섹터서버나 클라우드서버에 접속하여 섹터서버의 매장DB나 클라우드서버의 클라우드DB를 조작해서 데이터를 변경, 저장하는 단계; 및
섹터서버에서 클라우드서버의 해당 매장 클라우드DB에 변경된 데이터를 동기화하고, 클라우드서버에서 해당 섹터서버의 매장DB에 변경된 데이터를 동기화하는 단계;를 포함하여 구성된다.
또한, 상술한 목적을 달성하기 위한 본 발명의 실시예에 따른 닷넷리모팅 기술을 적용한 클라우드기반 POS시스템은 각 섹터(가맹점)의 매장DB를 통합하여 관리하는 클라우드DB를 구현하고, 섹터서버와 CSP(Client Service Pos)의 접속관리를 하며, DB 동기화를 위해 Sql 동기화를 수행하는 클라우드서버;
섹터(가맹점)에서 자신의 매장DB를 관리하고, 클라우드서버로의 접속 및 CSP의 접속관리를 하며, DB 동기화를 위해 Sql 동기화를 수행하는 섹터서버;
상기 클라우드서버와 섹터서버의 연결이 끊어진 경우 섹터서버와 연동하여 기본적인 POS 시스템의 기능을 수행하고, 네트워크 연결시에 클라우드서버와 통신하여 클라우드서비스가 작동되도록 하는 CSP;
닷넷리모팅(.Net Remoting) 기술을 이용하여 클라우드기반 POS시스템 서비스를 제공하기 위한 로직으로, Sql 동기화, Sql 역동기화, CSP의 Sql 요청 처리 기능을 수행하는 클라우드로직; 및
상기 매장DB와 클라우드DB에 각각 연결하여 DB를 제어하는 DB로직;을 포함하는 것을 특징으로 한다.
상술한 과제의 해결 수단에 의하면, DB를 로컬과 웹 서버 두 곳에 저장하고 닷넷리모팅 기술을 적용하여 두 DB를 동기화하고, 클라우드DB로 활용 가능한 시스템을 개발할 수 있다.
또한, 로컬 내에서 DB 사용시 네트워크의 영향이 없이 빠른 속도로 사용가능하며, 로컬의 PC 장애가 발생하여도 웹 서버에 저장한 내용으로 데이터 안전성 보장 및 외부에서 데이터 활용할 수 있다.
도 1은 본 발명의 실시예에 따른 클라우드DB 동기화방법을 설명하기 위한 개념도이다.
도 2는 본 발명의 일실시예에 따른 클라우드DB 동기화방법의 순서도이다.
도 3은 본 발명의 다른 실시예에 따른 클라우드DB 동기화방법의 순서도이다.
도 4는 본 발명의 실시예에 따른 클라우드기반 POS시스템을 나타내는 블록도이다.
도 5는 도 4에 나타낸 클라우드기반 POS시스템의 로직을 나타내는 도면이다.
도 6a 내지 도 6f는 도 5에 나타낸 클라우드서버를 설명하기 위한 도면이다.
도 7a 내지 도 7i는 도 5에 나타낸 섹터서버를 설명하기 위한 도면이다.
도 8a 내지 도 8c는 도 5에 나타낸 클라우드로직을 설명하기 위한 도면이다.
도 9a 내지 도 9c는 도 5에 나타낸 CSP를 설명하기 위한 도면이다.
이하 본 발명의 실시예에 대하여 첨부된 도면을 참고로 그 구성 및 작용을 설명하기로 한다.
도면들 중 동일한 구성요소들에 대해서는 비록 다른 도면상에 표시되더라도 가능한 한 동일한 참조번호 및 부호들로 나타내고 있음에 유의해야 한다.
하기에서 본 발명을 설명함에 있어, 관련된 공지 기능 또는 구성에 대한 구체적인 설명이 본 발명의 요지를 불필요하게 흐릴 수 있다고 판단되는 경우에는 그 상세한 설명을 생략할 것이다.
또한, 어떤 부분이 어떤 구성요소를 "포함"한다고 할 때, 이는 특별히 반대되는 기재가 없는 한 다른 구성요소를 제외하는 것이 아니라 다른 구성요소를 더 포함할 수 있는 것을 의미한다.
도 1은 본 발명의 실시예에 따른 클라우드DB 동기화방법을 설명하기 위한 개념도이다.
도 1에 도시된 바와 같이 클라우드서버(10), 섹터서버(20) 및 사용자PC(30a,30b)를 포함하여 구성된다.
클라우드서버(10)와 매장의 섹터서버(20)는 닷넷리모팅 기술을 이용하여 인터넷을 통해 서로 접속해서 통신가능하며, 각각 독자적으로 클라우드DB(12a,12b,12c)와 매장DB(22)를 구비하여 운용하고 관리한다.
이때 클라우드DB(12a,12b,12c)는 매장DB와 일 대 일로 대응되도록 다수 개로 이루어진 통합DB이다.
사용자는 사용자PC(30a,30b)를 이용하여 인터넷을 통해 클라우드서버(10)나 섹터서버(20)에 접속해서, 그 클라우드서버(10)나 섹터서버(20)에서 운용하고 관리하는 클라우드DB(12a,12b,12c)나 매장DB(22)를 조작할 수 있다.
여기서 클라우드서버(10), 섹터서버(20) 및 사용자PC(30a,30b)의 구체적인 기능은 도 4를 참고하여 상세히 후술하고, 여기서는 클라우드DB(12a,12b,12c) 동기화방법에 대해 간단히 설명한다.
먼저, 평상시에는 인터넷을 통하여 매장의 섹터서버(20)와 클라우드서버(10) 간 DB 동기화작업이 이루어진다.
그러다가 인터넷 장애 발생시 섹터서버(20)에서 매장DB(22)를 독자적으로 운용하며, 이때 클라우드서버(10)는 클라우드DB(12a,12b,12c)를 독자적으로 운용할 수 없다.
인터넷 장애 복구시 섹터서버(20)는 클라우드서버(10)에 자동으로 연결되어 독자적으로 운용하면서 변경한 내역을 클라우드DB(12a,12b,12c)에 동기화한다.
도 2는 본 발명의 일실시예에 따른 클라우드DB 동기화방법의 순서도이다.
도 2에 도시된 바와 같이, 먼저 클라우드서버(10)와 섹터서버(20)는 각각 프로그램을 실행하여 클라우드서버(10)와 섹터서버(20)를 구동한다(S1,S2).
섹터서버(20)는 인터넷을 통해 클라우드서버(10)에 접속을 시도하고(S3), 클라우드서버(10)는 접속을 허용하여 섹터서버(20)와 클라우드서버(10) 간에 서로 데이터를 주고받을 수 있도록 연결된 상태가 된다(S4).
이와 같은 상태에서 사용자는 사용자PC(30a,30b)를 이용해 인터넷을 통해 섹터서버(20)나 클라우드서버(10)에 접속하여 매장DB(22)나 클라우드DB(12a,12b,12c)를 조작함으로써 매장DB(22)나 클라우드DB(12a,12b,12c)에 데이터를 변경하여 저장한다(S5,S5')
매장DB(22)나 클라우드DB(12a,12b,12c)에 저장된 데이터가 변경된 경우 섹터서버(20)는 클라우드서버(10)의 클라우드DB(12a,12b,12c)에 변경된 데이터를 동기화하고(S6), 클라우드서버(10)는 섹터서버(20)의 매장DB(22)에 변경된 데이터를 동기화한다(S6').
이와 같은 방식으로 평상시에는 인터넷을 통하여 매장의 섹터서버(20)와 클라우드서버(10) 간 DB 동기화작업이 이루어진다.
도 3은 본 발명의 다른 실시예에 따른 클라우드DB 동기화방법의 순서도이다.
도 3에 도시된 바와 같이, 먼저 클라우드서버(10)와 섹터서버(20)는 각각 프로그램을 실행하여 클라우드서버(10)와 섹터서버(20)를 구동한다(S11,S12).
섹터서버(20)는 인터넷을 통해 클라우드서버(10)에 접속을 시도하고(S13), 클라우드서버(10)는 접속을 허용하여 섹터서버(20)와 클라우드서버(10) 간에 서로 데이터를 주고받을 수 있도록 연결된 상태가 된다(S14).
그러다가 인터넷 장애가 발생하여 섹터서버(20)와 클라우드서버(10) 간에 연결이 끊어진 상태에서, 사용자는 사용자PC(30a,30b)를 이용해 인터넷을 통해 섹터서버(20)에 접속하여 매장DB(22)를 조작하고(S15), 섹터서버(20)는 장애 복구시 동기화를 위해 매장DB(22)에 변경된 데이터를 저장한다(S16).
사용자가 사용자PC(30a,30b)를 이용해 인터넷을 통해 클라우드서버(10)에 접속하여 클라우드DB(12a,12b,12c)를 조작하는 경우(S15'), 데이터 안전성 보장을 위해 연결이 끊어진 섹터(매장)에 대응되는 클라우드DB(12a,12b,12c)는 조작 불가능하도록 한다(S16').
인터넷 장애 발생시 매장DB(22)만 조작하여 데이터를 변경하는 중에 섹터서버(20)는 계속하여 클라우드서버(10)에 접속을 시도한다(S17).
그러다가 인터넷 장애가 복구되면 클라우드서버(10)는 섹터서버(20)의 접속을 허용하여 클라우드서버(10)와 섹터서버(20) 간에 다시 연결 상태가 된다(S18).
다음 섹터서버(20)는 클라우드서버(10)에 인터넷 장애 중에 변경한 데이터 내역을 해당 매장의 클라우드DB(12a,12b,12c)에 저장하여 복구함으로써 클라우드DB를 동기화한다(S19).
도 4는 본 발명의 실시예에 따른 클라우드기반 POS시스템을 나타내는 블록도이다.
도시된 바와 같이 클라우드서버(10), 섹터서버(20), CSP(40)를 포함하여 구성된다.
클라우드서버(10)는 각 매장(가맹점)의 통합DB(클라우드DB)(12a,12b,12c)를 구현하고, 접속된 섹터서버(20) 및 CSP(Client Service Pos)(40) 정보를 저장한다.
CSP(40)는 연결된 섹터서버(20)에 동일한 매장DB(22)를 구현하고, 섹터서버(20)와 클라우드서버(10) 어디든 접속하여 작업할 수 있다.
인터넷 장애가 발생하여 클라우드서버(10)와의 연결이 끊어졌을 경우 섹터서버(20)는 각 매장(가맹점) 단위로 CSP(40)가 기본적인 POS 시스템의 기능을 수행하도록 하며, 인터넷 장애가 복구되어 연결시에 클라우드서버(10)와 통신하여 데이터 동기화(Data Sync) 기능을 수행한다.
도 5는 도 4에 나타낸 클라우드기반 POS시스템의 로직을 나타내는 도면으로서, 상기한 클라우드서버(10), 섹터서버(20), CSP(40) 이외에 DB로직(50) 및 클라우드로직(60)을 더 포함하여 구성된다.
또한, 클라우드서버(10), 섹터서버(20), CSP(30)에도 기능을 수행하기 위한 로직이 구비된다.
아래의 표 1은 도 5에 나타낸 데이터 스트럭트(Struct) 클래스(Class)를 정의한다.
Figure 112013070638619-pat00001
이하 도 4 및 도 5를 참고로 각 구성의 기능을 설명하면 다음과 같다.
먼저, 클라우드서버(10)는 각 섹터(가맹점)의 매장DB(22)를 통합하여 관리하는 클라우드DB(12a,12b,12c)를 구현하고, 각 섹터서버(20)와 CSP(40)의 접속관리를 해준다.
이 클라우드서버(10)의 기능은 크게 접속관리와, Sql 동기화이다.
상기 Sql(Structureed Query Language)은 관계형 DB에 특정 질의를 하여 DB에서 원하는 결과를 받을 수 있도록 하는 언어이다.
첫째 접속관리 기능에서 상기 접속관리의 대상은 가맹점의 섹터서버(20)와 CSP(40)가 되며 ID와 비밀번호를 전달받아 데이터베이스에서 사용자가 맞는지 인증을 한 뒤, 결과를 알려주고 접속 내역을 저장한다.
또한, 접속한 섹터서버(20)와 CSP(30)를 따로 관리하며, CSP(40)의 경우 CSP(40)가 속한 섹터서버(20)의 현재 접속 여부를 판단하여 접속되어 있는 경우에만 접속을 허용함으로써 데이터 안전성을 보장한다.
둘째 Sql 동기화 기능은 정상상태에서 CSP(40)의 작업 요청을 처리하며 섹터서버(20)의 매장DB(22)와 클라우드서버(10)의 통합DB인 클라우드DB(12a,12b,12c)의 동기화 상태를 유지하는 기능이다.
이때 클라우드서버(10)에서 Sql 동기화 기능은 섹터서버(20)에서 Sql 요청을 하는 것과 클라우드서버(10)에 접속한 CSP(40)에서 Sql을 요청한 것으로 나뉘는데, 섹터서버(20)에서 요청하는 경우는 섹터서버(20)에서 Sql을 처리한 순서대로 요청을 받으므로 요청받은 순서대로 해당 매장의 클라우드DB(12a,12b,12c)에 적용하여 섹터서버(20)의 매장DB(22)와 동일한 상태로 유지시켜주고, CSP(40)에서 요청하는 경우는 섹터서버(20)로 역동기화 요청을 보내서 섹터서버(20)에서 Sql 적용 순서를 맞추도록 한다.
섹터서버(20)는 섹터(가맹점)에서 자신의 매장DB(22)를 관리하고, 클라우드서버(10) 접속 및 CSP(40)의 접속관리를 해준다.
이 섹터서버(20)의 기능도 크게 접속관리와 Sql 동기화이다.
첫째 접속관리 기능은 클라우드서버(10)로의 접속과 CSP(40)의 접속관리로 나뉘는데, 클라우드서버(10)로의 접속은 섹터서버(20)가 최초 실행될 때 ID와 비밀번호를 입력받아 수행되며, 지속적으로 클라우드서버(10)와의 접속 상태를 체크하고, 접속이 끊어진 경우 주기적으로 재접속을 요청한다.
CSP(40)의 접속관리는 상술한 클라우드서버(10)와 동일하게 수행된다.
둘째 Sql 동기화 기능은 섹터서버(20)에 속한 CSP(30)에서 작업요청을 수행할 때 적용한 Sql을 순서대로 클라우드서버(10)에 전달하여 섹터서버(20)의 매장DB(22)와 클라우드서버(10)의 클라우드DB(12a,12b,12c)의 상태를 동일하게 유지하는 기능이다.
CSP(40)에서 작업요청이 오는 경우는 크게 두 가지로 한 가지는 섹터서버(20)에 직접 접속한 CSP(40)에서 요청하는 경우로 Sql 요청 작업이 수행되며, 나머지 한가지는 클라우드서버(10)에 접속한 CSP(40)에서 요청하는 경우로 클라우드서버(10)에서 Sql 역동기화 작업으로 섹터서버(20)에 전달되어 수행된다.
상기 Sql 요청 작업과 Sql 역동기화 작업은 모두 전달받은 쿼리(Query)문을 Sql 동기화 작업으로 전달하고, Sql 동기화 작업은 큐(Queue)를 통하여 전달받은 순서대로 클라우드서버(10)에 전달한다.
클라우드로직(60)은 닷넷 리모팅(.Net Remoting) 기술을 이용하여 클라우드기반 POS시스템 서비스를 제공하기 위한 로직으로, 기능은 크게 Sql 동기화, Sql 역동기화, CSP의 Sql 요청 처리이다.
첫째 Sql 동기화는 섹터서버(20)에 접속한 CSP(40)에서 요청한 Sql을 섹터서버(20)에서 처리한 후, 클라우드서버(10)로 전송하여 양쪽의 DB((12a,12b,12c),(22))를 동일한 상태로 유지시켜주는 기능이다.
둘째 Sql 역동기화는 클라우드서버(10)에 접속한 CSP(40)에서 요청한 Sql을 CSP(40)가 속하는 섹터서버(20)로 Sql 요청을 전송하여 양쪽의 DB((12a,12b,12c),(22))를 동일한 상태로 유지하는데, 선택 쿼리(Select Query)와 삽입/업데이트/삭제(Insert/Update/Delete) 쿼리를 나누어 처리한다.
선택 쿼리의 경우 섹터서버(20)의 큐(Queue)에 Sql을 등록하여 자신의 순서가 되었을 때, 클라우스서버(10) 자체에서 처리를 하며(섹터서버의 DB와는 무관), 삽입/업데이트/삭제 쿼리의 경우는 섹터서버(20)의 DB(22)의 데이터를 변경해야 하므로, 섹터서버(20)의 Sql 동기화 기능을 이용하여 처리를 한다.
셋째 CSP(40)의 Sql 요청 기능은 CSP(40)가 접속한 서버(섹터서버(20) 또는 클라우드서버(10)에게 CSP(40)가 요청한 Sql문을 전송하여 Sql 동기화 또는 Sql 역동기화 작업을 처리하고 결과를 전해주는 기능이다.
CSP(40)는 인터넷(네트워크)과 연결이 끊어졌을 경우 기본적인 POS 시스템의 기능을 수행하도록 하며, 네트워크 연결시에 클라우드서버(10)와 통신하여 클라우드 서비스가 작동하도록 설계한 POS로 자체의 BusinessLogic과 클라우드로직(50)의 PosListener과의 클라우드 서비스가 제공된다.
DB로직(50)은 섹터서버(20)의 매장DB(22)와 클라우드서버(10)의 클라우드DB(12a,12b,12c)에 각각 연결하여 DB를 제어하는 로직이다.
도 6a 내지 도 6f는 도 5에 나타낸 클라우드서버를 설명하기 위한 도면이다.
도 6a와 도 6b는 클라우드서버의 초기화시 도 5의 연결 상태와 화면을 나타내는 도면으로서, 처음 실행시 클라우드로직(60)의 Synchronizer 닷넷리모팅 기능을 생성하여 섹터서버(20)의 접속이 가능하도록 한다.
도 6c와 도 6d는 섹터서버 접속시 도 5의 연결 상태와 화면을 나타내는 도면으로서, 섹터서버(20)가 접속하면 해당 섹터서버(20)를 관리하는 SectorInformation을 생성하고, SectorInformation은 접속한 섹터서버(20)의 InversSynchronizer에 접속한 뒤, 클라우드로직(60)의 PosListener 닷넷리모팅 서비스를 생성하여 CSP(40)의 접속을 기다린다.
도 6d에 도시된 바와 같이 접속한 섹터서버(20)는 화면의 접속표시에 녹색으로 표시하여 준다.
도 6e와 도 6f는 섹터서버 관리시 도 5의 연결 상태와 화면을 나타내는 도면으로서, 클라우드서버(10)에 접속할 수 있는 섹터서버(20)의 계정을 관리한다.
도 7a 내지 도 7i는 도 5에 나타낸 섹터서버를 설명하기 위한 도면이다.
도 7a와 도 7b는 섹터서버의 초기화시 도 5의 연결 상태와 화면을 나타내는 도면으로서, 처음 실행시 로그인창에 아이디와 패스워드를 입력하면 클라우드서버(10)의 Synchronizer 닷넷리모팅 서비스에 접속하여 로그인을 하고, Sql 역동기화를 위한 inversSynchronizer와 CSP(30)의 접속을 대기하기 위한 PosListener 닷넷리모팅 서비스를 생성한다.
도 7c와 도 7d는 CSP 초기화시 도 5의 연결 상태와 화면을 나타내는 도면으로서, 섹터서버(20)에 CSP(30)가 접속한 경우, PosLinstener 닷넷리모팅 서비스를 통해서 접속을 받으면 사용자 인증을 한 후, POS 접속 내역에 표시해준다.
도 7e와 도 7f는 네트워크 장애 발생시 도 5의 연결 상태와 화면을 나타내는 도면으로서, 네트워크 장애 발생시 ‘클라우드 서버 연결 오류’라고 화면에 표시하고, 주기적으로 클라우드서버(10)와 재연결을 시도한다.
네트워크 장애가 발생한 때부터 CSP(40)에서 오는 Sql 요청은 모두 섹터서버(20)에만 적용된다.
전송되는 Sql 중 삽입/업데이트/삭제 쿼리의 경우 매장DB(22)의 TempQueue 테이블에 저장하고, 클라우드서버(10)와 다시 연결된 경우 TempQueue 테이블에 저장해둔 Sql을 순서대로 클라우드서버(10)에 전송한다.
도 7g 내지 도 7i는 네트워크 장애 복구시 DB의 동기화 작업을 나타내는 도면으로서, 네트워크 장애 복구 시 도 7g처럼 저장된 쿼리 목록이 클라우드서버(10)에 적용되어 도 7h처럼 서로 다르던 DB 내용이 동기화되어 도 7i처럼 일치하게 된다.
도 8a 내지 도 8c는 도 5에 나타낸 클라우드로직을 설명하기 위한 도면이다.
도 8a는 Sql 동기화시 도 5의 연결 상태를 나타내는 도면으로서, 섹터서버(20)에 접속한 CSP(40)가 Sql 처리를 요청하면서 Sql 동기화 로직이 시작된다.
클라우드로직(60)의 PosListener에 의해 전송된 Sql은 DonPosSector의 내부 Sql 큐를 통하여 요청 순서에 따라 처리되며, 선택 쿼리의 경우 섹터서버(20)의 매장DB(22) 질의를 통해 결과를 반환하고, 삽입/업데이트/삭제 쿼리의 경우 섹터서버(20)의 매장DB(22) 조작 및 Synchronizer를 통해 클라우드서버(10)의 클라우드DB(12a,12b,12c)도 변경하여 동일한 상태를 유지시켜준다.
도 8b는 Sql 역동기화시 선택 쿼리의 경우 도 5의 연결 상태를 나타내는 도면으로서, 클라우드서버(10)에 접속한 CSP(40)가 Sql 처리를 요청하면서 Sql 역동기화 로직이 시작된다.
클라우드로직(60)의 PosListener에 의해 전송된 Sql은 SectorInformation으로 전송되어, 해당 섹터서버(20)의 InversSynchronizer를 이용하여 섹터서버(20)의 Sql 큐에 등록, 순서를 기다린다.
순서가 돌아오면 클라우드서버(10)의 클라우드DB(12a,12b,12c)를 조작하여 결과를 반환한다.
도 8c는 Sql 역동기화시 삽입/업데이트/삭제 쿼리의 경우 도 5의 연결 상태를 나타내는 도면으로서, 클라우드로직(60)의 PosListener에 의해 전송된 Sql중 삽입/업데이트/삭제 쿼리는 SectorInformation으로 전송되어, 해당 섹터서버(20)의 InversSynchronizer를 이용하여 섹터서버(20)의 Sql 요청 처리를 하고, Synchronizer을 통해 클라우드서버(10)와 섹터서버(20) 양쪽 DB 모두에 적용한다.
도 9a 내지 도 9c는 도 5에 나타낸 CSP를 설명하기 위한 도면이다.
도 9a와 도 9b는 Sql 요청시 도 5의 연결 상태와 화면을 나타내는 도면으로서, CSP(40)에서의 DB 조작은 BusinessLogic을 통하여 작동하며, BusinessLogic은 Sql을 클라우드로직(60)의 PosListener에 의해 전송한다.
전송을 받는 대상은 CSP(40)가 접속한 대상이 어디냐에 따라 클라우드서버(10)와 섹터서버(20) 모두 가능하다.
도 9c는 DB 적용 모습을 보여주는 화면으로서, DB를 직접 접속한 화면이다.
CSP(40)에서 주문한 내역이 클라우드서버(10)와 섹터서버(20) 양쪽의 DB에 모두 적용된 것을 확인할 수 있다.
이상을 통해 본 발명의 바람직한 실시예에 대하여 설명하였지만, 본 발명은 이에 한정되는 것이 아니고 특허청구범위와 발명의 상세한 설명 및 첨부한 도면의 범위 안에서 여러 가지로 변형하여 실시하는 것이 가능하고 이 또한 본 발명의 범위에 속하는 것은 당연하다.
10: 클라우드서버 12a,12b,12c: 클라우드DB(통합DB)
20: 섹터서버 22: 매장DB
30a,30b: 사용자 PC 40: CSP
50: DB로직 60: 클라우드로직

Claims (10)

  1. 클라우드서버, 매장의 섹터서버 간에 닷넷리모팅 기술을 적용하여 클라우드DB를 동기화하는 방법에 있어서,
    클라우드서버와 섹터서버에서 각각 프로그램을 실행하여 클라우드서버와 섹터서버를 구동하는 단계;
    섹터서버에서 클라우드서버에 접속을 시도하고, 클라우드서버에 접속을 허용하여 서로 네트워크 연결이 되는 단계;
    사용자PC를 이용해 섹터서버나 클라우드서버에 접속하여 섹터서버의 매장DB나 클라우드서버의 클라우드DB를 조작해서 데이터를 변경, 저장하는 단계; 및
    섹터서버에서 클라우드서버의 해당 매장 클라우드DB에 변경된 데이터를 동기화하고, 클라우드서버에서 해당 섹터서버의 매장DB에 변경된 데이터를 동기화하는 단계;를 포함하는 닷넷리모팅 기술을 적용한 클라우드DB 동기화방법.
  2. 제1항에 있어서,
    상기 클라우드서버와 섹터서버 간에 네트워크 연결이 끊어진 경우, 사용자PC를 이용해 섹터서버에 접속하여 매장DB를 조작해서 데이터를 변경, 저장하는 단계;
    상기 네트워크 연결이 끊어진 상태에서 섹터서버에서 계속하여 클라우드서버에 접속을 시도하고, 다시 네트워크 연결이 된 경우 접속을 허용하는 단계;
    상기 섹터서버에서 네트워크 연결이 끊어진 상태에서 변경한 데이터를 클라우드서버의 해당 매장 클라우드DB에 복구하여 동기화하는 단계:를 더 수행하는 것을 특징으로 하는 닷넷리모팅 기술을 적용한 클라우드DB 동기화방법.
  3. 제2항에 있어서,
    상기 클라우드서버와 섹터서버 간에 네트워크 연결이 끊어진 상태에서, 사용자PC를 이용해 클라우드서버에 접속하여 클라우드DB를 조작하려는 경우 연결이 끊어진 섹터서버에 대응되는 클라우드DB는 조작이 불가능하도록 하는 것을 특징으로 하는 닷넷리모팅 기술을 적용한 클라우드DB 동기화방법.
  4. 각 섹터(가맹점)의 매장DB를 통합하여 관리하는 클라우드DB를 구현하고, 섹터서버와 CSP(Client Service Pos)의 접속관리를 하며, DB 동기화를 위해 Sql 동기화를 수행하는 클라우드서버;
    섹터(가맹점)에서 자신의 매장DB를 관리하고, 클라우드서버로의 접속 및 CSP의 접속관리를 하며, DB 동기화를 위해 Sql 동기화를 수행하는 섹터서버;
    상기 클라우드서버와 섹터서버의 연결이 끊어진 경우 섹터서버와 연동하여 기본적인 POS 시스템의 기능을 수행하고, 네트워크 연결시에 클라우드서버와 통신하여 클라우드서비스가 작동되도록 하는 CSP;
    닷넷리모팅(.Net Remoting) 기술을 이용하여 클라우드기반 POS시스템 서비스를 제공하기 위한 로직으로, Sql 동기화, Sql 역동기화, CSP의 Sql 요청 처리 기능을 수행하는 클라우드로직; 및
    상기 매장DB와 클라우드DB에 각각 연결하여 DB를 제어하는 DB로직;을 포함하는 닷넷리모팅 기술을 적용한 클라우드기반 POS시스템.
  5. 제4항에 있어서,
    상기 클라우드서버는 섹터서버와 CSP의 접속을 따로 관리하여, CSP가 속한 섹터서버의 현재 접속 여부를 판단하여 접속되어 있는 경우에만 CSP의 접속을 허용하는 것을 특징으로 하는 닷넷리모팅 기술을 적용한 클라우드기반 POS시스템.
  6. 제4항에 있어서,
    상기 클라우드서버의 Sql 동기화 기능은 섹터서버에서 Sql 요청을 하는 것과 클라우드서버에 접속한 CSP에서 Sql을 요청한 것으로 나누어, 섹터서버에서 요청하는 경우는 섹터서버에서 Sql을 요청받은 순서대로 해당 가맹점의 클라우드DB에 적용하여 매장DB와 동일한 상태로 유지시켜주고, CSP에서 요청하는 경우는 섹터서버로 역동기화 요청을 보내서 섹터서버에서 Sql 적용 순서를 맞추도록 하는 것을 특징으로 하는 닷넷리모팅 기술을 적용한 클라우드기반 POS시스템.
  7. 제4항에 있어서,
    상기 섹터서버에서 클라우드서버로의 접속은 섹터서버가 최초 실행될 때 ID와 비밀번호를 입력받아 수행되며, 지속적으로 클라우드서버와의 접속 상태를 체크하고, 접속이 끊어진 경우 주기적으로 재접속을 요청하는 것을 특징으로 하는 닷넷리모팅 기술을 적용한 클라우드기반 POS시스템.
  8. 제4항에 있어서,
    상기 Sql 동기화 기능은 섹터서버에 접속한 CSP에서 요청하는 경우와, 클라우드서버에 접속한 CSP에서 요청하는 경우로 나누어, 전자인 경우는 요청을 수행할 때 적용한 Sql을 순서대로 클라우드서버에 전달하여 매장DB와 클라우드DB의 상태를 동일하게 유지하고, 후자인 경우는 클라우드서버에서 Sql 역동기화 작업으로 섹터서버에 전달되어 수행되는 것을 특징으로 하는 닷넷리모팅 기술을 적용한 클라우드기반 POS시스템.
  9. 제4항에 있어서,
    상기 클라우드로직의 Sql 역동기화 기능은 선택 쿼리(Select Query)와 삽입/업데이트/삭제(Insert/Update/Delete) 쿼리로 나누어, 선택 쿼리의 경우 섹터서버의 큐에 Sql을 등록하여 자신의 순서가 되었을 때 클라우스서버 자체에서 처리를 하고, 삽입/업데이트/삭제 쿼리의 경우는 섹터서버의 Sql 동기화 기능을 이용하여 처리를 하는 것을 특징으로 하는 닷넷리모팅 기술을 적용한 클라우드기반 POS시스템.
  10. 제4항에 있어서,
    상기 클라우드서버와 섹터서버의 연결이 끊어진 경우 CSP에서 오는 Sql 요청은 섹터서버에만 적용되고, Sql 중 삽입/업데이트/삭제 쿼리의 경우 매장DB의 TempQueue 테이블에 저장하였다가 클라우드서버와 다시 연결된 경우 TempQueue 테이블에 저장해둔 Sql을 순서대로 클라우드서버에 전송하는 것을 특징으로 하는 닷넷리모팅 기술을 적용한 클라우드기반 POS시스템.
KR20130092452A 2013-06-24 2013-08-05 닷넷리모팅 기술을 적용한 클라우드db 동기화방법 및 클라우드기반 pos시스템 KR101460554B1 (ko)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
KR20130072269 2013-06-24
KR1020130072269 2013-06-24

Publications (1)

Publication Number Publication Date
KR101460554B1 true KR101460554B1 (ko) 2014-11-11

Family

ID=52287737

Family Applications (1)

Application Number Title Priority Date Filing Date
KR20130092452A KR101460554B1 (ko) 2013-06-24 2013-08-05 닷넷리모팅 기술을 적용한 클라우드db 동기화방법 및 클라우드기반 pos시스템

Country Status (1)

Country Link
KR (1) KR101460554B1 (ko)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102185555B1 (ko) * 2020-05-18 2020-12-02 주식회사 지에스리테일 데이터베이스의 보안 접근 및 쿼리 수행 방법과 이를 구현하는 서버

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100557192B1 (ko) 2004-04-06 2006-03-03 삼성전자주식회사 서버와 클라이언트간에 데이터 동기화 시 비정상 종료된경우 데이터 전송 방법 및 그 시스템.
WO2012009657A2 (en) 2010-07-15 2012-01-19 Google Inc. Point of sale data collection
KR20130044080A (ko) * 2011-10-21 2013-05-02 현대오토에버 주식회사 호스트디비 기반 개별 클라이언트디비 통합관리시스템

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100557192B1 (ko) 2004-04-06 2006-03-03 삼성전자주식회사 서버와 클라이언트간에 데이터 동기화 시 비정상 종료된경우 데이터 전송 방법 및 그 시스템.
WO2012009657A2 (en) 2010-07-15 2012-01-19 Google Inc. Point of sale data collection
KR20130044080A (ko) * 2011-10-21 2013-05-02 현대오토에버 주식회사 호스트디비 기반 개별 클라이언트디비 통합관리시스템

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
카탈로그: 기사 *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102185555B1 (ko) * 2020-05-18 2020-12-02 주식회사 지에스리테일 데이터베이스의 보안 접근 및 쿼리 수행 방법과 이를 구현하는 서버
WO2021235752A1 (ko) * 2020-05-18 2021-11-25 주식회사 지에스리테일 데이터베이스의 보안 접근 및 쿼리 수행 방법과 이를 구현하는 서버

Similar Documents

Publication Publication Date Title
US11853990B2 (en) Systems and methods for providing a point of sale platform
US11868980B2 (en) Wireless data communication interface
US9946999B2 (en) Customer interaction manager on a point of sale computer
US9870555B2 (en) Customer interaction manager on a restaurant computer
US20120296679A1 (en) Web integrated point-of-sale system
CA2836049C (en) Web integrated point-of-sale system
JP6187564B2 (ja) 情報処理システム、情報処理装置、連携情報処理システム、情報処理方法、プログラム
US11481755B2 (en) Multi-venue food-service transaction fulfillment using unique system-wide identifiers
EP3954139A1 (en) Multi-venue food-service transaction fulfillment using unique system-wide identifiers
KR101460554B1 (ko) 닷넷리모팅 기술을 적용한 클라우드db 동기화방법 및 클라우드기반 pos시스템
JP2005128843A (ja) クレジットカード取引システム及びクレジットカード取引システムの端末連動方法
US9996828B2 (en) Customer interaction manager on a mobile smart device
US10410199B2 (en) Print control system and print control method
US11017457B2 (en) Information processing system and information processing method of information processing system
US10368188B2 (en) Systems and methods for identifying location-based services
JP2024076890A (ja) 情報処理装置および注文管理システム
JP2023047264A (ja) 商材情報管理システム、商材情報管理方法、及びサーバ装置
AU2020264388A1 (en) Web integrated point-of-sale system
US20140156430A1 (en) Customer Interaction Manager
AU2011368727A1 (en) Web integrated point-of-sale system

Legal Events

Date Code Title Description
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 20171103

Year of fee payment: 4

FPAY Annual fee payment

Payment date: 20181213

Year of fee payment: 5