최근 수정 시각 : 2024-06-18 21:24:42

마인크래프트/서버/자바 에디션


파일:나무위키+유도.png  
은(는) 여기로 연결됩니다.
서버 목록에 대한 내용은 마인크래프트/서버/목록 문서
번 문단을
부분을
, 마인크래프트 멀티플레이나 멀티플레이 서버의 구분 등에 대한 내용은 마인크래프트/멀티플레이 문서
번 문단을
번 문단을
부분을
부분을
, 에 대한 내용은 문서
번 문단을
번 문단을
부분을
부분을
, 에 대한 내용은 문서
번 문단을
번 문단을
부분을
부분을
, 에 대한 내용은 문서
번 문단을
번 문단을
부분을
부분을
, 에 대한 내용은 문서
번 문단을
번 문단을
부분을
부분을
, 에 대한 내용은 문서
번 문단을
번 문단을
부분을
부분을
, 에 대한 내용은 문서
번 문단을
번 문단을
부분을
부분을
, 에 대한 내용은 문서
번 문단을
번 문단을
부분을
부분을
, 에 대한 내용은 문서
번 문단을
번 문단을
부분을
부분을
참고하십시오.
파일:상위 문서 아이콘.svg   상위 문서: 마인크래프트/서버
파일:관련 문서 아이콘.svg   관련 문서: 마인크래프트/플러그인
,
,
,
,
,

'''
getbukkit 다운로드 제거에 대한
이 문서에서
토론이 진행되고 있습니다.''' 토론 중인 내용을 일방적으로 편집할 경우 관련 규정에 따라 제재될 수 있습니다.


파일:마인크래프트 로고.svg
{{{#!wiki style="margin: -0px -10px -5px"
{{{#!folding [ 펼치기 · 접기 ]
{{{#!wiki style="margin: -6px -1px -11px"
<colbgcolor=darkgreen><colcolor=#fff> 기본 플레이
시스템세계 (시드) · 게임 모드 · 난이도 · 게임 규칙 · 엔딩 · 죽음 메시지 · 스플래시 · 명령어 · NBT · 런처
인게임아이템 · · 개체 · 날씨 · 차원 · 생물군계 · 구조물 · 마법 부여 · 상태 효과 · 조작법 · 피해 · 발전 과제
도움말튜토리얼 · (탐험 · 파밍 · 회로) · 브릿징 · PVP · 파쿠르 · 스피드런 · 건축
시리즈 및 매체
출시 에디션자바 에디션 (업데이트) · 베드락 에디션 (업데이트) · 포켓 에디션* · 콘솔 에디션* · 파이 에디션*
파생 게임마인크래프트 던전스* · 마인크래프트 레전드* · 마인크래프트 에듀케이션 · 마인크래프트: 스토리 모드* · 마인크래프트 어스*
미디어OST · 관련 서적 · 레고 · 애니메이션 · 더 무비 · Minecraft Live · Minecraft Now · Minecraft Monthly
유저 콘텐츠
창작 요소2차 창작 · 망토 · · 모드 (개발 · · 모드팩) · 애드온 · (리소스 팩 · 데이터 팩) · 외부 프로그램 ·
멀티 콘텐츠멀티플레이 · 서버 · 플러그인 · Realms · EULA
개발개발 기초 · 모드 개발 · 플러그인 개발
기타
이야깃거리여담 · 커뮤니티 · 사건 사고 · 문제점 · 용어 · 지원 언어 · 머나먼 땅 · 이미테이션 게임
관련 문서나무위키 마인크래프트 프로젝트 · 마인크래프트로 분류된 문서 · 마인크래프트의 하위 문서
* 표시는 서비스가 종료되었거나 개발이 중단되었다는 표시이다. }}}}}}}}}
<nopad> 본 위키는 공식 MINECRAFT 서비스가 아닙니다. 이용에 참고 바랍니다.


1. 개요2. 서버 유형
2.1. LAN 서버2.2. Realms2.3. 서버 구현 프로그램
3. 서버 만들기
3.1. 윈도우 환경
3.1.1. 자바 설치3.1.2. 구동기 만들기3.1.3. 인바운드 규칙 설정
3.1.3.1. 포트포워딩
3.1.3.1.1. 포트포워딩 문제 해결
3.1.4. 마인크래프트 서버 연결하기
3.2. 리눅스 환경
3.2.1. 자바 설치
3.3. 도메인 설정(공통)
4. 개인 운영5. 마인크래프트 서버 호스팅 업체6. 서버 설정7. 서버 구현물 목록
7.1. 바닐라 서버7.2. Bukkit API
7.2.1. Craftbukkit7.2.2. Spigot7.2.3. Paper7.2.4. Purpur7.2.5. Plazma7.2.6. Pufferfish7.2.7. Folia
7.3. 자체 API 기반
7.3.1. Forge7.3.2. NeoForge7.3.3. Fabric7.3.4. SpongeVanilla7.3.5. Minestom7.3.6. Cuberite7.3.7. Glowstone
7.4. 플러그인 API + 모드
7.4.1. SpongeForge7.4.2. CatServer7.4.3. Arclight7.4.4. Mohist7.4.5. Cardboard
7.5. 다중 서버용 프록시 서버
7.5.1. BungeeCord7.5.2. Velocity
7.6. 개발 중단된 프로젝트
7.6.1. Craftbukkit7.6.2. Tuinity7.6.3. TacoSpigot7.6.4. Thermos7.6.5. Cauldron (MCPC+)7.6.6. Kettle7.6.7. Yatopia7.6.8. Waterfall
8. 사건 사고
8.1. 2014년 Craftbukkit DMCA 테이크 다운
8.1.1. 발단8.1.2. 전개8.1.3. 결말

1. 개요

마인크래프트 멀티플레이 서버를 구축하는 방법은 LAN 서버, Realms, 바닐라 서버, 모드/플러그인 서버가 있다.

참고로 마인크래프트가 기존 PC용 자바 에디션과, 콘솔/모바일 크로스 플랫폼을 지원하는 베드락 에디션으로 분리되어, 자신의 플랫폼에 알맞은 서버 구동기를 선택해야 한다.

2. 서버 유형

2.1. LAN 서버

싱글플레이 세계에서 게임설정에 들어가면 LAN 서버를 열 수 있다.

같은 근거리 통신망에 연결되어 있는 유저끼리 접속할 수 있다. 서버를 구동하는 PC와 같은 와이파이 또는 회선에 접속된 PC에서만 접속할 수 있다는 것이다.

다만 같은 내부 네트워크에 연결되어 있지 않더라도 VPN이나 공유기의 포트포워딩을 통해 외부에서 접속할 수 있다.

치트 사용이 불가능한 특정 맵에서의 꼼수가 가능한 방법으로, LAN 서버 만들기에 들어가 치트 사용을 켜고 서버를 열면 치트 사용이 가능해진다. MC-134(의도한 대로 작동) 다만, 그 맵에서 나간 순간 전부 다 풀려버리니 주의하도록 하자.

LAN 서버에서 버킷 플러그인을 사용할 수 없다. 모드는 포지나 패브릭을 설치하면 이용 가능하며, 플러그인과 유사한 기능을 하는 서버측(Server-Side) 모드를 대체재로 사용할 수 있다.

가장 쉽고 편하게 하는 방법은 바로 하마치를 이용하는 것이다. 당장 네이버구글에 검색만 해봐도 하마치를 쓰라는 글이 수두룩하다. 그러나 하마치의 특성상 꽤나 불안정하고 모드가 많거나 개인의 컴퓨터의 문제가 있다거나 네트워크가 아주 약간만 불안정해져도 바로 호스트를 제외한 모두가 게임에서 튕겨버린다.

2.2. Realms

파일:상세 내용 아이콘.svg   자세한 내용은 Minecraft Realms 문서
번 문단을
부분을
참고하십시오.
렐름 서버 또한 자바 에디션용 렐름과 베드락 에디션용 렐름이 따로있다.

2.3. 서버 구현 프로그램

구현물 또는 구현 프로그램 (Implementation[1]) 을 통해 서버를 구동할 수 있다. 방법은 다음 문단에서 설명한다.

자바 에디션에서는 일반적으로 구현 프로그램은 Java 언어로 작성되었고, jar 파일[2]로 구성된다. 바닐라 서버와 달리 플러그인 API를 내장하고 있어 플러그인을 추가할 수 있다. 구현물 중에서 포지와 연계되어 있는 SpongeForge를 사용한다면 플러그인과 모드를 동시에 적용할 수도 있다.

프로그램이 실행되는 동안 서버가 인터넷 전역으로 공개되어 열린다. 같은 와이파이에 연결될 필요가 없다는 말이다.[3] 대부분의 서버 구현 프로그램들은 이 바닐라 서버를 기반으로 제작되었다. 바닐라 서버에 대한 자세한 정보는 이 문단 참고.

3. 서버 만들기

대다수의 서버 구현물은 Java로 작성된 프로그램이다. PE 포맷이 아닌 Jar 파일이기 때문에 일반적인 실행 방법[4]으로 구동할 수 있지만 GUI가 뜨지 않고 로그가 기록되지 않아 서버 실행 상황과 버그같은 오류를 확인할수 없으므로 각종 서버 구현물을 통하여 서버를 돌리는 것이 좋다.

NAS 등 개인용 서버 보유자라면 마인크래프트 서버 관리 프론트엔드[5]를 활용하는 것도 나쁘지 않다.

3.1. 윈도우 환경

당신이 지금 윈도우 운영체제를 사용하고 있다면 아래 방법을 따르도록 하자.

3.1.1. 자바 설치

서버를 실행하려면 JRE(Java Runtime environment, 자바 실행 환경)[6]가 설치되어 있어야 한다.

자바가 설치되어 있는지 확인하려면:
  • 실행 창(윈도우 키+R)에 cmd /k java -version 를 입력하고 Enter를 누른다.
  • java version "..." 메세지와 함께 자바 버전이 출력되면 잘 설치되어 있는 것이다.
만약 "java -version 은(는) 내부 또는 외부 명령, 실행할 수 있는 프로그램, 또는 배치 파일이 아닙니다." 라는 문구가 뜬다면 자바가 설치되어 있지 않거나, 시스템 환경변수(PATH)에 자바 경로가 설정되지 않은 것이다.
  • 자바를 설치하려면 1.16.5 이하는 Java 8, 1.18~1.20.4는 Java 17, 1.20.5 이상은 Java 21을 설치한다. OpenJDK를 제외한 다른 자바 런타임을 사용 하고 싶을 경우 Java 문서를 참고하면 좋다.
  • 일반적으로 Java를 설치하면 대부분은 환경 변수가 설정되지만, 일부 환경 변수가 설정되지 않는 경우도 있다.[7]
  • 자바 환경변수를 설정하려면,
  • 윈도우키+Pause 키를 눌러 "시스템"에 들어간다. 만약 Pause키가 없는 경우, 윈도우키+R키를 눌러 control(제어판)을 실행, "제어판\시스템 및 보안\시스템"에 들어가준다.
  • 좌측의 "고급 시스템 설정"에 들어간다.
  • "고급" 탭의 "환경 변수" 버튼을 누른다.
  • "시스템 변수" 리스트에서 "Path" 항목을 선택하고 "편집" 버튼을 누른다.
  • "새로 만들기" 버튼을 눌러 자바가 설치되어 있는 경로(폴더)를 입력한다. (대부분 "%programfiles%\Java\JDK-1x.0.x\bin\"에 설치되어 있다.)
  • "확인" 버튼을 누른다.
  • 윈도우키+R 키를 눌러 /cmd /fbccfe /k java를 입력하고 "java 은(는) 내부 또는 외부 명령, 실행할 수 있는 프로그램, 또는 배치 파일이 아닙니다." 라는 문구가 더이상 출력되지 않는다면 성공이다.

환경변수 관련 설정 방법은 오라클 공식 문서에 자세히 나와 있다.

3.1.2. 구동기 만들기


구동기는 서버 구현 프로그램을 실행하는 명령어를 실행 가능한 배치파일로 만드는 것이다. 아래 설명과 같이 구동기를 만든 후 더블 클릭으로 구동기 파일을 실행하면 서버가 켜진다.
  1. 폴더[8] 하나를 만든다.
  2. 폴더 안에 들어가서 미리 받아 놓은 서버 구현물(Spigot이나 Paper 등) 파일을 옮겨 넣는다.[9]
  3. 폴더의 빈 화면에 우클릭 > 새로 만들기 > 텍스트 문서
  4. 파일 이름을 start[10]로 정하고 메모장으로 열어서 아래와 같이 작성한다.
chcp 65001
cls
java -Xms2048M -Xmx2048M -jar <서버 파일>.jar
pause||
만약 서버를 계속 다시 시작하고 싶다면 다음과 같이 작성한다.
chcp 65001
:start
cls
java -Xms(서버가 사용할 최초 메모리 크기) -Xmx(서버가 사용할 최대 메모리 크기) -jar <서버 파일>.jar
pause
goto start||
주의: <서버 파일>.jar 부분을 방금 준비한 서버 구현물의 파일 이름으로 바꾸도록 한다.[11] 예) spigot-1.21.jar
작성한 구동기 스크립트에 대한 설명은 아래 표와 같다. 필요하면 기호에 맞게 스크립트를 바꿔 써도 좋다.
명령문 (매개 변수) 명령문 설명
@echo off프롬프트 메시지에 "C:\Windows\System32 >" 처럼 파일 경로가 출력되는 것을 끈다.
chcp 65001콘솔에서 한글이 깨지는 현상을 수정한다.
:startgoto 명령어에서 신호를 받았을 때 여기서부터 명령을 다시 시작한다.
cls콘솔에 출력된 모든 텍스트를 제거한다.
java -jar server.jar "server.jar" 라는 이름의 서버 구현물 파일을 Java로 실행한다.[12]
-Xms2048M -Xmx2048M서버를 실행하는 데 할당시킬 메모리 크기[13].
-Xms는 최초 할당 크기, -Xmx는 최대 할당 크기이다.
되도록이면 -Xms와 -Xmx를 같게 설정하는 것이 좋다.
컴퓨터의 메모리 크기와 맞춰 설정하는 것이 좋지만, 서버를 연 컴퓨터로 다른 작업을 하려면 4GB 정도의 여유를 남기고 할당해야 한다.
pause일괄적인 처리를 보류한다. 서버 종료시 화면이 갑자기 꺼지지 않아 유용하다.
goto start:start 부터 명령을 다시 시작한다.
{{{#!folding 추가 인수 [ 펼치기 · 접기 ] 모든 인수는 -jar (서버 이름).jar로 시작한다.
--help사용 가능한 인수를 실행하고 서버를 끈다.
--bonusChest세계 생성 시 보너스 상자를 생성한다.
--demo체험판 버전으로 실행한다.
--eraseCache싱글에서 세계 최적화 버튼을 누르는 것과 같다.
--forceUpgrade모든 청크를 현재 실행중인 버전으로 강제로 업그레이드 한다.
nogui
--nogui
GUI를 열지 않는다.
--safeMode안전 모드(바닐라 데이터팩)로 진입한다.
--port <값>포트를 지정한다. 기본값은 -1이다.
-1은 server.properties 파일 내의 server-port의 값을 읽는다.
}}}
{{{#!folding Log4j 취약점 수정 인수 [ 펼치기 · 접기 ]-Dlog4j2.formatMsgNoLookups=true1.17~1.18 전용. 심각한 보안 취약점 해결 1.18은 가능한 경우 1.18.1로 업그레이드 한다. 그렇지 못한 경우 이 인수를 넣는다.
-Dlog4j.configurationFile=log4j2_112-116.xml1.12 ~ 1.16.5 전용. 심각한 보안 취약점 해결 여기에서 다운로드 받은 뒤 서버 폴더에 넣고 JVM 인수 추가한다.
-Dlog4j.configurationFile=log4j2_17-111.xml1.7 ~ 1.11.2 전용. 심각한 보안 취약점 해결 여기에서 다운로드 받은 뒤 서버 폴더에 넣고 JVM 인수 추가한다. }}}
1. 파일을 저장한 후 메모장을 닫는다.
1. start.txt 텍스트 파일 이름을 start.bat 또는 .cmd[14]으로 바꾼 뒤 실행한다.
* 텍스트 파일 이름을 바꿔도 여전히 텍스트로 열린다면 파일 탐색기가 확장자명을 숨기고 있기 때문이다. Windows10 기준 폴더 창 상단의 보기-옵션-보기-알려진 파일 형식의 파일 확장명 숨기기 박스 체크 해제하면 파일의 확장자가 보인다. 파일 이름이 start.bat.txt 처럼 확장자가 변경된 것이 아니라 이름만 변경된 경우이다. 뒤의 txt를 지우면 해결된다.
1. 메모장을 열어 주고 내용에 eula=true만 작성한다. 그리고 파일 이름은 eula.txt로 하고 서버 폴더 안에 저장한다.
이는 EULA에 동의한다는 의미이며 자신이 서버를 운영하면서 위반 행위를 할 경우 모장으로부터 제재를 받을 수 있다.
1. .bat 또는 .cmd 파일을 열어 준다. 그리고 잠시 기다리면 콘솔에 텍스트가 표시되며 world, server.properties 같은 폴더나 파일이 생성된다.[15] 이후 서버 콘솔에 Done (시간)! For help, type "help"가 기록되었다면 서버가 열렸음을 의미한다.
  • Invalid maximum heap size: -Xmx(자신이 지정한 크기) The specified size exceeds the maximum representable size. 라고 뜬다면 자바가 32비트라서 일어나는 오류다. 자바 사이트에서 64비트 버젼을 받아주면 해결된다. JDK를 설치했다면 무조건 64비트 버전이 설치된다.
  • 서버는 JVM(자바 가상 머신)에서 돌아가기 때문에, 가비지 컬렉션 관련 인수를 추가하여 서버를 최적화 하면 좋다. 가비지 컬렉션중 가장 유명한 컬렉션은 Aikar Flags이다. 아래의 내용을 -Xmx와 -jar 사이에 넣으면 된다.
    • https://flags.sh 에서 빠르게 JVM 인수들이 달린 명령을 생성 할 수 있다.
  • 번지코드 구동기를 만드는 경우, 위 배치 파일에서 파일 이름을 번지코드 서버 파일의 이름으로 수정하면, 바로 번지코드 서버 실행기로 바꿀 수 있다. 추가적으로 번지코드는 하위 서버들에 있는 server.properties 파일에서 online-mode 항목을 false으로 수정하고, 1.19.1 이상의 경우 enforce-secure-profile 항목도 false으로 수정해야 하며, bukkit.yml 파일에서는 connection-throttle 항목을 -1로 수정하고, spigot.yml 파일에서 bungeecord 항목을 true로 수정해야 한다.

3.1.3. 인바운드 규칙 설정

위의 방법대로 따라한다면 서버는 정상적으로 구동될테지만 본인 밖에 접속을 할 수 없을 것이다. 이를 해결하기 위해서는 방화벽을 해제해야 한다.

방화벽은 윈도우의 방화벽과 공유기의 방화벽이 존재하며, 윈도우의 방화벽을 열지 않으면 공유기에 방화벽을 열었다고 해도 멀티가 불가능 하나 윈도우의 방화벽을 열었다면 같은 공유기 내에서는 멀티가 가능하다.

포트포워딩이나 DMZ로 공유기의 포트를 열 경우 보안이 취약해지기 때문에 장거리 멀티가 아니라면 윈도우 방화벽만 해제해 주자.[16]

1.윈도우 키 + R을 입력하고 나타나는 실행 창에 control을 입력한다. 또는 제어판을 검색하여 연다.
2. 시스템 및 보안 → Windows Defender 방화벽 → 왼쪽에 위치한 고급 설정 클릭
3. 아웃바운드는 기본 설정이 접속 허용이니 건드릴 필요가 없고 인바운드 규칙을 선택한다.[17]
4. 오른쪽에 새 규칙포트(O)를 선택[18], TCP(T)특정 로컬 포트(S)[19] 선택하고 포트 입력 칸에 자신이 설정한 서버의 포트를 입력한다.(포트를 따로 설정하지 않았다면 기본 포트인 25565를 입력하면 되며 베드락 에디션은 19132).[20]
5. 연결 허용(A)를 선택하고, 도매인(D), 개인(P), 공용(U) 모두 선택한다.
6. 이름은 편한대로 지정해주고 설명은 선택 옵션이다.
3.1.3.1. 포트포워딩
자신의 컴퓨터가 Wi-Fi 에 연결되지 않고 LAN 선이 모뎀이나 스위칭 허브에 연결되어 있거나 VPS 등의 호스팅 서비스를 사용하는 경우 패스. 하지만 LAN선이 라우터에 연결된 경우에는 아래 추가 절차가 필요하다.

장거리를 하고 싶다면 위에서 연 포트를 공유기에서도 열어주어야 한다. 모든 공유기 공통으로 공유기 페이지에 로그인해야되며 방법을 모르는 경우 공유기의 사용설명서를 읽어보면 된다. 공유기 제조사별로 방법이 천차 만별이니 문서에 모든 경우를 다 적기에는 어려움이 있다. 열심히 공유기의 포트 포워드나 포트 포워딩항목을 찾아보자 다만 iptime같은 사제 공유기 말고 통신사의 공유기라면 내부 포트를 제대로 지정할 수 없는 경우가 있는데[21] 통신사에 연락하거나 DMZ, S-DMZ, Twin-IP를 사용하거나 내부 포트에 맞춰주자. 모뎀을 사용하거나 이중 공유기이면 모든 모뎀, 공유기를 똑같이 설정해주어야 한다.[22] 공유기에서 컴퓨터로 할당되는 IP를 고정하는 것을 추천[23], 유동 IP이기 때문에 컴퓨터로 할당되는 IP주소가 바뀐다면 다시 설정해야 되기 때문이다. 포트포워딩 테스트[24]

포트포워딩 완료 시 공유기와 유선으로 접속해 서버를 개방해야 한다.
3.1.3.1.1. 포트포워딩 문제 해결
간혹 공유기로 구축된 내부 네트워크와 서버 프로그램 자체에서 설정한 내부 네트워크 간 IP 설정이 달라[25] 127.0.0.1과 같은 루프백 IP로는 접근이 되는데, 외부에서 서버 접근이 안 되는 경우가 있다. 방화벽 설정, 공유기 포트포워드 설정 등등을 다 했는데 안 되면 환장할 노릇.
그런 경우에는 최초 서버 구축 시에 "사용자의 내부 IP *.*.*.*으(로) 포트포워드가 필요할 수 있습니다"라는 문구가 뜨는데
관리자 권한으로 cmd 실행
netsh interface portproxy add v4tov4 listenport=[설정 포트] listenaddress=[내부 네트워크 IP] connectport=[설정 포트] connectaddress=[컴퓨터의 내부 IP 주소]
와 같이 컴퓨터 내부적으로 한 번 더 포트포워딩 해줘야 정상적으로 포트포워드가 작동해 외부에서 내부 서버로 접근이 가능해진다. VMware 같은 가상 머신을 이용하는 컴퓨터의 경우 발생하는 문제.

3.1.4. 마인크래프트 서버 연결하기

이 문단은 번지코드 서버가 아닌 일반 마인크래프트 서버를 만들고자 이 문서를 읽으러 온 사람이라면 이 문단은 무시하고 가면 된다.

위에 적힌대로 번지코드 서버를 실행하고 기본 주소인 localhost:25577을 바로 서버 목록에 추가하면 MOTD랑 핑은 정상적으로 나타나지만 들어가보면 연결된 마인크래프트 서버가 없다며 들어가지지 않는 모습을 볼 것이다. 이를 해결하기 위해서는 최소 한 개의 마인크래프트 서버랑 연결해야 한다. 아래 모든 항목은 연결할 마인크래프트 서버를 번지코드용으로 수정했고, 서버 관련 지식이 어느정도 있는 하에 작성되었다.

실행기를 한번 실행하고 생성된 config.yml의 일부 중 아래와 같은 항목이 있을 것이다.
#!syntax java 
servers:
  lobby:
    motd: '&1Just another BungeeCord - Forced Host'
    address: localhost:25565
    restricted: false
이것을 자신의 입맛에 맞게 수정해주려면 먼저 연결할 서버 폴더로 가 server.properties의 server-port의 값을 확인해주자. 이 값을 lobby의 address 항목에 서버 IP:포트 형식으로 수정해주면 된다. MOTD의 경우 일반 server.properties 스타일로 적어줄 경우 적용되지 않으며, 이곳에서 생성해서 For config.yml아래에 있는 항목을 복사해 lobby의 motd에 넣어주면 된다.

3.2. 리눅스 환경

3.2.1. 자바 설치

자바 설치법은 배포판의 종류에 따라 다르다. 자바 홈페이지에서 바이너리 압축 파일을 내려받거나 운영체제의 패키지 매니저[26]를 통해 open-jdk 또는 oracle-jdk를 내려받는다. 데비안 계열은 apt-get install open-jdk라고 하면 된다.

3.3. 도메인 설정(공통)

자신이 어떤 운영체제를 사용해도 도메인 설정을 하는 방법은 동일하다. 도메인이란 간단히 말해서 숫자로 된 아이피주소를 문자열로 바꿔주는 서비스인데 일단 아이피가 바로 노출되는 것 보단 보안에 효과가 있으며, 사용자들이 알기 쉬워 접근성을 올려 줄 수 있고, 서버의 특성을 나타내는 수단이다.

노하마치, 장거리 멀티등으로 많은 블로그에서 홍보하는데 하마치 아이피도 도메인 등록을 할 수 있으며 장거리 멀티는 도메인과는 크게 상관이 없다. 굳이 도메인을 안쓰고 아이피 주소를 사용하는 것도 충분히 가능하다. 반드시 해야하는 절차가 아니며 개인의 취향과 선택에 따르는 선택사항이라는 점을 명심하자. 또한 .com같은 도메인은 이미 다른 사용자가 가져간 경우가 태반이며, 가격 역시 매우 비싸며, .kr은 대한민국 법의 보호를 받는 도메인이라는 점을 참고해두자.[27]

도메인을 등록하려면 대개 돈을 지불하여야 하며, 무료 도메인 사이트 역시 존재하나 무료 도메인 사이트는 선택할 수 있는 폭이 좁고 디도스 공격을 당해 서버가 폐쇄될 가능성이 높다. 과거 무료 도메인 사이트인 oa.to가 디도스 공격으로 폐쇄되었던 걸 생각해보자.

그냥 도메인을 등록하면 가정에선 기본적으로 유동 아이피이기에 아이피 주소가 바뀌어 도메인이 갑자기 안될 수도 있으며 이러한 불편함을 해소하기 위해서는 아이피를 고정하거나 DDNS서비스를 사용하여야 한다.
iptime공유기라면 내장된 무료 DDNS를 사용하는 것을 추천하고, 이외에는 no-ip 또는 MCV.KR[28][29] no-ip같은 경우 추가 프로그램을 깔지 않으면 DDNS가 안되니 참고 바람. 다른 서비스를 찾고 싶다면 구글에 DDNS 검색을 해보자.

DDNS가 싫다고 한다면 그냥 도메인을 아이피로 등록하면 된다. 만약 많은 사람들이 참여하는 서버로 만들고 싶다면 반드시 아이피를 고정하거나 DDNS를 사용해야 하며, 그냥 도메인을 등록하는 경우는 친한 사람끼리 플레이하는 정도가 적당하다.

4. 개인 운영

개인 운영이란 서버 호스팅을 이용하지 않고 본인 컴퓨터로 서버를 열거나 직접 서버용 컴퓨터를 장만해서 운영하는 방법을 말한다.

호스팅 비용이 들지 않겠지만, 24시간 내내 컴퓨터를 켜야 하기에 전기요금이 많이 나갈 수 있어서 대부분은 시간제[30]로 운영한다. 뿐만 아니라 디도스 공격에 취약하기 때문에 누군가가 서버 컴퓨터에 디도스 공격을 하면 그대로 서버 자체가 마비될 수 있기 때문이다. 디도스 공격을 걱정한다면 비싼 돈을 들여서 디도스 방어 장비를 사용하기보다는 그냥 호스팅을 이용하는 게 좋다.

또한 컴퓨터의 성능이 많이 받쳐줘야 한다. 서버 인원이 적은 소규모 서버라면 감당할 수 있어도 서버 인원이 늘어나고 서버에 컨텐츠를 추가할수록 많은 리소스를 먹게 되어 개인 컴퓨터로는 감당하기 어렵다. 특히 야생서버의 경우 서버 유저들이 맵을 자유롭게 돌아다니다 보니 맵 파일 크기가 몇십에서 심하면 몇백GB를 넘어버린다. 따라서 Worldborder나 플러그인을 통해 맵의 크기를 제한시켜야 한다.

그리고 외부에서 접속할 수 있도록 공유기 설정도 변경해야 하는데, 공유기마다 접근 방법이나 설정 페이지가 다르기 때문에 어려올 수 있다.

5. 마인크래프트 서버 호스팅 업체

마인크래프트 서버를 전문적으로 호스팅해주는 업체 역시 존재한다. Mojang 스튜디오(전 Mojang AB)에서 운영중인 Minecraft Realms이 있지만, 바닐라 서버만 사용이 가능해 친구들과 가볍게 플레이할 목적이 아니라면 불편할 수 있다.

따라서 바닐라 외의 서버를 돌려주는 호스팅 업체들을 사용하는 것이 좋다. 호스팅 업체에 따라서 Java 에디션 서버만 지원하거나 Java와 베드락 에디션 서버를 돌다 지원한다. 규모가 큰 업체의 경우는 다른 게임 서버도 호스팅해주기도 한다.

외국의 대표적인 호스팅 업체로는 MCProHosting[31], Apex Hosting 등이 있으며, Aternos 같은 무료 호스팅 업체도 있으나 무료 호스팅 업체들은 대부분 램 1GB에 성능이 낮은 편이다보니 서버 랙이 있으며, 플러그인을 많이 적용하거나, 모드를 적용하면 램 용량을 초과해버려서 서버가 작동하지 않는다. 유료 호스팅의 경우는 추가로 금액을 지불해서 램 용량을 추가하거나 저장공간 용량을 업그레이드할 수 있다.

업체마다 원격 데스크톱 연결을 지원하거나, DDoS 방어 기능을 지원하기도 한다. 또한 리눅스 말고 윈도우 서버를 선택할 수 있다, 다만 윈도우 서버를 선택한다면, 월 라이선스비가 추가되며 서버 구동에 사용할수 있는 메모리 역시 리눅스 서버에 비해 낮으므로 윈도우 환경이 반드시 필요한 것이 아니라면 리눅스 서버를 사용하는 것이 가성비가 좋은 편이다.

호스팅 비용은 업체마다 다른 편이며, 비용이 싼 것도 있고, 비싼 것도 있다. 비용이 싸고 신뢰도가 낮은 업체는 사기나 먹튀 위험이 있기 때문에 피해야 한다. 비용이 싼 업체들은 원칙적으로 환불이 불가능하므로 신중하게 선택하는 것이 좋다.

이외 가상 서버 호스팅을 구입한 뒤 직접 자바를 설치, 서버를 운영할 수도 있으나 일부 업체의 경우 부하 등의 이유로 게임서버 운영을 금지하기도 하므로 마인크래프트 서버를 운영해도 괜찮은지 반드시 확인해야 한다.

6. 서버 설정

아래에는 서버를 설정하는 방법을 서술한다.

6.1. server.properties

파일:상세 내용 아이콘.svg   자세한 내용은 server.properties 문서
번 문단을
부분을
참고하십시오.

6.2. motd 설정

Message of the Day. 마인크래프트의 멀티플레이에서 서버의 설명을 정하는 설정이다. server.properties에서 서버 motd를 설정하거나 스크립트로 설정할 수 있다. 1.19.4 이하 버전은 한글로 작성하려면 인코딩 방식이 다르기 때문에 UTF-8 형식으로 작성해야 한다.MC-2215 한글에서 유니코드로 바꾸는 방법은 여기로 가서 변환 해주도록 하자. 뿐만이 아니라 색을 입히고 출력 결과물을 미리 볼 수 있는등 편하게 설정 할 수 있다.

7. 서버 구현물 목록


이 문단은 현재까지 사용 가능하거나 개발이 중단된 다양한 종류의 서버 구현 프로그램을 소개한다.
* 이름: 서버 구현 프로그램 이름
* 한글 이름: 제안하는 한글 표기명
* API: 플러그인 동작의 기반이 되는 API
* 지원 로더: 모드와 플러그인의 지원 여부
* 홈페이지: 공식 홈페이지 링크
* 마지막 버전: 개발이 중단된 경우 기입
* 추가 설명: 해당 구현물의 부가적인 설명
* 지원 중단 사유: 개발이 중단된 서버 구현물들중 특별한 사유가 존재할 경우 기입
마인크래프트 버전 요구 Java 버전
~ 1.16.5 8
1.17 ~ 1.17.1 16
1.18 ~ 1.20.4 17
1.20.5 ~ 21

7.1. 바닐라 서버

Vanilla Server
(바닐라 서버)
파일:마인크래프트/잔디 블록.png
(위키에서 임의로 넣은 로고)
API 없음
지원 로더 데이터 팩
지원 버전 클래식 ~ 최신 스냅샷
공식 다운로드 최신 릴리스 버전
다른 릴리스 버전 [ 펼치기 · 접기 ]
1.21
1.20.6 1.20.5 1.20.4 1.20.2 1.20.1 1.20
1.19.4 1.19.3 1.19.2 1.19.1 1.19
1.18.2 1.18.1 1.18[Log4j_미수정]
1.17.1
1.16.5 1.16.1
1.15.2
1.14.4
1.13.2
1.12.2
1.11.2
1.10.2
1.9.4
1.8.9(.exe)
1.7.10(.exe)
1.6.4(.exe)
1.5.2(.exe)
1.4.7(.exe)
1.3.2(.exe)
1.2.5
제작사인 Mojang Studios에서 개발하는 공식 서버 프로그램이다. 근거리 네트워크 망의 유저끼리만 접속되는 LAN 서버나, Mojang Studios 사에서 호스트해주는 Minecraft Realms와 달리 독립적인 서버 프로그램을 통해 여는 방식이라 유저가 자신의 컴퓨터로 서버를 호스팅 할 수 있다. 아래에 나열할 서버 프로그램들도 마찬가지.
멀티플레이를 많이 해보면 알다시피 서버의 기능을 풍요롭게 하는 요소로써 모드 또는 플러그인이 빠질 수 없는데, 바닐라 서버는 API가 존재하지 않아 모드 또는 플러그인을 적용할 수 없다. 즉, 화폐를 추가하거나 미니게임을 제공하는 등 플러그인이 제공하는 기능을 사용할 수 없고 기본적인 게임 요소만을 즐길 수 있다.[33] 따라서 플러그인을 사용하지 않는 생야생 서버[34]를 여는 경우에는 바닐라 서버가 가장 적합하다.[35]

다만 다른 구동기들에 비해 최적화가 많이 부족하다는 단점이 있어서, 생야생 서버를 연다고 해도 컴퓨터 사양이 넉넉하지 않거나 서버 규모가 큰 경우라면 다른 구동기를 사용하는 것이 더 좋다. 그밖에 바닐라 서버는 정식으로 출시되지 않은 스냅샷 버전을 지원한다는 이점을 가지고 있다.
  • 다운로드 방법은 다음과 같다.
    • 최신 릴리즈 버전: 여기에서 내려받는다.
    • 다른 버전, 스냅샷 버전: 공식 게임 런처에서 설치 설정(Installations) → 새 설치 설정(New inatallations) → 원하는 버전(VERSION) → 버전 항목 오른쪽에 서버(SERVER)를 클릭한다.

7.2. Bukkit API

플러그인 API의 일종이다. 아래 목록은 이 API를 제공하는 서버 구현 프로그램들이다.

대한민국은 물론 해외를 포함하여 가장 높은 점유율을 보이며, 대다수의 플러그인들이 이 API를 기반으로 개발된다. 모장이 버킷 개발팀을 인수했고, 2014년 DMCA 테이크 다운으로 인해 버킷의 공식 개발은 완전히 중단되어 Bukkit API를 기반으로 한 다른 구현체로 넘어가는 추세이다. 플러그인 중 하나인 WorldEdit은 PaperAPI를 기반으로 제작되어 Bukkit/Spigot에서는 실행되지 않는다.

아래는 서버 구현체들을 모아둔 사진이다.[36]
파일:마인크래프트/서버/자바 에디션/버킷리스트.png

7.2.1. Craftbukkit

Craftbukkit
(크래프트버킷)
파일:Bukkit 로고.png
API Bukkit API
지원 로더 버킷 플러그인
지원 버전 1.8 ~ 1.20
라이선스 GPL v3
웹사이트 공식 홈페이지, 코드 저장소[37]
공식 다운로드 # BuildTools
비공식 다운로드 (Beta_1.2_01 ~ 1.2.5), #
서버로서의 동작 자체는 문제없고 최신 버전까지 업데이트가 되고 있으나 순전히 개발 목적만 사용해야 하며, 서버를 관리/운영할 생각이 있다면 Craftbukkit 보다는 Spigot, Paper를 쓰는 것이 훨씬 더 좋은 선택이다. 그 이유는 여기(영어) 참고.

DMCA 사태 이후 Spigot팀이 프로젝트를 넘겨받아 업데이트한 Craftbukkit을 기반으로 Spigot을 업데이트하기 위한 목적으로만 개발이 되어 유지되고 있는 정도에 가깝고 대다수의 플러그인은 Craftbukkit을 지원하지 않는다. 따라서 Spigot이나 Paper를 쓰는 것이 훨씬 더 좋다.

1.14.4 이후 Spigot팀은 BuildTools로 대부분의 플레이어들이 Spigot이 아닌 Craftbukkit을 얻을 목적으로 실행하는 것을 좋지 않게 보았는지 BuildTools로 통한 Craftbukkit.jar 파일을 획득하기 더 어렵게 만들었다. # 따라서 개발 목적이 아닌 이상 권장되지 않는다.

그래도 권장하지 않지만 구하고 싶다면 여기서 알아보자.

7.2.2. Spigot

Spigot
(스피곳)
파일:Spigot 로고.png
API Bukkit API, Spigot API
지원 로더 버킷 플러그인, 스피곳 플러그인
지원 버전 1.4.4 ~ 1.19.4[38], 1.20.6
라이선스 GPL v3
웹사이트 공식 홈페이지, 공식 디스코드, 코드 저장소[39]
공식 다운로드 #, BuildTools
비공식 다운로드 #
Craftbukkit의 DMCA 사건으로 인해 다운로드 방법이 막혔다가 BuildTools를 통한 빌드방식[40]을 사용하며 빌드하여 구현 프로그램을 얻는데 꽤 오랜 시간이 걸린다. 때문에 인터넷에는 이러한 빌드 과정을 미리 완료 해둔 파일을 바로 내려받을 수 있게 배포하는 사이트도 존재하나, 이미 컴파일된 파일을 배포하는 것은 라이선스 위반이라 고소를 당하면 배포 중단할수 밖에 없다.

BuildTools로 Spigot을 구하는 방법은 여기서 알아보자.

Spigot은 Bukkit API를 채택하여 Craftbukkit 기반 버킷 플러그인이 호환되며, 설정 튜닝을 통한 최적화 기능도 제공한다. 단 Spigot API가 수정된 Bukkit API이기에 Spigot 전용 플러그인을 Craftbukkit에서 구동하려고 하면 오류가 발생할 수 있다.

장점이라면 빠른 업데이트를 예로 들 수 있는데, 프리릴리즈등 정식 출시되지 않은 버전들의 업데이트가 조금이라도 늦어질 경우, BuildTools를 통해 바로 개발 버전의 스피곳을 사용해볼 수 있는 경우가 많다. 만약 새 빌드가 나올 경우 이전 빌드를 사용하는 서버에서는 새 빌드를 다운받으라며 20초 후 서버를 시작한다.[41]

7.2.3. Paper

Paper
(페이퍼)
파일:Paper 로고.png
API Bukkit API, Spigot API, Paper API
지원 로더 버킷 플러그인, 스피곳 플러그인, 페이퍼 플러그인
지원 버전 1.7.10~1.19.4, 1.20.6[42]
라이선스 GPL v3
웹사이트 공식 홈페이지, 깃허브
공식 다운로드 다운로드(1.7.10[Log4j미수정])
Spigot을 포크하여 여러 문제점들을 해결한 버전. Spigot 대비 장점이 많아 2024년 기준 대부분의 서버들이 사용하고 있다. Fabric 모드 프로젝트 중 Lithium의 일부 코드를 가져와 최적화도 더 잘 되어있다. Spigot을 패치한 JAR 형태로 배포되어 사용할 수 있다.

Spigot과는 다르게 DMCA 테이크 다운 문제가 해결되어 일반적인 JAR 파일을 배포하는 방법으로 손쉽게 다운로드하여 사용할 수 있다. 거의 모든 Spigot 플러그인과 호환된다.

다만 기반암 파괴, 레일 복사 등을 모두 막아버려 바닐라의 공장 대다수가 Paper에서 고장나 설정을 건드리거나[44] Paper 전용 공장을 만들어야 해서 야생 유저들 중 Paper를 좋지 않게 보는 시선이 제법 있다. 이로인해 Paper 대신 바닐라 서버 혹은 Fabric 서버를 여는 서버가 있다.

한국 표준시 기준 2021년 8월 18일 오전 4시 40분, Tuinity의 개발자인 Spottedleaf가 Paper 팀의 개발자로 합류했다는 소식이 공지되었고, 1.17.1 #232 버전 이상부터 Tuinity 패치를 사용할 수 있게 변경되며 성능이 향상되었다.

7.2.4. Purpur

Purpur
(퍼퍼)
파일:PurpurMC 로고2.svg
API Bukkit API, Spigot API, Paper API, Tuinity API, Purpur API, Pufferfish API
지원 로더 버킷 플러그인, 스피곳 플러그인, 페이퍼 플러그인, 튜이니티 플러그인, 퍼퍼 플러그인
지원 버전 1.7.10~1.19.4, 1.20.6
라이선스 GPL v3
웹사이트 공식 홈페이지, 깃허브
공식 다운로드 공식 다운로드
Paper, Tuinity를 포크한 구현체다. 주로 마인크래프트의 시스템을 purpur.yml 로 수정할 수 있도록 커스터마이징에 초점을 맞춘 구현체이며, 이 역시 Tuinity 처럼 대규모 서버를 열 생각이라면 이 구현체를 추천한다. 심지어 이 구현체는 지원하는 공유기의 경우 방화벽 설정부터 포트포워딩까지 자동으로 진행한다.

서버를 최적화하고 싶다면 이 문서를 참고하자. 1.17이 되며 Airplane 포트가 제거되었으나, 2021년 7월, Purpur의 개발자가 Airplane 포트를 공식적으로 다시 지원하며 Airplane의 모든 기능을 지원하게 되었다. 2022년 1월에는 1.18.1에서 Pufferfish 포트를 지원하기 시작했다.

7.2.5. Plazma

Plazma
(플라즈마)
파일:PlazmaMC 로고.png
API Bukkit API, Spigot API, Paper API, Tuinity API, Purpur API, Pufferfish API, Plazma API
지원 로더 버킷 플러그인, 스피곳 플러그인, 페이퍼 플러그인, 튜이니티 플러그인, 퍼퍼 플러그인, 플라즈마 플러그인
지원 버전 1.19.4, 1.20.1, 1.20.2, 1.20.4, 1.20.6
라이선스 GPL v3
웹사이트 공식 문서, 깃허브
공식 다운로드 공식 다운로드
Paper 기반으로 Pufferfish와 Purpur를 포함하는 구현체이다. 주로 다양한 버킷과 모드의 일부 최적화 및 개선 패치를 포트 일부 익스플로잇 방지를 백포트를 패치한다.

버킷 구성이 위에서 언급한 최적화 가이드 문서에 따라 일부 기본적으로 설정 되어있다.

특이하게 다른 버킷과 다르게 최신 버전이 아닌 구 버전도 어느정도는 유지 보수를 진행한다.

초창기에는 호환성과 코드 품질에 문제가 있었으나 시간이 지남에 따라 현재에 이르러선 호환성과 안정성이 상당히 개선되었다. 2024년 4월 1일 기준 규모가 작은 프로젝트이므로 신중히 판단하고 사용해야 한다.

7.2.6. Pufferfish

Pufferfish
(퍼퍼피쉬)
파일:Pufferfish 버킷 로고.png
API Bukkit API, Spigot API, Paper API, Petal API
지원 로더 버킷 플러그인, 스피곳 플러그인, 페이퍼 플러그인
지원 버전 1.17.1~1.18.2, 1.20.4
라이선스 GPL v3
웹사이트 공식 홈페이지, 깃허브
공식 다운로드 다운로드
대규모 서버에서 최고의 성능과 안정성을 얻게 만드는 것이 목적이다. Paper를 포크하였고 몇몇 최적화 기능들은 Airplane에서 가져왔다. 자신들의 제품인 Pufferfish Host라는 호스팅을 구매하면 좀 더 나은 성능을 제공하는 Pufferfish+를 이용할 수 있다. 그러나 주 기능인 비동기 엔티티 트래커와 비동기 경로 찾기를 1.19 버전부터 Petal에서 가져와 Pufferfish에 적용을 하게 되면서 사실상 큰 차이가 없어졌다.

7.2.7. Folia

Folia
(폴리아)
파일:Folia 로고.png
API Bukkit API, Spigot API, Paper API, Folia API
지원 로더[45] 버킷 플러그인, 스피곳 플러그인, 페이퍼 플러그인, Folia 플러그인
지원 버전 1.19.4, 1.20.4
라이선스 GPL v3
웹사이트 공식 홈페이지, 깃허브[46]
Tuinity를 개발하던 SpottedLeaf가 주로 주도하는 PaperMC의 프로젝트이다. 2023년 12월 기준 PaperMC 공식 Organization 아래에서 개발이 진행되고 있다.

페이퍼를 포크한 서버 구현체로, 무려 구역별 멀티쓰레딩을 지원한다![47] 다만 멀티쓰레딩을 사용하면서 기존 플러그인들과 호환되지 않는데다 플러그인 API도 완전치 않고, 비활성화된 명령어들중 scoreboard, tag, bossbar, team 등 맵에서 많이 쓰이는 명령어들이 비활성화 되어 있어 명령 블록이 있는 맵을 사용하려면 바닐라에 가까운 서버 구현체들[48]로 구동하는 것을 추천한다.

또한 애초에 완전히 완성되지 않은 서버 구현체이므로[49] 예상치 못한 버그는 언제든 발생 할 수 있다.[50] 대규모 서버에서 실제 서비스 제공 용도로 사용하는것은 그닥 좋은 생각은 아니며, 컴퓨터 자원이 그닥 많지 않은 경우도 성능 미달로 인한 문제 발생이 있을 수 있기에 추천되지는 않는다.[51]

개발적으로 관심이 있는 경우 작동 원리를 읽어보는것도 도움이 된다.

PaperMC 측에서 테스트한 결과에 대한 글도 있다. 1차 테스트 (기본적 및 개발 정보) 2차 테스트 (개발 정보 위주)

개발 초기의 테스트 결과를 보아, 앞으로 있을 테스트를 기대 해볼만큼 꽤 좋은 성능을 내고 있다.

7.3. 자체 API 기반

아래 목록의 프로그램들은 Bukkit API와 독립적이므로 버킷 플러그인과 호환되지 않는다. 일부 프로그램은 NMS[52]에 의존하지 않고 하나부터 열까지 서버 기능을 직접 구현하기도 한다. 이 경우 업데이트 속도가 더디거나 지원하지 않는 기능이 있으므로, 신중하게 선택하기 바란다.

7.3.1. Forge

Forge
(포지)
파일:MinecraftForge 로고.png
API Forge API
지원 로더 포지 모드
지원 버전 1.1~ 1.20.4
라이선스 GNU LGPL v2.1
웹사이트 공식 홈페이지, 깃허브
공식 다운로드 다운로드[53]
포지 모드 서버 구동에 사용되는 서버 프로그램. 플러그인은 호환되지 않지만 비슷한 역할을 하는 서버용 모드나 포지 모드로 포트된 플러그인을 대신 사용 가능하다. 예를 들어 WorldEdit, Dynmap, LuckPerms등은 포지와 버킷 플러그인 버전이 모두 존재한다.

7.3.2. NeoForge

NeoForge
(네오포지)
파일:MinecraftNeoForge 아이콘.png
API Forge API, NeoForge API
지원 로더 네오포지 모드
지원 버전 1.20 ~ 1.20.6
라이선스 GNU LGPL v2.1
웹사이트 공식 홈페이지, 깃허브
공식 다운로드 1.20.1, 1.20.2 ~ 1.20.6[54]
포지의 포크이다. 포크된 이유는 마인크래프트/모드 문서의 NeoForge 문단 참고

7.3.3. Fabric

Fabric
(패브릭)
파일:FabricMC 로고.png
API Fabric API
지원 로더 패브릭 모드
지원 버전 1.14 ~ 1.20.6 ~ 최신 스냅샷
라이선스 Apache License 2.0
웹사이트 공식 홈페이지, 깃허브
공식 다운로드 다운로드, API[55]
1.14 때 Forge의 업데이트가 늦어지자 대체재로 개발된 프로젝트다. Forge 보다 굉장히 빠르고 가볍다. 또한 패치 속도가 매우 빨라 스냅샷 버전도 지원한다는게 특징이다.

버킷 플러그인은 호환되지 않지만 비슷한 역할을 하는 서버용 모드나 패브릭 모드로 포트된 버킷 플러그인을 대신 사용 가능하다. 예를 들어 WorldEdit, Dynmap, LuckPerms등은 패브릭과 버킷 플러그인 버전이 모두 존재한다.

야생 유저의 경우 기반암 파괴, 레일 복사 등 바닐라 버그를 고치지 않고 공장들도 바닐라 시스템 그대로 작동하면서 Lithium, LazyDFU, FerriteCore와 같은 바닐라 친화적 서버 최적화 모드들로 상당한 최적화를 보여주며 반대로 막힌 버그들을 활성화 시키려면 직접 설정을 건드려야 하는[56] Paper의 대체품으로 좋은 편이다.

7.3.4. SpongeVanilla

SpongeVanilla
(스펀지바닐라)
파일:Sponge 로고.png
API Sponge API
지원 로더 스펀지 플러그인
지원 버전 1.8~ 1.20.4
라이선스 MIT
웹사이트 공식 홈페이지, 깃허브
공식 다운로드 다운로드 페이지
스펀지바닐라는 스펀지포지의 모드 호환성만 제거한 버전으로 볼 수 있다. (따라서 Forge 기반의 모드가 아니다.) 설치 방법은 스펀지 공식 문서를 참고하자.

7.3.5. Minestom

Minestom
(마인스톰)
파일:Minestom 로고.png
API Minestom API
라이선스 Apache License 2.0
지원 로더 Minestom Extension
웹사이트 공식 홈페이지, 깃허브
Glowstone과 마찬가지로 멀티쓰레드로 동작하며[57], 바닐라 서버를 기반으로 하지않고 모든 것을 자체적으로 구현하였다.

차이점으로는 다른 서버 프로그램과는 달리 바닐라 서버를 목적으로 한 프로그램이 아니며 모든 것을 직접 구현하도록한[58] 장르서버 특화의 오픈소스 서버 빌딩 라이브러리이다. 주요 Bukkit API 구현 서버 프로그램들처럼 미리 컴파일된 파일을 실행만 하면 끝나는 게 아니라는 뜻이기 때문에 일반적인 사용자는 이용하지 않는 것이 좋다. 최신버전만을 지원하지만, 번지코드나 Velocity 같은 프록시 프로그램도 지원하기 때문에 프록시 플러그인을 이용하여 간접적으로 이전버전에서의 접속을 허용할수 있다.

7.3.6. Cuberite

Cuberite
(큐브라이트)
파일:Cuberite 로고.png
API Cuberite API
지원 로더 큐브라이트 플러그인
지원 버전 1.8 ~ 1.12.2
라이선스 Apache License 2.0
웹사이트 공식 홈페이지, 깃허브
C++로 작성한 마인크래프트 서버. 서버 리소스(CPU, 메모리 등) 관리 최적화를 염두에 두고 개발되어 성능이 좋다. 하지만 서버를 자체 구현했기 때문에 업데이트가 느리고 잔 버그가 많다.[59] Lua로 작성된 자체 플러그인들이 존재한다.

7.3.7. Glowstone

Glowstone
(글로우스톤)
파일:Glowstone 로고.png
API GlowKit API, Bukkit API, Spigot API, Paper API
지원 로더 글로우킷 플러그인, 버킷 플러그인, 스피곳 플러그인, 페이퍼 플러그인
지원 버전 1.12.2, 1.14 ~ 1.16[60], 1.19
웹사이트 공식 홈페이지, 깃허브
공식 다운로드 #
바닐라 서버를 기반으로 하는 대다수의 서버 프로그램과 달리, 글로우스톤은 서버의 기능을 하나부터 열까지 자체적으로 구현하였다.

각 월드마다 개별의 멀티 쓰레드로 동작하기 때문에 단일 쓰레드로 동작하는 다른 서버와 비교했을 때 서버에 걸리는 부하가 적을 것이다. 다만, 서버의 모든 요소들을 자체 구현했기 때문에 아직 기본적인 게임 기능마저 덜 구현되었다.[61]

7.4. 플러그인 API + 모드


일명 하이브리드 서버(Hybrid Server). 아래 있는 구현체들은 Forge/Fabric 모드와 Bukkit API 또는 자체 API 플러그인들 혹은 다른것들까지 동시에 지원하는 구현체들이다. 하지만 계면활성제 없이 차가운 물과 뜨거운 기름을 섞고 그걸로 집을 짓는 수준의 난이도라 호환되지 않을 가능성이 매우 높고 버그가 극도로 많다.

Bukkit API의 경우 모드들이 추가하는 기능들을 Bukkit API쪽에서 다루기 까다롭게 설계되어 있는 데다 모드가 게임 시스템을 완전히 뒤바꾸어 버릴 경우 바닐라 시스템을 기준으로 설계한 Bukkit API 쪽에서 오류를 내뿜을 것이다. 당연히 호환을 시도하는 서버 프로그램들은 불안정할 수밖에 없다. 게다가 커뮤니티 지원을 받을 가능성이 낮아져 본인 스스로 해결해야 하는 경우가 많다. 그나마 SpongeForge의 경우 처음부터 API가 다시 설계되어 사정이 나은 편이다.

7.4.1. SpongeForge

SpongeForge
(스펀지포지)
파일:Sponge 로고.png
API Sponge API, Forge API
지원 로더 스펀지 플러그인, 포지 모드
지원 버전 1.8~1.12.2, 1.16.5, 1.19.4
웹사이트 공식 홈페이지, 깃허브
공식 다운로드 다운로드 페이지[62]
Craftbukkit의 DMCA 사건으로 인해 WorldEdit 개발자[63]와 콜드론 개발자 등 많은 사람들이 모여 스펀지 팀을 창설했고, 버킷과 완전히 다른 새로운 API를 갖는 서버 구현 프로그램인 Sponge가 탄생했다. 스펀지포지는 Forge와 SpongeAPI를 동시에 포함한다. 따라서 모드와 플러그인을 동시에 지원하고, Forge 서버에 설치되는 하나의 모드와 같이 동작한다. 주의할 점은 버킷 플러그인과 호환되지 않으며 포지 모드와의 호환성이 완전하지 않다. 설치 방법은 스펀지 공식 문서를 참고하도록 하자.[64] 또한 클라이언트에도 역시 적용 가능하다.

7.4.2. CatServer

CatServer
(캣서버)
파일:lo2ovq312pf21.jpg
API Bukkit API, Spigot API, Paper API, Forge API
지원 로더 버킷 플러그인, 스피곳 플러그인, 페이퍼 플러그인, 포지 모드
지원 버전 1.12.2, 1.16.5, 1.18.2
웹사이트 공식 홈페이지, 깃허브
NMS 레이어부터 패치하는 방식으로 패키징되어 포지와 스피곳을 모두 호환, 따라서 모드와 플러그인을 전부 지원하는 서버이다. 더 나은 호환성과 안정성, 빠른 속도를 제공하며, 코어모드에 대한 호환성이 향상되었다. 현재 1.12.2에서 모드+플러그인 구현체 중 가장 안정적이라고 한다.[65]

7.4.3. Arclight

Arclight
(아크라이트)
파일:Arclight 로고.jpg
API Forge API, Bukkit API, Spigot API
지원 로더 포지 모드, 버킷 플러그인, 스피곳 플러그인
지원 버전 1.14~1.15[66] 1.16~1.20.4
웹사이트 깃허브
공식 다운로드 1.19.4
Magma, Mohist, CatServer 처럼 포지와 스피곳을 모두 호환하는 하이브리드 구현체이며, 최신버전 하이브리드 구현체 중 가장 안정적이다.[67]

7.4.4. Mohist

Mohist
(모히스트)
파일:mohistLogo.png
API Forge API, Bukkit API, Spigot API, Paper API
지원 로더 포지 모드, 버킷 플러그인, 스피곳 플러그인, 페이퍼 플러그인
지원 버전 1.7.10[68], 1.12.2~ 1.20.2
웹사이트 공식 홈페이지 깃허브

1.7.10의 경우 지원이 중단되어 CrucibleMC 를 사용해야 한다.
CatServer 처럼 포지와 스피곳을 모두 호환하는 구현체이다. 호환성이 완벽하지 않아 일부 필수급 플러그인은 자체적인 패치가 진행된 플러그인으로 변경한다.[69] 그러나 1.12.2 버전에선 CatServer 다음으로 가장 호환성이 좋다.[70] 1.18.2버전에서는 현재 일부의 명령어가 작동을 안하며 오류 구문이 자주 뜨고 심지어 일부 공식 플러그인을 일일이 확인하고 바꿔치기 하는 수상한 행동이 발각되어 EssentialsX 등의 커뮤니티에서는 사용하지 말 것을 권고하기도 했다.#

7.4.5. Cardboard

Cardboard
(카드보드)
파일:Cardboard 로고.png
API Fabric API, Bukkit API, Spigot API, Paper API
지원 로더 패브릭 모드, 버킷 플러그인, 스피곳 플러그인, 페이퍼 플러그인
지원 버전 1.16.5 ~ 1.20.4
웹사이트 공식 홈페이지, 깃허브
공식 다운로드 다운로드
Rainbow 프로젝트의 개발자인 Isaiah가 개발하는 패브릭 모드 이다. Bukkit, Spigot, Paper를 지원하도록 하는 모드이나, 아직 Mohist처럼 불안정하다. 서버 구현체가 아닌 모드이기 때문에, 패브릭 로더를 1회 구동 시켜 모드 폴더에 넣어 주어야 한다.

7.5. 다중 서버용 프록시 서버

아래 서버 프로그램들은 마인크래프트 서버들을 하나로 묶어 서버간 이동을 할 수 있게 해주는 서버 프로그램들이다. 이 서버 프로그램들은 그 자체로 절대 마인크래프트 서버가 아니다.

Bungeecord와 Waterfall은 모두 보안 상 문제가 있어(예: UUID 스푸핑)[71] BungeeGuard와 같은 보안 플러그인을 프록시와 마인크래프트 서버 둘 다 적용해야한다. BungeeGuard의 경우 여기서 설치 방법을 확인 할 수 있다.

무조건 BungeeGuard만을 이용할 필요는 없다. Velocity의 경우 Modern Forwarding 설정을 이용하면[72] BungeeGuard가 필요 없다.

7.5.1. BungeeCord

BungeeCord
(번지코드)
파일:BungeeCord 로고.png
API BungeeCord API
지원 버전 1.4.7~1.19.4, 1.20
라이선스 All Rights Reserved
공식 다운로드 깃허브, 다운로드, 공식 위키
SpigotMC가 관리하며 가장 인지도가 높은 마인크래프트 서버 간 이동을 하게 해주는 프록시 서버 프로그램들 중 하나이다.

7.5.2. Velocity

Velocity
(벨로시티)
파일:Velocity 로고.png
API Velocity API
지원 버전 1.7.2~1.20
지원 서버[73] Paper, Spigot, SpongeVanilla, Fabric[74], Forge(1.7.2~1.12.2, 1.13~1.20.1, 1.20.2 ~)[75]
라이선스 GPL v3
공식 다운로드 깃허브, 다운로드, 공식 문서
BungeeCord의 포크가 아니다. 처음부터 다시 만들어서 BungeeCord랑 Waterfall보다 성능이 좋으며 BungeeCord의 여러 문제점들을 해결했다. 아예 공식으로 서로 비교하는 문서까지 있을 정도. 단점으로는 거의 모든 BungeeCord 플러그인들과 호환되지 않아 Velocity용 플러그인을 찾아야 한다는 점을 뽑을 수 있다.

7.6. 개발 중단된 프로젝트

여기 서술되어 있는 구현체 중 1.7 이상 버전에서 2021년 12월 10일 이전에 개발이 중단되거나 그 이후 log4j 취약점 패치를 받지 못한 구현체는 절대 쓰면 안된다.

Spigot, Paper는 지원 중단된 버전도 이 패치만은 추가로 적용시켜 주었다. 1.7.10을 제외하고.[76]

1.7 미만 버전들은 log4j 취약점 말고 다른 취약점이 많으니 사용하지 않는 것을 권장한다.

7.6.1. Craftbukkit

Craftbukkit
(크래프트버킷)
파일:Bukkit 로고.png
API Bukkit API
지원 로더 버킷 플러그인
지원 중단 사유DMCA
대체 서버 프로그램Paper
지원 버전 Beta_1.2_01 ~ 1.7.10
라이선스 GPL v3
웹사이트 공식 홈페이지, 코드 저장소
DMCA 사태 이후 기존 Bukkit 팀은 해산되었고 이후 Spigot팀이 프로젝트를 넘겨받아 유지되고 있는 상태이다. 이 문단은 Bukkit 팀 시절 서버 구동기.

7.6.2. Tuinity

Tuinity
(튜이니티)
파일:Tuinity 로고.png
API Bukkit API, Spigot API, Paper API, Tuinity API
지원 중단 사유Paper와 병합
대체 서버 프로그램Paper
라이선스 GPL v3
지원 버전 1.15.2~1.16.3[77], 1.16.4 ~ 1.17
웹사이트 깃허브 1.16.5 다운로드, 1.17+ 버전 다운로드[78]
Paper를 포크하여 만들어진 구현체이다. 대규모 서버에 초점이 맞춰져있다.[79] 페이퍼를 최적화 해서 페이퍼보다 성능은 더 좋다.[80] 또한 자체적인 Fabric 모드(Starlight)를 개발해 패치하였다. 페이퍼에서 작동되는 플러그인 중 호환성 문제는 없다. 한국에서는 현재 인지도가 낮지만 해외에서는 인지도가 높은 편이다. 대부분의 Paper 포크도 Tuinity를 기반으로 제작할 정도다.[81] 한국 표준시 기준 2021년 8월 18일 오전 4시 40분, Tuinity의 개발자인 Spottedleaf가 Paper 팀의 개발자로 합류했다는 소식이 공지되었고, 이후 Paper와 완전히 병합되어 더 이상 Tuinity의 업데이트는 없을거라 한다.

7.6.3. TacoSpigot

  • 파일:TacoSpigot.png
  • 이름 : TacoSpigot
  • 한글 이름 : 타코 스피곳
  • API : Bukkit
  • 지원 버전 : 1.8.8~1.9.4, 1.10.2~1.12.2[82]
  • 지원 로더 : 버킷 플러그인
  • 홈페이지 : 현재 없어졌다.
  • 라이선스 : GPL v3
  • 최신 버전 : 설치 가능 사이트
  • 추가 설명 : 페이퍼를 기반으로 만들어진 구현체이다. 페이퍼의 여러 문제점들을 해결했다고 자칭하는데... 그건 1.8.8 ~ 1.9.4 서버 한정이다. 1.8.8~1.9.4 서버의 경우 페이퍼보다 더 오래 지원되었고, 많은 버그 수정이 있었지만 2018년에 개발이 중단되면서 1.12.2의 경우 2019년 중반까지 개발된 페이퍼보다 더 안좋다.

7.6.4. Thermos

  • 이름 : Thermos
  • 한글 이름 : 써모스
  • API : Bukkit
  • Log4j 취약점 수정 여부: 수정되지 않음.
  • 지원 로더/플러그인 : 버킷 플러그인, 포지 모드
  • 마지막 버전 : 1.7.10-R0.2
  • 라이선스 : GPL v3
  • 다운로드 링크 : 링크
  • 추가 설명 : 1.7.10에서 가장 안정적으로 알려졌던 버킷 플러그인/포지 모드 를 지원했던 구현체였다. 현재는 개발이 중단되었다.

이 구현체는 Log4j 취약점이 수정되어있지 않다. 사용하지 않는 것을 강력하게 권장한다.

7.6.5. Cauldron (MCPC+)

Cauldron[83]
(콜드론)
API Bukkit API, Forge API
지원 중단 사유DMCA
지원 로더 버킷 플러그인, 포지 모드
지원 되었던 버전 1.2.5~1.7.10-R0.2
관련 웹사이트 미러
MCPC+ 즉, 모드 버킷으로 유명한 서버 구현. Craftbukkit DMCA 사건으로 인해 서버가 다운되면서 프로젝트가 강제로 종료되었다. 개발진은 Sponge로 넘어갔지만, KCauldron이라는 파생 프로젝트(fork)가 생겨났다. 하지만 이 또한 개발이 끊긴 것으로 보인다. 1.7.10 이상이라면 이걸 사용할 바에 Thermos 또는 Sponge 서버 , Catserver, Mohist 로 넘어가자.

7.6.6. Kettle

  • 이름: Kettle
  • 한글 이름 : 케틀
  • API: FML, Bukkit API, Spigot, Paper API, Sponge
  • 지원 로더 : 버킷 플러그인, 스피곳 플러그인, 페이퍼 플러그인, 포지 모드, 스펀지 플러그인
  • 관련 웹사이트 : https://github.com/KettleFoundation/Kettle
  • 라이선스 : GPL v3
  • 마지막 버전: 1.12.2 HEAD-a8543ec
  • 추가 설명: Cat Server 처럼 모드와 플러그인을 동시에 지원하는 구현체다. 지금은 개발이 종료되었다.

7.6.7. Yatopia

  • 이름 : Yatopia
  • API : Bukkit
  • 지원 중단 사유 : 개발자들의 단체 이탈
  • 지원 버전 : 1.16.2~1.16.5
  • 지원 로더 : 버킷 플러그인
  • 라이선스 : GPL v3
  • 홈페이지 : 깃허브 공식 다운로드
  • 추가 설명 : Tuinity를 포크하고 다수의 Paper[84] 포크와 Fabric 모드[85]에서 최적화 패치를 가져와 결합한 구현체이다. 여러가지의 최적화 옵션을 사용할 수 있다. 한때 호환성 문제가 심각했던적이 있었지만, 최신버전에서는 일부 고쳐졌음에도 불구하고 Yatopia에 대한 사람들의 시선이 좋지 못하자[86], 결국 개발자들이 단체로 이탈하고 주도 개발자마저 프로젝트를 종료 선언했다.

7.6.8. Waterfall

Waterfall
(워터펄)
API BungeeCord API, Waterfall API
지원 중단 사유 #
대체 서버 프로그램 Velocity
지원 버전 1.11~ 1.20
공식 다운로드 깃허브, 다운로드
PaperMC에서 개발했으며 BungeeCord를 포크해 여러 패치를 적용시킨 프록시 서버 프로그램이다. BungeeCord의 포크이기 때문에 거의 모든 BungeeCord의 기능이 Waterfall에서도 작동한다.

한국 표준시 기준 2024년 3월 27일 새벽 1시 39분에 PaperMC팀이 Waterfall에 대한 공식적인 지원을 종료하겠다고 발표했다.#

8. 사건 사고

8.1. 2014년 Craftbukkit DMCA 테이크 다운


사건에 대해 읽기 전 EULA 에 대해 알아가길 바람.
EULA란, End User License Agreement 의 약자로, 한국어로 최종 사용자 사용권 계약이라고 부른다.

마인크래프트 의 제작사 Mojang (이하 "모장") 에서 인터넷을 통해 실행되는 모든 서버[87]에 적용시킨 규칙으로 이를 어길 시 모장에서 제재한다.

EULA는 마인크래프트 제작사인 모장과 이 게임을 이용하는 사용자 간의 권리와 의무가 명시된 내용으로, 민사 상의 계약이기 때문에 지키지 않는다고 해서 감옥에 간다든가 그런 게 절대 아니다. 물론 계약은 계약이기에 약관상에 명시된 사항이라면 모장 사 측에서 임의로 처리가 가능하다. 예를 들어 계정을 삭제해버린다던지, 해당 IP를 게임 다운로드나 실행 관련 인터넷망에서 완전히 끊어버리던지.

자세한 내용은 Minecraft Eula(최종 사용자 라이선스 계약) 참고.

8.1.1. 발단

이 EULA 실시 이후 2014년 8월 21일, Craftbukkit 팀(이하 "버킷 팀") 의 리더인 EvilSeph트위터를 통해 아래와 같이 을 올림.
It's time to say good bye.
이제 헤어져야 할 시간입니다.
이에 마인크래프트의 수석 개발자인[88] 옌스 베리엔스텐이 위 글에 대해 아래와 같이 답변함.
Warren over at bukkit seems to have forgotten that the project was bought by Mojang over two years ago, and isn't his to discontinue.
버킷의 워렌은 2년 전 모장이 버킷팀을 인수했고, 2년 전부터 이 프로젝트는 모장의 소유였다는 것을 잊은 것 같네요. 이 프로젝트는 그의 마음대로 그만 둘 수 없습니다.
그리고 갑자기 버킷 팀의 총 책임자였던 Nathan Adams 가 아래와 같이 말함.
To make this clear: Mojang owns Bukkit. I'm personally going to update Bukkit to 1.8 myself. Bukkit IS NOT and WILL NOT BE the offical API.
명확하게 하겠습니다. 버킷은 모장의 것이 맞습니다. 저는 개인적으로 직접 1.8 업데이트를 진행할 것입니다. 버킷은 지금 공식 API가 아니고, 앞으로도 절대 그러하지 않을 겁니다.
그리고 이어서
I started Bukkit, I'm going to personally see it through for 1.8 Updating it now :)
저는 버킷 개발을 시작했습니다. 저는 개인적으로 지금 1.8로 업데이트하고 있다는 것을 보여줄 겁니다. :)

8.1.2. 전개

발단 이후, 버킷 팀에 약 25% 의 코드를 제공한 사람인 Wesley Wolfe (이하 "울프") 가 Bukkit API 를 이용한 모든 사이트에 DMCA 테이크 다운을 요청했고, 울프의 요청에 따라 GitHub 링크와, 공식 사이트의 다운로드 서버, JavaDocs 서버가 다운되었다.

울프가 신청한 DMCA 의 원문내용은 아래와 같다. 해석은 아래에.
From: Wesley Wolf <email redacted>
Date: 3 Septemver 2014 03:48
Subject: [SL] [abuse-google] Copyright

My name is Wesley Wolfe. A site hosted on an IP adress owned by Multiplay
(ip redacted) is infringing on my software copyright by the distribution
of a software known as CraftBukkit.

Original content can be fount at

https://github.com/Wolvereness/Bukkit-Bleeding/commits?author=Wolverness
https://github.com/Wolvereness/Bukkit-Bleeding/commit/0a0fee8be25bf8a732abff2d66a89a64614b6327

and the appropriate license for previously mentioned content can be found at

https://github.com/Wolvereness/Bukkit-Bleeding/blob/f210234e59275330f83b994e199c76f6abd41ee7/LICENCE.txt

The provided license requires the use of included or linking code to
provide the original source under the GNU GPL license version 3, or any
later version. An offical notice has been sent to Mojang AB, whereas the
Chief Operating Officer, Vu Bui, responded with the clear text:

Mojang has not authorized the inclusion of any of its proprietary
Minecraft Software (including its Minecraft Server software) within the
Bukkit project to be included in or made subject to any GPL or LGPL
license, or indeed any other open source license.

As the Minecraft Server software is included in CraftBukkit, and the
original code has not been provided or its user authorized, this is a
violation of my copyright. I have a goot faith belief the distribution of
the copyright owner, it's agent, or the low

Pages including infringing content:
http://dl.bukkit.org/ - links to:
http://dl.bukkit.org/latest-rb/craftbukkit.jar
http://dl.bukkit.org/latest-beta/craftbukkit-beta.jar
http://dl.bukkit.org/downloads/craftbukkit/ - links to 45 pages, with
infringing content begginning on craftbukkit build #1597 and currently
ending at craftbukkit build #3115, but please allow me not to enumerate
them all
http://dl.bukkit.org/downloads/craftbukkit/view/00703_1.1-R1/ (the
first infringing build)

I have a good faith belief that the above information is accurate and that
I am the copyright owner or authorized to act on the copyrigh owner's
behalf.

Pursuant to the Digital Millennium Copyright Act (17 U.S.C 짠 512(c)), the
above mentioned pages need to be expeditiously remove or access-of
disabled.

Electronically Singed:
위의 원문을 해석한 것이다. 애매한 부분이 있다면 정확하게 수정해주길 바람.
발신: 웨슬리 울프
날짜: 2014년 09월 03일 03시 48분
제목: 저작권

제 이름은 웨슬리 울프입니다. 멀티플레이가 소유한 IP 주소로 호스팅된 사이트의
Craftbukkit으로 알려진 소프트웨어가 저의 소프트웨어에 대한 저작권을 침해, 배포하고 있습니다.

원래 컨텐츠는 여기서 찾을 수 있습니다 :
https://github.com/Wolvereness/Bukkit-Bleeding/commits?author=Wolverness
https://github.com/Wolvereness/Bukkit-Bleeding/commit/0a0fee8be25bf8a732abff2d66a89a64614b6327

기타 이전에 언급한 내용을 통해 정당한 라이센스를 확인할 수 있습니다.
https://github.com/Wolvereness/Bukkit-Bleeding/blob/f210234e59275330f83b994e199c76f6abd41ee7/LICENCE.txt

라이센스는 GNU GPL 라이센스 버전 3 또는 그 이후 버전에 속하는 라이센스를 통해 제공하고 있으며
원본 소스를 제공하기 위해 코드를 링크하거나 포함하여 사용하는 것을 말합니다.

안내문을 모장에게 보냈으며, 운영책임자인 Vu Bui 는 명확한 글로 답변해줬습니다.

모장은 마인크래프트 소프트웨어 (서버 소프트웨어를 포함하여) 에 대한 권리와
버킷 프로젝트를 포함하든 GPL 또는 LGPL 라이센스로 만들어 졌든, 또는 실제 다른 오픈소스 라이센스이든
어떤 소유자에 대한 권리도 가지고 있지 않습니다.

Craftbukkit은 마인크래프트 서버를 포함하고 있음에도 불구하고, 원본 코드가 제공되지 않았으며, 권한도 명시하지 않았습니다.
이는 저의 저작권에 대한 위반입니다. Craftbukkit 을 배포하는 것은 소유권을 가진 사람의 권리(또는 법)을 무시한 행위 입니다.

저작권 침해를 포함하는 사이트들 입니다.
http://dl.bukkit.org/ - 이는 아래와 연결되어 있습니다.
http://dl.bukkit.org/latest-rb/craftbukkit.jar
http://dl.bukkit.org/latest-beta/craftbukkit-beta.jar
http://dl.bukkit.org/downloads/craftbukkit/ - 45페이지와 연결되어 있으며
제가 정리한 모든 것은 Craftbukkit 빌드 #1597 을 시작해 Craftbukkit 은 #3115 에서 끝납니다.
http://dl.bukkit.org/downloads/craftbukkit/view/00703_1.1-R1/
(제일 첫번째 위반 빌드 입니다.)

위의 정보가 정확하다고 보고 있으며
저는 저작권 소유주이며, 저작권 소유자의 권한을 행사할 수 있습니다.

디지털 밀레니엄 저작권 법 (DMCA) 에 의거
위에서 언급한 페이지들은 빠른 시간안에 삭제하거나 접속이 금지되어야 합니다.

웨슬리 울프
울프의 신청으로 Bukkit API 를 사용한 버킷이 먼저 내려가게 되었고, 그 다음 Spigot, Cauldron 순으로 내려가게 되었다.

버킷의 플러그인들도 하나 둘씩 업데이트를 하지 않게 되었다.
그러다 Spigot 이 버킷을 업데이트 한 이후로 중요한 플러그인들[89][90]은 계속해서 업데이트가 되고 있다. 거의 모든 플러그인이 Spigot-API 기반으로 업데이트되었다.

8.1.3. 결말

이 DMCA를 피하는 과정에서 여러 프로젝트가 주목받았다. 또 서버 소프트웨어의 주도권이 Spigot으로 넘어감에 따라 전체적인 업데이트 속도가 향상되었다.
Beat 패치, BuildTools 빌드, 서버 코드 자체 제작, Forge 의존 등 여러 DMCA 회피 방법이 나왔으며 이는 이후에 유사한 상황이 생길 시 유용하게 쓰일 것이다.


[1] 용어에 대한 정의는 위키피디아에 나와있다.[2] 압축을 풀면 사용할 수 없다![3] 단, 공유기를 사용 중이라면 공유기의 포트포워딩 설정을 통해 외부로 서버 포트를 개방해야 외부 유저들이 접속할 수 있다.[4] 파일을 더블 클릭하는 것과 같은 행위.[5] MineOS, Crafty Controller 등.[6] JDK(Java Development Kit)가 설치되어 있어도 작동한다. 이는 JDK에 JRE가 포함되어 있기 때문. 하지만 JRE가 용량을 더 적게 잡아먹으므로 모드 개발이라도 할 게 아닌 이상 JRE 설치가 권장된다. 1.16 기준으로 더이상 JRE를 지원하지 않는 서버 구현체(Paper 등)가 많아졌으므로 JDK를 설치하는것이 좋다.[7] 환경 변수가 설정 되었는지 확인하려면, 윈도우키+R 을 누른 후 cmd /k java --version 을 입력해보면 된다.[8] 이 폴더는 서버 월드, 플러그인, 설정 파일이 담길 폴더이므로 신중하게 정하자. 띄어쓰기나 기호가 없는 오로지 영문숫자_ 만으로 된 폴더명을 추천한다.[9] 어떤 구현물을 써야 할 지 모르겠다면 여기를 클릭해서 확인해보자.[10] 배치 파일 이름은 무엇으로 해도 상관없다.[11] 파일 이름과 확장자명을 올바르게 기입하지 않으면 서버가 켜지지 않는다.[12] Java를 설치했더라도 이 과정에서 Java가 잡히지 않거나, Java가 여러 버전이 깔려 있을 때는 설치된 경로에서 java.exe를 찾아 수동으로 지정해줘야 한다.[13] 플러그인이나 모드가 많거나 동시 접속자가 많으면 더 많은 을 할당할 필요가 있다. M 대신 G를 사용해 기가바이트 단위로 할당 가능하다. 1G=1024M[14] 경고가 나온다면 무시하고 실행하면 된다.[15] 폴더나 파일이 생성 되지 않는다변 .bat나.cmd 파일을 다시 메모장으로 열어 준 다음 서버 구현체 파일 이름과 메모장에 쓴 파일 이름이 일치한지 확인하면 된다.[16] 윈도우 방화벽을 열어주어야 랜서버로 같은 공유기 내에서 멀티를 할 수 있는 것이다.[17] 아웃바운드는 내가 접속하는 것, 인바운드는 남이 접속하는 것을 의미한다.[18] 프로그렘을 선택해서 자바로 지정해주어도 된다. jre에 있는 java.exe를 지정하면 된다.[19] 모든 로컬 포트로 설정해도 되지만 포트를 적게 열어두는 것이 그나마 보안에 도움이 된다.[20] 1000-2000이런 식으로 범위로 지정해주어도 된다. 다만 그 범위에 설정한 포트가 포함되어 있어야 된다.[21] 한 LG공유기로 예를 들자면 내부 포트를 지정된 범위에서만 선택 가능하다. ex)스타크래프트 1234. 메일 P2P 1555등등등 이런 경우면 여기에 맞게 외부 포트도 설정해주고 윈도우 방화벽도 다시 설정해주어야 하며 서버에서도 설정해주어야 한다.[22] 모뎀일 경우 통신사에 연락해야하는 경우가 많다.[23] 이것 역시 방법이 천차만별[24] 이 사이트에서 베드락 에디션 서버를 테스트하면 포트가 안열려있다고 나오지만 실제 접속해보면 문제 없이 접속되는 경우가 있다. 그리고 테스트할때는 서버가 실행되고 있어야 한다.[25] 한번 다르게 설정되었다면 아래 방법으로 해결될때 까지 절대 문제가 해결되지 않는다. 환장할 노릇[26] 데비안 계열은 apt-get, 레드햇 계열은 dnf 또는 yum, 아치 리눅스 계열은 pacman을 사용한다.[27] 일반인도 .kr이 들어간 도메인을 사용할 수 있다. 국가기관은 go.kr을 사용하며 go.kr은 일반인이 사용하지 못한다.[28] no-ip는한달에 한 번 갱신하여야 도메인을 계속 사용 할 수 있는데 비용은 무료이다. 기간이 다가오면 메일이 오니 참고하자[29] MCV.KR은 no-ip와 다르게 한달에 한 번 갱신을 할 필요가 없고, SRV레코드 까지 지원하며, 현재는 무료 DDoS 방어 연결 서비스를 재공하고 있다.[30] 새벽에만 서버를 운영하는 등.[31] 한때 하이픽셀이 이 호스팅 업체를 통해 운영되었으나 자체 운영으로 전환되었다.[Log4j_미수정] 1.18 이하 버전부터 Log4j 취약점이 수정되어있지 않다.[33] 다만 1.13부터 데이터 팩 기능이 추가되면서 플러그인을 어느정도 대체하는 것이 가능하다.[34] 경제, RPG, 미니게임 등을 모두 배제하고 마인크래프트 본연의 야생 생존만이 유일한 장르인 서버.[35] 또한 비-바닐라 서버에서는 기반암 파괴, 레일 복사 등과 같은 버그들이 자체 패치된 경우가 많아 일일이 서버 설정을 수정해야하는 귀찮은 단점이 있다. 반면 바닐라 서버에서는 버그들을 모두 별다른 설정 없이 재현 가능하기 때문에 야생 유저들에게는 오히려 이런 점이 장점이 될 수도 있다.[36] 업데이트 이전의 사진 파일:마인크래프트/서버/자바 에디션/버킷리스트2.png[37] 과거 깃허브 저장소가 있었으나 DMCA 사건 이후 비활성화 되었다.[38] 1.8 이전 버전은 BuildTools에서 구할 수 없어 2024년 기준 미리 컴파일된 파일을 직접 찾아야한다. 특별한 이유가 있지 않은 이상 1.8 이상의 버전을 사용하는 것을 권장한다.[39] 과거 깃허브 저장소가 있었으나 DMCA 사건 이후 비활성화 되었다.[40] Git 저장소에 저장되어 있는 소스코드를 내려받아 프로그램을 컴파일하는 방법이다. 윈도우 환경에서는 Git Bash 프로그램을 설치해야 했으나 그냥 CMD에다 쳐도 알아서 Git를 다운받아 진행한다.[41] -jar 과 서버파일.jar 사이 -DIReallyKnowWhatIAmDoingISwear 를 넣으면 20초 기다림 없이 시작할 수 있으나, 아무리 다시 빌드하기 귀찮더라도 계속 업데이트를 해주는 것을 권장한다. 정말로 귀찮은 경우 Paper 사용을 고려해보자.[42] 신규 버전의 Paper 업데이트 즉시 이전 버전의 지원은 종료된다.[Log4j미수정] 이 구현체는 1.7~1.8.9의 플레이어가 1.7.10 서버에 들어올 수 있는 구현체이다. 그러나 일반 버전도 ViaVersion이나 ProtocolSupport를 적용하면 최신버전까지도 지원할 수 있다. 단 Log4j 패치가 안되었으므로 위에 있는 필수적인 Log4j 패치 명령문을 cmd 파일에다가 입력해주고 웬만하면 지인들과 플레이할때만 사용하자.[44] 이마저도 일부 버그 한정. 대다수는 설정조차 제공되지 않는다.[45] 거의 모든 Bukkit API를 기반으로 하는 플러그인들과 호환되지 않는다. Folia 자체에서 지원되는 API로 코드를 바꿔야 하는데, Folia 전용으로 별도의 플러그인을 제공하는 프로젝트가 거의 없기 때문이다.[46] 이 주소를 git clone으로 복사해 직접 컴파일해야 한다. 공식 다운로드는 API상으로만 제공되며, Paper 팀에서는 가급적이면 이미 컴파일된 파일을 공유하지 말아달라 말하고 있다. 빌드 방법과 다운로드 API 두 가지 모두 모르는 경우 쓰지 않는것이 권장된다.[47] 기존에는 서버를 돌리는데 1코어만 사용해 코어의 개수가 많아져도 성능의 향상이 없다시피 했다. 그런데 이 구현을 사용하면 코어들을 구역별로 나눠 사용해 더 높은 성능을 낼 수 있는 것이다. 주로 스카이블럭과 SMP처럼 플레이어가 분산된 서버에서 큰 효과를 발휘한다.[48] Fabric, Sponge 등[49] 개발 기간만 따져도 최초 커밋을 기준으로 2024년 1월 기준 약 2년 7개월이다. 물론 2년이 짧은 시간은 아니지만 검증된 프로젝트들인 Craftbukkit과 Spigot은 10년 넘는 역사를 보여주고, 이들의 상위 호환인 Paper마저 10년이 코앞인 것을 보면 상대적으로 짧은편.[50] Folia 단독으로 확실하게 재현 가능하고 기본 Paper에서 재현되지 않는 경우 GitHub Issue를 생성하여 버그를 신고 할 수 있다.[51] 공식 문서상에서 최소 16 코어(스레드가 아니다.)가 Folia의 성능을 보기에 충분하다고 한다. 그렇다고해서 서버가 아예 안켜지는 것이 아니기에 서버를 여는 것 자체는 가능하다. 다만 플러그인 개발의 용도가 아닌 이상 실제 사용으로 쓰일 일은 거의 없어 보인다.[52] 모장이 개발한 마인크래프트 서버 소스코드[53] 이곳에서 받을 수 있는 클라이언트 설치파일로 포지서버 설치도 가능하다.[54] 이곳에서 받을 수 있는 클라이언트 설치파일로 포지서버 설치도 가능하다.[55] 인스톨러로 설치 후 모드를 적용하려면 API 파일을 모드 폴더에 넣어야 한다. 모드 폴더는 포지랑 동일하게 mods.[56] 이마저도 일부 버그 한정.[57] Glowstone보다 더 뛰어난 멀티쓰레드 환경이 구축되어있다. 월드뿐만 아니라 더 많은 부분이 멀티쓰레드로 설계되어있다.[58] 기본적인 게임 요소 또한 예외가 아니여서 라이브러리를 이용해 서버를 시작하면 특정 좌표에 스폰시키는 것과 플레이어 이름에 맞추어 스킨을 입히는 것조차 직접 구현해야하는 모습을 볼 수 있다.[59] 마인크래프트 1.20이 나온 시점에서 여전히 1.12.2까지만 지원할 정도이다.[60] 다운로드는 불가능하지만 Github에서 직접 받아 빌드할수는 있다.[61] 2018년 초 기준, 마인카트도 구현되지 않았다.[62] 다운받은 파일 이름 끝부분은 Forge 호환버전을 의미한다.[63] sk89q, Craftbukkit 시절 WorldEdit 플러그인으로 유명해진 개발자. 현재 스펀지 개발에서 손을 뗀 상태.[64] 스펀지 공식 문서는 오픈 소스이며, 누구든지 번역에 참여할 수 있다. 현재 한글 번역이 진행중이다.[65] -EssentialsX 개발자[66] 지원 종료[67] 최신 마인크래프트 버전도 패치하지 않으면 지원되지 않는 WorldEdit, Skript 등 플러그인도 완벽히는 아니지만 다른 하이브리드 구현체보단 잘 작동한다. 또한 자체적인 시스템을 추가하여 모드의 월드를 플러그인에 호환되도록 변환하는 시스템도 있다.[68] log4j 취약점이 수정된 업데이트가 출시되었다.[69] 이 플러그인 패치는 Mohist에서 해당 플러그인을 포크한 Github 에서 다운받아온다. 다만 이러한 방식이 플러그인의 원 제작자들 사이에서 큰 논란이 되었는데, 자세한 내용은 후술.[70] 이 버전과 1.16.5를 제외한 나머지는 깃허브에서 대놓고 안정성이 낮다고 나와있으니 해당 버전에서는 다른 서버 프로그램을 사용하는 것을 추천한다.[71] 자세한 설명은 이곳 참고.[72] Paper 1.13이상을 요구하며, Fabric의 경우 FabricProxy-Lite가 필요하다.[73] 기울임체로 표시된 서버 프로그램들은 지원은 되나 권장되지 않는 서버 프로그램들이다.[74] 문서 참조[75] 1.13~1.20.1 이용을 원할시 공식 문서를 참고하는것이 권장된다.[76] 후술할 Craftbukkit의 DMCA 사건 때문에 1.7.10 이하는 패치하고 싶어도 못 한다고 한다.[77] 1.15.2, 1.16.1, 1.16.3[78] 아카이브를 제외한 모든 다운로드 링크가 막혔다.[79] 그렇기에 대규모 서버를 열 생각이라면 이 구현체를 추천한다.[80] 청크 생성 속도, 빛 관련 성능에서 체감이 크다.[81] Purpur, Airplane, Yatopia[82] 이 버전들은 차라리 페이퍼를 쓰는게 낫다.[83] 원래 이름은 MCPC+ 였지만 1.7 업데이트를 진행하면서 Cauldron으로 변경되었다.[84] Akarin, EMC, Origami, Airplane[85] Lithium, Cadmium, Tic-Tacs[86] Paper 개발자의 문서중 하나, 또는 완전히 분리된 문서도 있다. ViaVersion은 완전히 구동되지 않도록 되어있다. (실행은 되지만, 다른 애드온을 꺼버린다.)[87] 즉, 친구들끼리 하마치를 통해 여는 서버도 포함. 사실 현실에 인맥이 있는 친구들끼리 하면 EULA에 위반 될 일을 할 필요가 없다[88] 마인크래프트 원개발자인 마르쿠스 페르손옌스 베리엔스텐이 모장에 온 이후, 수석 개발자 자리를 줬다.[89] WorldEdit, AuthMe, Factions 등등[90] Essentials 의 경우 Spigot 팀에서 직접 업데이트 한다고 알려져있다.