문제해결

Nginx.conf 파일을 Vim으로 편집할 때 Syntax Highlight 표시하기

Nginx를 설치하면 설정파일을 수정하기 위해 /etc/nginx/nginx.conf 파일을 자주 열게 될 것입니다.

그런데 언제부턴가 우분투(Ubuntu)에서 nginx 설정 파일을 vim으로 열면 문법 강조가 되지 않고 죄다 회색으로 나오고는 했습니다. 아래와 같이 말이죠.

이렇게되면 어디가 속성이고 어디가 값인지 헷갈려질 뿐만 아니라 가독성이 떨어지고 보기에 답답해집니다. 그렇다면 어떤 방법으로 nginx.conf 파일의 문법 강조(Syntax Highlighting)을 활성화할 수 있을까요?

Vim nginx.conf Syntax highlighting 활성화 방법

문법 강조를 활성화하기 위해서는 .vim에 정의된 문법 강조 파일을 넣어주면 됩니다. 마치 플러그인을 설치하듯이 구성을 만들어주는 것인데, 이를 쉽게 적용하기 위해 GitHub에서 제공되는 스크립트 파일이 공유되고 있습니다.

이 스크립트를 사용하기 전에 OS에 wget 패키지가 설치되어있어야 합니다. 만약 wget 명령어가 존재하지 않는다면 아래 명령어로 wget을 설치해주셔야 합니다. (Debian/Ubuntuapt, CentOS/RedHatdnf를 주로 사용합니다.)

# apt install wget

다음으로 아래 내용을 모두 복사해주세요. (위 링크의 스크립트 내용과 동일합니다.)

#!/bin/bash
#
# Highligh Nginx config file in Vim

# Download syntax highlight
mkdir -p ~/.vim/syntax/
wget http://www.vim.org/scripts/download_script.php?src_id=19394 -O ~/.vim/syntax/nginx.vim

# Set location of Nginx config file
cat > ~/.vim/filetype.vim <<EOF
au BufRead,BufNewFile /etc/nginx/*,/etc/nginx/conf.d/*,/usr/local/nginx/conf/* if &ft == '' | setfiletype nginx | endif
EOF

이제 아래 명령어를 사용하여 새 스크립트 파일을 만들어줍니다. 스크립트 파일명은 아래 예시와 같지 않아도 됩니다.

$ vim add_syntax_highlight.sh

이제 위에서 복사한 내용을 붙어넣습니다. 완료했다면 파일을 저장하고 나와줍니다.

이 과정이 끝났다면 스크립트를 실행할 수 있도록 권한을 추가해줍니다. 아래 명령어를 실행해주세요.

$ chmod +x add_syntax_highlight.sh

이제 해당 스크립트를 실행해보겠습니다.

$ ./add_syntax_highlight.sh

그러면 다음과 같이 스크립트가 실행되면서 작업이 완료될 것입니다.

$ ./test.sh 
--2021-06-03 11:53:31--  http://www.vim.org/scripts/download_script.php?src_id=19394
Resolving www.vim.org (www.vim.org)... 44.237.4.221
Connecting to www.vim.org (www.vim.org)|44.237.4.221|:80... connected.
HTTP request sent, awaiting response... 302 Found
Location: https://www.vim.org/scripts/download_script.php?src_id=19394 [following]
--2021-06-03 11:53:32--  https://www.vim.org/scripts/download_script.php?src_id=19394
Connecting to www.vim.org (www.vim.org)|44.237.4.221|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: unspecified [application/octetstream]
Saving to: ‘/root/.vim/syntax/nginx.vim’

/root/.vim/syntax/nginx.vim                             [ <=>                                                                                                               ]  28.85K  --.-KB/s    in 0.1s    

2021-06-03 11:53:32 (231 KB/s) - ‘/root/.vim/syntax/nginx.vim’ saved [29542]

이제 다시 파일(/etc/nginx/nginx.conf)을 열어보겠습니다. 아래와 같이 문법이 제대로 강조되어 표시되고 있습니다. (사진의 색상은 터미널 설정값에 따라 조금 다르게 보일 수 있습니다.)

이제 사용했던 스크립트 파일은 삭제해도 됩니다.

JooTC

안녕하세요. 테크놀로지에 관심이 많은 블로거입니다.

Recent Posts

[iOS] Xcode ‘You do not have required contracts to perform an operation’ 해결

Xcode에서 iOS 애플리케이션을 빌드(Archive)하고 App Store Connect에 앱을 업로드하는 도중, 아래와 같은 에러가 발생하면서 더…

2개월 ago

[안드로이드] INSTALL_FAILED_INSUFFICIENT_STORAGE 해결

INSTALL_FAILED_INSUFFICIENT_STORAGE 문제 안드로이드 스튜디오에서 에뮬레이터를 실행하고 개발중인 애플리케이션을 실행하려 하면 로그 창에 아래와 같이 표시되면서…

7개월 ago

Zalgo 텍스트와 이를 방지하는 방법

인터넷 커뮤니티 사이트에서 게시글이나 댓글에 간혹 장난을 목적으로 작성된 특이한 글자를 볼 수 있습니다. 위…

9개월 ago

리눅스 kill, killall 명령어 – 특정 프로세스 종료하기

리눅스 명령어 - kill, killall 리눅스 kill 명령어는 특정 프로세스를 종료해주는 명령어입니다. 백그라운드에서 실행되고 있는…

9개월 ago

JavaScript typeof null이 ‘object’인 이유

JavaScript는 역사가 긴 스크립트 프로그래밍 언어입니다. 세월이 흐르면서 많은 자바스크립트 표준이 만들어졌고, 현재는 많은 문법적…

9개월 ago

Mocha Error: Resolution method is overspecified. 해결 방법

NodeJS 테스트 프레임워크인 Mocha는 비동기 테스트를 지원합니다. 간혹 특정 테스트 스크립트를 작성하고 실행하면 아래와 같이…

9개월 ago