티스토리 뷰
Slate란?
Slate
는 HTML 형태의 API 문서를 만들어주는 도구이다. 정확히는Ruby
기반의 HTML 실시간 렌더링, 빌드 기능을 가진 애플리케이션이다. Slate의 강점은 낮은 학습곡선, 자유도와 생산성이다. 흔히 API 툴링시 많이 도입하는Swagger 2
,ReDoc
조합이 여의치 않을 경우 매력적인 대안이 될 수 있다.- Slate 다운로드 후 하위
/source
디렉토리의Markdown
문서들을 기반으로 API 문서를 작성하면 Slate가 미려한 UI의 반응형 웹으로 변환해준다. - 실시간으로 마크다운 문서를 확인할 수 있으며 또한 배포 목적의 HTML 빌드 기능도 제공한다.
- Slate는 아주 간단한 Markdown 문법 만을 제공하기에 자유도가 상당히 높다. 문법 중간 중간 HTML과 CSS를 허용한다. 예를 들어
Bootstrap
의 CSS를 임포트하면 그대로 HTML에서 사용할 수 있다.
Slate 설치
- Slate는 어떤 운영체제에서도 개발이 가능하다.
Ruby
,Bundler
,Node.js
만 사전 설치되어 있으면 된다.CentOS 6
을 예로 들어 개발환경을 구성해보자.
# Ruby, Bundler 설치
$ cd ~
$ wget https://github.com/feedforce/ruby-rpm/releases/download/2.3.4/ruby-2.3.4-1.el6.x86_64.rpm
$ sudo yum install -y ruby-2.3.4-1.el6.x86_64.rpm
$ sudo gem install bundler
# Node.js 설치
$ curl --silent --location https://rpm.nodesource.com/setup_6.x | sudo bash -
$ sudo yum install -y nodejs gcc-c++ make
# Slate 설치
$ git clone https://github.com/lord/slate.git
$ cd slate
# Bundle 실행(소스 코드를 내려 받은 최초 1번만 실행)
$ bundle install
Slate 개발 서버 구동
- Slate 설치가 완료되었으면
/source/index.html.md
와/includes/*.html.md
를 작성하여 API 문서를 작성하면 된다. 아래와 같이Middleman
을 구동하여 작성된 파일의 실시간 브라우저 확인이 가능하다. (기본값은 HTTP 4577번 포트로 실행된다.)
# Slate 서버 실행
$ bundle exec middleman --watcher-force-polling
Slate 빌드
- 작성이 완료된 API 문서를 빌드하려면 아래와 같이 실행한다.
/build
디렉토리에 진입점이 되는index.html
과 기타 파일들이 생성된다. 빌드된 파일들을 클라이언트에게 전달하거나 웹사이트에 배포하면 된다.
# Slate 빌드 실행
$ bundle exec middleman build --clean
발견된 문제점
- 좌측 네비게이션 메뉴의 검색 기능(문서 상에서
search: true
로 활성화)은 한글 문자열에 대해서 작동하지 않는다. 한글 문서라면 사용하지 않는 편이 낫다. - v2.0의 경우 좌측 네비게이션 메뉴의 각 항목(문서 상에서
#
또는##
으로 정의된 부분)이 한글과 같은 UTF-8 문자열로 시작할 경우 메뉴 기능이 정상적으로 작동하지 않는다. 다운그레이드하여 v1.5 버전을 사용하거나 앞에숫자
또는_
문자열을 접두어로 붙이면 해결된다.
댓글
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 로드 바이크
- java
- jstl
- MySQL
- jsp
- kotlin
- Spring MVC 3
- maven
- Eclipse
- Kendo UI
- bootstrap
- Docker
- 로드바이크
- jpa
- graylog
- Tomcat
- 알뜰폰
- CentOS
- node.js
- 평속
- JavaScript
- JHipster
- 태그를 입력해 주세요.
- spring
- chrome
- DynamoDB
- 자전거
- Kendo UI Web Grid
- 구동계
- Spring Boot
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함