[델파이 웹개발] 델파이로 풀스택 웹 개발하기 – uniGUI 활용


델파이는 윈도우 등 네이티브 앱 개발 시 가장 강력한 개발 환경입니다. 하지만 웹 서버와 웹 UI 클라이언트 개발로도 확장할 수 있는 습니다. 이 세션에서는 델파이를 웹 세상으로 확장하는 여러 기술 중 하나인 uniGUI를 설명합니다. uniGUI는 웹 서버와 웹 클라이언트 한번에 구축할 수 있는 풀 스택 개발 능력이 특징입니다.

  • uniGUI와  Sencha Ext JS 개요
  • (데모) http://unigui.com 홈페이지에서 제공되는 라이브 데모 살펴보기 (01분 44초 부터)
  • (데모) https://sencha.com 홈페이지에서 제공되는 라이브 데모 살펴보기 (04분 20초 부터)  
  • uniGUI의 주요 특징
  • (데모) 5분내에 웹 개발하기 (07분 52초 부터)
  • (데모) 모바일웹 화면 개발하기 (12분 52초 부터)
  • (데모) 접속한 장비에 맞게 데스크톱웹과 모바일웹 화면을 제공 (16분 16초 부터)
  • uniGUI 하이퍼서버 (HyperServer)
  • (데모) uniGUI 하이퍼서버 (HyperServer)에서 작동시키기 (19분 49초 부터)
  • (데모) uniGUI 하이퍼서버 (HyperServer) 관리 화면 (21분 45초 부터)
  • (데모) 하이퍼서버 (HyperServer)로 웹애플리케이션 원격 배포 (23분 55초 부터)
  • (데모) 하이퍼서버 (HyperServer)에서 노드 관리하기 (26분 22초 부터)
  • 리눅스 서버 지원
  • (데모) 리눅스에 uniGUI 웹애플리케이션 배포하기 (30분 25초 부터)
  • uniGUI 로드맵

uniGUI와  Sencha Ext JS 개요

  • uniGUI
    • (델파이용) 풀스택 웹 애플리케이션 프레임워크
    • 델파이 안에서 델파이와 같은 방식으로 웹 애플리케이션 개발
    • uniGUI는 Ext JS Classic Toolkit와 Ext JS Modern Toolkit을 사용
  • Sencha Ext JS
    • Sencha Ext JS는 자바스크립트 프레임워크 중 가장 종합적이다. 
    • 큰 데이터를 빠르게 표현하는 면에서 탁월하고, 웹과 모바일 플랫폼을 가리지 않는다.
    • Ext JS에는 고성능이 검증된 140여개의 클라이언트 UI 컴포넌트가 들어있다.

(데모) http://unigui.com 홈페이지에서 제공되는 라이브 데모 살펴보기 (01분 44초 부터)

Delphi > Tools > GetIt Package Manager 선택 > 겟잇 필터에서 ‘Code’라고 입력 > CodeSite Express를 선택하고 [Install] 버튼 클릭 후 기본 설정을 따라 설치 > 델파이 재시작 후 겟잇에서 Installed로 표시되는 지 확인

(그림1. http://unigui.com 의 라이브 데모에서 uniGUI로 구현된 실제 웹 페이지를 직접 작동시켜볼 수 있다.)
그림2. http://unigui.com 의 라이브 데모에서 uniGUI로 구현된 실제 웹 페이지의 해당 소스 코드를 볼 수 있다. (델파이 코드임을 알 수 있다)

(데모) https://sencha.com 홈페이지에서 제공되는 라이브 데모 살펴보기 (04분 20초 부터)

그림3.  https://sencha.com 홈페이지의 라이브 데모에서 실제 구현된 웹 페이지와 해당 자바스크립트 소스 코드를 볼 수 있다.

uniGUI의 주요 특징

  • 150여개의 UI 콘트롤
    • 데이터 표현 성능과 능력이 특히  뛰어나다.
  • 풀 스택 (Full-Stack) 웹 개발 능력
    • 프론트 엔드 클라이언트와 백 엔드 서버를 모두 개발할 수 있다.
    • 클라이언트와 백엔드 서버를 한번에 자동으로 생성한다. (클라이언트 UI와 백엔드 서버 각각 별도의 도구가 사용되는 일반적인 풀 스택 웹 개발보다 쉽고 빠르르다)
    • 델파이의 (애플리케이션 개발을 빠르게하는) RAD 방식을 그대로 적용한다.
    • 세션 관리를 프레임워크 수준에서 자동으로 관리한다.
  • uniGUI 배포 옵션
    • 독립 실행 파일 (윈도우, 리눅스)
    • 윈도우 서비스
    • ISAPI 모듈 DLL (윈도우 용)
    • 네이티브 아파치 모듈 (윈도우, 리눅스)
    • 리눅스 서비스로도 가능 (독립 실행 파일의 구성 파일 수정 필요)

그림4. uniGUI에서 제공하는 150여개의 UI 콘트롤들

(데모) 5분내에 웹 개발하기 (07분 52초 부터)

File > New > Other > Delphi > uniGUI for Delphi > Application Wizard 를 사용하여 demodb라는 프로젝트를 만든다. 그 결과, 메인폼메인모듈서버모듈이 생성된다.

메인모듈에서는 
FireDAC의 FDMemTable을 추가하고, 로컬 데이터를 담는다.
TDataSource를 추가하고 DataSet 속성에 FDMemTable을 연결한다.

메인폼에서는
 TUniDBGrid를 추가하고, DataSource 속성에 메인모듈에서 추가한 DataSource를 연결한다.
 TUniDBImage를 추가하고, DataSource 속성과 DataField 속성을 연결한다. Proportional과 Stretch 속성은 True로 설정한다. 
 TUniDBEdit를 추가하고 DataSource 속성과 DataField 속성을 연결한다. 
 TUniDBNavigator를 추가하고 DataSource 속성을 연결한다. 

컴파일을 하고 실행을 하면, uniGUI 웹애플리케이션 서버가 작동한다.
웹브라우저에서 localhost:8077 주소로 접근하면, 델파이에서 만든 메인폼이 웹브라우저에 표시된다.

네비게이터를 이용하여 데이터세트 사이를 이동할 수 있다. 하고, 데이터 변경을 할 수 있다.
그리드 안의 셀 또는 에디트박스에서 데이터를 변경하고 네비케이터의 체크 표시를 클릭하면 서버의 데이터가 변경된다.

그림5. uniGUI로 만든 웹화면, 데이터 조회 수정이 모두 가능하다.

(데모) 모바일웹 화면 개발하기 (12분 52초 부터)

File > New > Other > Delphi > uniGUI for Delphi > Mobile Form 를 사용하여 모바일폼을 추가한다. (메인화면으로 사용하려면 Mobile Application Main Form을 선택한다)

모바일폼에서 uniGUI 모바일 UI 컴포넌트를 추가한다: TUnimDBEdit, TUnimDBimage, TUnimDBNavigator
각 DB인식 UI 컴포넌트에 웹메인폼에서 한 것 처럼 메인모듈에 있는 데이터소스를 연결한다.

컴파일을 하고 실행을 하면, uniGUI 웹애플리케이션 서버가 작동한다. 이제 데스크톱의 웹브라우저용 뿐만아니라 모바일 웹브라우저용 메인화면도 제공된다.
모바일용 메인화면은 주소가 달라야한다. 모바일 장비에서 접속하면 이곳으로 전환된다. (데모에서는 /m을 추가한다: localhost:8077/m)

그림6. uniGUI로 만든 모바일웹화면 (시뮬레이터에서 모바일 장비에 따라 화면이 어떻게 보일지 미리 볼 수 있다)

(데모) 접속한 장비에 맞게 데스크톱웹과 모바일웹 화면을 제공 (16분 16초 부터)

  • 델파이에서 데스크톱웹 메인인 Main.pas와 모바일웹 메인인 Mainm.pas가 각각 있다. 
  • uniGUI는 접속한 장비가 데스크톱인지 모바일인지를 인식하고 장비에 맞는 메인폼을 제공한다. 

uniGUI 하이퍼서버 (HyperServer)

  • uniGUI 애플리케이션의 가용성, 안정성, 확장성을 현격하게 향상시킨다.
  • 백그라운드에서 여러 인스턴스가 작동한다. 각 인스턴스는 노드(Node)라고 부른다.
  • 서버를 멈추지 않고도 원격에서 애플리케이션을 업데이트 할 수 있다.
  • 여러 세션들이 여러 노드에 나누어져서 작동한다.
  • 노드가 사용되지 않을 때는 다른 세션을 위해 재활용될 수 있어서 서버의 컴퓨팅 자원이 효율적으로 사용된다.
  • 즉 하이퍼서버는 계란을 한바구니에 담지 않고 여러 바구니에 나누어 담는 방식이다.

(그림7. 하이퍼서버의 아키텍처는 uniGUI 웹 애플리케이션 세션 1개 이상이 들어있는 노드 여러개가 작동한다. 그리고 노드에 문제가 생기면하므로, 하이퍼서버는 해당 노드를 중단시키고, 차후에 재활용 한다.)

(데모) uniGUI 하이퍼서버 (HyperServer)에서 작동시키기 (19분 49초 부터)

앞에서 개발된 웹애플리케이션의 실행파일을 복사하여 하이퍼서버 실행파일이 있는 폴더에 넣는다. 

같은 폴더에 있는 하이퍼서버 구성정보 파일 (hyper_server.cfg) 내용을 아래와 같이 편집한다:
[hyper_server] 애트리뷰트의 binary_name에 uniGUI로 만든 웹애플리케이션 실행파일명을 적고 저장한다.

이제 이 웹애플리케이션은 하이퍼서버 안에서 작동된다.

(데모) uniGUI 하이퍼서버 (HyperServer) 관리 화면 (21분 45초 부터)

웹브라우저에서 localhost:8077/server 주소를 통해 하이퍼서버 관리화면을 열 수 있다.

  • 하이퍼서버에서 작동 중인 노드의 PID 상태와 각 보유 세션 갯수 등의 정보를 보고 관리할 수 있다.
  • 문제가 있거나 유휴한 노드는 자동으로 내려가고 추후 재활용된다.
  • 윈도우 작업관리자에서 각 노드가 백그라운드에서 각각 별도의 프로세스로 실행되고 있음을 알 수 있다. 
  • 구성정보에서 노드의 총갯수를 지정할 수 있다.

(데모) 하이퍼서버 (HyperServer)로 웹애플리케이션 원격 배포 (23분 55초 부터)

  •  웹애플리케이션의 새버전을 배포할 때 서버를 중단할 필요가 없다.
  •  하이퍼서버 관리 화면에서 [업로드]를 선택하고 버전이 올라간 새 웹애플리케이션의 실행파일을 선택하여 업로드한다.
  •  그 결과, 기존의 노드는 버려지고 구버전 애플리케이션 세션을 더이상 제공하지 않는다. (이후 새버전 세션을 제공할 때 재활용된다)
  •  새 버전이 배포된 후에 웹브라우저를 통해 접근하는 사용자는 자동으로 새 버전을 사용하게 된다. (즉 노드에 새로운 버전으로 작동하는 세션이 생겨난다)

(데모) 하이퍼서버 (HyperServer)에서 노드 관리하기 (26분 22초 부터)

  •  uniGUI 부하 테스트 도구를 사용하여, 동시 접속 100개를 실행하면, 하이퍼서버에는 노드가 16개와 총 100개의 세션이 만들어지는 것을 볼 수 있다.
  •  세션이 만료되면 노드는 재활용된다.
  •  동시접속을 1,000개로 하면 16개 노드에 총 1,000개 세션이 만들어진다. 세션은 각 노드에 안분된다.

리눅스 서버 지원

  • 델파이 10.3 버전 이후부터 Linux용 uniGUI 웹애플리케이션을 만들 수 있다.
  • 데이터베이스 지원: FireDAC 또는 기타 리눅스를 지원하는 데이터 연결 컴포넌트 사용할 수 있다.
  • 그래픽과 이미지 처리 등은 리눅스에서 제약일 있을 수 있지만, 그 외에는 리눅스에서도 윈도우와 같이 작동한다.
  • 리눅스용 하이퍼서버는 현재 개발 중이다.

(데모) 리눅스에 uniGUI 웹애플리케이션 배포하기 (30분 25초 부터)

델파이에서 타겟플랫폼을 Linux 64-bit로 선택한다.
PA 서버 연결을 설정하고 실행한다. (참고: 델파이는 개발 장비 바깥으로 애플리케이션을 배포하고 디버깅할 때 PA서버를 사용한다.)

단, 리눅스의 경우에는, 배포전에 UniGUIServerModule.pas파일에서 OnVeforeInit 이벤트에 uniGUI 런타임 파일 경로를 지정해야한다.

이때 아래와 같이 IFDEF를 사용하여 해당 플랫폼에서만 반영되도록 한다.

uniGUI 로드맵

  • Ext JS 최신 버전인 7.4로 업그레이드 (현재 사용 중인 Ext JS 버전은 7.0)
  •  Ext JS 최신 버전의 모든 새 기능을 uniGUI 컴포넌트에 반영하여 강화
  •  uniGUI 모바일 기능 강화 및 새 컴포넌트 추가
  •  하이퍼서버 강화 (설정 파일 대신 관리화면에서 설정 관리 등)
  •  Server Farms 용 하이퍼서버
  •  리눅스 용 하이퍼 서버
  •  uniGUI 설치 자동화 향상
  •  각국 언어 기능 향상
  •  테마 추가 성능 강화

12.0 12.1 AI AWS C++ c++빌더 chatgpt DelphiCon ios rad서버 RAD스튜디오 UI UIUX UX uxsummit vcl 개발 개발사례 고객사례 기술레터 기술백서 데브옵스 데이터 데이터베이스 델파이 리눅스 마이그레이션 머신러닝 모바일 새버전 샘플 세미나 안드로이드 윈도우 인공지능 인터베이스 출시 커뮤니티에디션 코드 클라우드 파이썬 파이어몽키 현대화