|
| 1 | +--- |
| 2 | +layout: news_post |
| 3 | +title: "Ruby 3.3.0-rc1 릴리스" |
| 4 | +author: "naruse" |
| 5 | +translator: "shia" |
| 6 | +date: 2023-12-11 00:00:00 +0000 |
| 7 | +lang: ko |
| 8 | +--- |
| 9 | + |
| 10 | +{% assign release = site.data.releases | where: "version", "3.3.0-rc1" | first %} |
| 11 | +Ruby {{ release.version }} 릴리스를 알리게 되어 기쁩니다. Ruby 3.3은 Prism이라는 이름의 새 파서를 추가하고, 파서 생성기로 Lrama를 사용하며, RJIT으로 명명된 새로운 순수 Ruby JIT 컴파일러를 추가하고, 특히 YJIT에서 많은 성능 향상이 있습니다. |
| 12 | + |
| 13 | +RC1 릴리스 이후로 ABI의 하위호환성을 깨트리는 변경은 가급적 피할 것입니다. 그래야 한다면, 릴리스 노트에서 해당 내용을 발표할 예정입니다. |
| 14 | + |
| 15 | +## Prism |
| 16 | + |
| 17 | +* [Prism 파서](https://github.com/ruby/prism)를 기본 gem에 추가했습니다. |
| 18 | + * Prism은 Ruby 언어를 위한 이식 가능하고, 에러 내성이 있으며 유지 보수 가능한 재귀 하향 파서입니다. |
| 19 | +* Prism은 프로덕션 환경에서 사용할 준비가 되어있으며 활발하게 유지보수되고 있으므로 Ripper 대신 이용할 수 있습니다. |
| 20 | + * Prism 사용 방법에 대한 [광범위한 문서](https://ruby.github.io/prism/)가 있습니다. |
| 21 | + * Prism은 CRuby에서 내부적으로 사용하는 C 라이브러리이자 Ruby 코드를 구문 분석해야 하는 모든 도구에서 사용할 수 있는 Ruby gem입니다. |
| 22 | + * Prism API에서 주목할 만한 메서드는 다음과 같습니다. |
| 23 | + * `Prism.parse(source)`는 ParseResult의 일부로 AST를 반환합니다. |
| 24 | + * `Prism.dump(source, filepath)`는 문자열로 직렬화된 AST를 반환합니다. |
| 25 | + * `Prism.parse_comments(source)`는 주석을 반환합니다. |
| 26 | +* 기여에 관심이 있다면 [Prism 저장소](https://github.com/ruby/prism)에서 직접 풀 리퀘스트나 이슈를 만들 수 있습니다. |
| 27 | + |
| 28 | +## Bison을 Lrama로 대체 |
| 29 | + |
| 30 | +* Bison 대신 [Lrama LALR 파서 생성기](https://github.com/yui-knk/lrama)를 사용하도록 변경했습니다. [Feature #19637](https://bugs.ruby-lang.org/issues/19637) |
| 31 | + * 관심이 있다면 [Ruby 파서의 미래 비전](https://rubykaigi.org/2023/presentations/spikeolaf.html)을 참고하세요. |
| 32 | + * 유지보수성을 위해 Lrama 내부 구문 분석기가 Racc에서 생성한 LR 구문 분석기로 대체되었습니다. |
| 33 | + * 매개변수화 규칙 `(?, *, +)`를 지원하며, Ruby의 parse.y에서 사용될 예정입니다. |
| 34 | + |
| 35 | +## RJIT |
| 36 | + |
| 37 | +* 순수 Ruby JIT 컴파일러 RJIT을 도입하고 MJIT을 대체했습니다. |
| 38 | + * RJIT은 Unix 플랫폼에서 x86-64 아키텍처만 지원합니다. |
| 39 | + * MJIT과 달리 런타임에 C 컴파일러가 필요하지 않습니다. |
| 40 | +* RJIT은 실험 목적으로 존재합니다. |
| 41 | + * 프로덕션 환경에서는 YJIT을 계속 사용해야 합니다. |
| 42 | +* Ruby용 JIT 개발에 관심이 있다면 [RubyKaigi 2023 3일 차에 있었던 k0kubun의 발표](https://rubykaigi.org/2023/presentations/k0kubun.html#day3)를 확인하세요. |
| 43 | + |
| 44 | +## YJIT |
| 45 | + |
| 46 | +* 3.2 버전 대비 주요 성능 개선 사항 |
| 47 | + * 스플랫과 나머지 인자 지원이 개선되었습니다. |
| 48 | + * 가상 머신의 스택 연산을 위해 레지스터가 할당됩니다. |
| 49 | + * 선택적 인수가 포함된 더 많은 호출이 컴파일됩니다. |
| 50 | + * 예외 처리기도 컴파일됩니다. |
| 51 | + * 클래스의 인스턴스 변수가 가지는 객체 형상의 조합이 매우 복잡한 경우에도 |
| 52 | + 컴파일되기 전의 바이트 코드로 전환되지 않습니다. |
| 53 | + * 지원되지 않는 호출 타입은 이제 컴파일되기 전의 바이트 코드로 전환되지 않습니다. |
| 54 | + * `Integer#!=`, `String#!=`, `Kernel#block_given?`, `Kernel#is_a?`, |
| 55 | + `Kernel#instance_of?`, `Module#===`은 특별히 최적화되었습니다. |
| 56 | + * 이제 optcarrot에서 인터프리터보다 3배 이상 빠릅니다! |
| 57 | +* 3.2보다 메모리 사용량이 크게 개선되었습니다. |
| 58 | + * 컴파일된 코드의 메타데이터가 훨씬 적은 메모리를 사용합니다. |
| 59 | + * ARM64에서 더 작은 코드를 생성합니다. |
| 60 | +* 3.2보다 컴파일 속도가 약간 개선되었습니다. |
| 61 | +* 실행 시간에 YJIT을 활성화할 수 있는 `RubyVM::YJIT.enable`이 추가됩니다. |
| 62 | + * 실행 명령의 인수나 환경 변수의 변경 없이 YJIT을 실행할 수 있습니다. |
| 63 | + * 애플리케이션 부팅이 완료된 후에 YJIT를 활성화하는 데에도 사용할 수 있습니다. |
| 64 | + 부팅 시 YJIT를 비활성화한 상태에서 다른 YJIT 옵션을 사용하려는 경우 `--yjit-disable`을 사용할 수 있습니다. |
| 65 | +* 코드 GC는 이제 비활성화된 상태로 시작하며, `--yjit-exec-mem-size`를 새 코드 컴파일을 멈추는 |
| 66 | + 최대 상한으로 취급합니다. |
| 67 | + * unicorn과 포크를 사용하는 서버에서 더 나은 쓰기 시 복사 동작을 생성할 수 있습니다. |
| 68 | + * 코드 GC로 인한 급격한 성능 하락이 사라집니다. |
| 69 | + * 필요하다면 `--yjit-code-gc`로 코드 GC를 활성화할 수 있습니다. |
| 70 | +* `--yjit-stats`로부터 생성된 `ratio_in_yjit` 통계는 릴리스 빌드에서도 이용 가능하며, |
| 71 | + 대부분의 통계에 접근하는 데 특수한 통계나 개발 빌드는 더 이상 필요하지 않습니다. |
| 72 | +* 종료 추적 옵션이 이제 샘플링을 지원합니다. |
| 73 | + * `--trace-exits-sample-rate=N` |
| 74 | +* Linux perf로 프로파일링을 용이하게 할 수 있도록 `--yjit-perf`가 추가됩니다. |
| 75 | +* 보다 철저한 테스트와 여러 버그 수정 |
| 76 | + |
| 77 | + |
| 78 | +### M:N 스레드 스케쥴러 |
| 79 | + |
| 80 | +* M:N 스레드 스케쥴러가 추가됩니다. [[Feature #19842]](https://bugs.ruby-lang.org/issues/19842) |
| 81 | + * M개의 Ruby 스레드를 N개의 네이티브 스레드(OS 스레드)로 관리하므로 스레드의 생성, 관리 비용이 절감됩니다. |
| 82 | + * C 확장 호환성에 문제가 발생할 가능성이 있으므로, 주 Ractor에서의 기본 설정은 비활성입니다. |
| 83 | + * `RUBY_MN_THREADS=1` 환경 변수를 사용해 주 Ractor에서 M:N 스레드를 활성화할 수 있습니다. |
| 84 | + * M:N 스레드는 주 Ractor가 아닌 Ractor에서 활성화되어 있습니다. |
| 85 | + * `RUBY_MAX_CPU=n` 환경 변수는 `N`(네이티브 스레드의 최대 개수)의 최댓값을 지정합니다. 기본값은 8입니다. |
| 86 | + * 하나의 Ractor에서는 하나의 Ruby 스레드만 실행 가능하므로 실제로 사용되는 네이티브 스레드의 개수는 `RUBY_MAX_CPU`에서 지정한 숫자나 실행 중인 Ractor의 개수보다 작습니다. 그러므로 (대다수를 차지하는) 단일 Ractor 애플리케이션에서는 하나의 네이티브 스레드를 사용합니다. |
| 87 | + * 블로킹 동작을 처리하기 위해, `N`개 이상의 네이티브 스레드가 사용될 수 있습니다. |
| 88 | + |
| 89 | +## 그 이외의 주목할 만한 새 기능 |
| 90 | + |
| 91 | + |
| 92 | + |
| 93 | +### 언어 |
| 94 | + |
| 95 | + |
| 96 | +## 성능 향상 |
| 97 | + |
| 98 | +* `defined?(@ivar)`가 객체 형상에 맞게 최적화됩니다. |
| 99 | +* `Socket.getaddrinfo`와 같은 이름 해결을 (POSIX 스레드가 사용 가능한 환경에서) 중단할 수 있게 됩니다. [Feature #19965](https://bugs.ruby-lang.org/issues/19965) |
| 100 | + * 이를 위해, getaddrinfo나 getnameinfo를 호출할 때마다 POSIX 스레드를 생성합니다. 이 영향으로 이름 해결에 약간의 오버헤드가 발생합니다(실험에서는 약 2.5배). 대부분의 애플리케이션에서 이름 해결의 오버헤드가 문제가 될 것이라고는 생각하지 않습니다만, 만약 그러한 현상을 확인하거나, 이 변경으로 인한 의도치 않은 영향을 발견했다면 부디 알려주세요. |
| 101 | +* 가비지 컬렉터의 몇몇 성능 향상 |
| 102 | + * 오래된 객체가 참조하는 어린 객체는 이제 즉시 오래된 객체로 마킹되지 않습니다. |
| 103 | + 이 동작은 메이저 GC의 빈도를 상당히 낮춰줍니다. |
| 104 | + [[Feature #19678]](https://bugs.ruby-lang.org/issues/19678) |
| 105 | + * 메이져 GC를 야기하는 보호받지 않은 객체의 숫자를 제어하는 |
| 106 | + 새로운 변수 `REMEMBERED_WB_UNPROTECTED_OBJECTS_LIMIT_RATIO`가 추가되었습니다. |
| 107 | + 기본값은 `0.01` (1%)입니다. 이는 메이저 GC의 빈도를 상당히 낮춰줍니다. |
| 108 | + [[Feature #19571]](https://bugs.ruby-lang.org/issues/19571) |
| 109 | + * `Time`, `Enumerator`, `MatchData`, `Method`, `File::Stat`, `BigDecimal` 등의 |
| 110 | + 주요 타입에 부족했던 쓰기 보호가 구현되었습니다. |
| 111 | + 이는 마이너 GC에 걸리는 시간과 메이저 GC 빈도를 상당히 줄여줍니다. |
| 112 | + * `Hash`, `Time`, `Thread::Backtrace`, `Thread::Backtrace::Location`, |
| 113 | + `File::Stat`, `Method` 등의 대부분의 주요 클래스는 이제 가변 폭 할당을 사용합니다. |
| 114 | + 이는 해당 클래스의 할당 및 할당 해제 속도를 빠르게 만들며, 메모리 사용량과 |
| 115 | + 힙 파편화를 줄여줍니다. |
| 116 | + * 가비지 컬렉터에 약한 참조가 추가됩니다. [Feature #19783](https://bugs.ruby-lang.org/issues/19783) |
| 117 | + |
| 118 | + |
| 119 | +## 그 이외의 3.2 이후로 주목할 만한 변경 |
| 120 | + |
| 121 | +### IRB |
| 122 | + |
| 123 | +IRB에 여러 개선 사항이 추가됩니다. 다음과 같은 내용이 포함됩니다. |
| 124 | + |
| 125 | +- 고급 `irb:rdbg` 통합 기능은 `pry-byebug`와 동등한 디버깅 경험을 제공합니다. ([문서](https://github.com/ruby/irb#debugging-with-irb)). |
| 126 | +- `ls`와 `show_source`, `show_cmds`와 같은 명령어에서 페이징을 지원합니다. |
| 127 | +- `ls`, `show_source` 명령에서 더 정확하고 유용한 정보를 제공합니다. |
| 128 | +- 타입 분석을 사용하는 실험적인 자동 완성 기능을 제공합니다. ([문서](https://github.com/ruby/irb#type-based-completion)). |
| 129 | +- Reline::Face 클래스의 도입으로 자동완성 다이얼로그의 글씨 색과 스타일이 변경 가능합니다. ([문서](https://github.com/ruby/ruby/blob/master/doc/reline/face.md)) |
| 130 | + |
| 131 | +또한, IRB는 광범위한 리팩토링을 거쳤으며, 향후 개선이 용이하도록 많은 버그 수정이 이루어졌습니다. |
| 132 | + |
| 133 | +## 호환성 문제 |
| 134 | + |
| 135 | +주의: 기능 버그 수정은 포함되어 있지 않습니다. |
| 136 | + |
| 137 | +* 블록에서 매개변수 없이 `it`을 호출하는 기능은 삭제 예정입니다. |
| 138 | + Ruby 3.4부터 `it`은 첫 번째 블록 인수를 가리킵니다. |
| 139 | + [Feature #18980](https://bugs.ruby-lang.org/issues/18980) |
| 140 | + |
| 141 | +### 삭제된 상수 |
| 142 | + |
| 143 | +폐기 예정이었던 상수가 삭제됩니다. |
| 144 | + |
| 145 | + |
| 146 | + |
| 147 | +### 삭제된 메서드 |
| 148 | + |
| 149 | +폐기 예정이었던 메서드가 삭제됩니다. |
| 150 | + |
| 151 | +### 삭제된 환경 변수 |
| 152 | + |
| 153 | +폐기 예정이었던 환경 변수가 삭제됩니다. |
| 154 | + |
| 155 | +* 환경 변수 `RUBY_GC_HEAP_INIT_SLOTS`는 폐기 예정이었으며 아무 효과도 없습니다. 대신 환경 변수 `RUBY_GC_HEAP_{0,1,2,3,4}_INIT_SLOTS`를 사용해 주세요. [Feature #19785](https://bugs.ruby-lang.org/issues/19785) |
| 156 | + |
| 157 | +## Stdlib 호환성 문제 |
| 158 | + |
| 159 | +### `ext/readline` 폐기 |
| 160 | + |
| 161 | +* 우리는 `ext/readline` API와 호환되는 순수 Ruby 구현인 `reline`을 가지고 있습니다. 앞으로는 `reline`에 의존할 것입니다. `ext/readline`을 사용해야 하는 경우, `gem install readline-ext`를 사용하여 rubygems.org를 통해 `ext/readline`을 설치할 수 있습니다. |
| 162 | +* 이제 더 이상 `libreadline` 또는 `libedit`과 같은 라이브러리를 설치할 필요가 없습니다. |
| 163 | + |
| 164 | +## C API 변경 |
| 165 | + |
| 166 | +### 갱신된 C API |
| 167 | + |
| 168 | +다음 API가 갱신됩니다. |
| 169 | + |
| 170 | + |
| 171 | + |
| 172 | +### 삭제된 C API |
| 173 | + |
| 174 | +다음 폐기 예정인 API가 삭제됩니다. |
| 175 | + |
| 176 | + |
| 177 | + |
| 178 | +## 표준 라이브러리 갱신 |
| 179 | + |
| 180 | +사용자가 미래의 Ruby 버전에서 내장될 예정의 gem을 직접 불러올 때 RubyGems와 Bundler가 경고 문구를 출력합니다. |
| 181 | + |
| 182 | +다음 라이브러리가 대상입니다. |
| 183 | + * abbrev |
| 184 | + * base64 |
| 185 | + * bigdecimal |
| 186 | + * csv |
| 187 | + * drb |
| 188 | + * getoptlong |
| 189 | + * mutex_m |
| 190 | + * nkf |
| 191 | + * observer |
| 192 | + * racc |
| 193 | + * resolv-replace |
| 194 | + * rinda |
| 195 | + * syslog |
| 196 | + |
| 197 | +다음 기본 gem이 추가되었습니다. |
| 198 | + |
| 199 | +* prism 0.15.1 |
| 200 | + |
| 201 | +다음 기본 gem이 갱신되었습니다. |
| 202 | + |
| 203 | +* RubyGems 3.5.0.dev |
| 204 | +* base64 0.2.0 |
| 205 | +* benchmark 0.3.0 |
| 206 | +* bigdecimal 3.1.5 |
| 207 | +* bundler 2.5.0.dev |
| 208 | +* cgi 0.4.0 |
| 209 | +* csv 3.2.8 |
| 210 | +* date 3.3.4 |
| 211 | +* delegate 0.3.1 |
| 212 | +* drb 2.2.0 |
| 213 | +* english 0.8.0 |
| 214 | +* erb 4.0.3 |
| 215 | +* etc 1.4.3.dev.1 |
| 216 | +* fcntl 1.1.0 |
| 217 | +* fiddle 1.1.2 |
| 218 | +* fileutils 1.7.2 |
| 219 | +* find 0.2.0 |
| 220 | +* getoptlong 0.2.1 |
| 221 | +* io-console 0.6.1.dev |
| 222 | +* irb 1.8.3 |
| 223 | +* logger 1.6.0 |
| 224 | +* mutex_m 0.2.0 |
| 225 | +* net-http 0.4.0 |
| 226 | +* net-protocol 0.2.2 |
| 227 | +* nkf 0.1.3 |
| 228 | +* observer 0.1.2 |
| 229 | +* open-uri 0.4.0 |
| 230 | +* open3 0.2.0 |
| 231 | +* openssl 3.2.0 |
| 232 | +* optparse 0.4.0 |
| 233 | +* ostruct 0.6.0 |
| 234 | +* pathname 0.3.0 |
| 235 | +* pp 0.5.0 |
| 236 | +* prettyprint 0.2.0 |
| 237 | +* pstore 0.1.3 |
| 238 | +* psych 5.1.1.1 |
| 239 | +* rdoc 6.6.0 |
| 240 | +* reline 0.3.9 |
| 241 | +* rinda 0.2.0 |
| 242 | +* securerandom 0.3.0 |
| 243 | +* shellwords 0.2.0 |
| 244 | +* singleton 0.2.0 |
| 245 | +* stringio 3.0.9 |
| 246 | +* strscan 3.0.7 |
| 247 | +* syntax_suggest 1.1.0 |
| 248 | +* tempfile 0.2.0 |
| 249 | +* time 0.3.0 |
| 250 | +* timeout 0.4.1 |
| 251 | +* tmpdir 0.2.0 |
| 252 | +* tsort 0.2.0 |
| 253 | +* un 0.3.0 |
| 254 | +* uri 0.13.0 |
| 255 | +* weakref 0.1.3 |
| 256 | +* win32ole 1.8.10 |
| 257 | +* yaml 0.3.0 |
| 258 | +* zlib 3.1.0 |
| 259 | + |
| 260 | +다음 기본 gem이 내장됩니다. |
| 261 | + |
| 262 | +* racc 1.7.3 |
| 263 | + |
| 264 | +다음 내장 gem이 갱신됩니다. |
| 265 | + |
| 266 | +* minitest 5.20.0 |
| 267 | +* rake 13.1.0 |
| 268 | +* test-unit 3.6.1 |
| 269 | +* rexml 3.2.6 |
| 270 | +* rss 0.3.0 |
| 271 | +* net-imap 0.4.4 |
| 272 | +* net-smtp 0.4.0 |
| 273 | +* rbs 3.2.2 |
| 274 | +* typeprof 0.21.8 |
| 275 | +* debug 1.8.0 |
| 276 | + |
| 277 | +기본 gem 또는 내장 gem에 대한 자세한 내용은 [Logger](https://github.com/ruby/logger/releases)와 같은 |
| 278 | +GitHub 릴리스 또는 변경 로그에서 확인하세요. |
| 279 | + |
| 280 | +더 자세한 내용은 [NEWS](https://github.com/ruby/ruby/blob/{{ release.tag }}/NEWS.md)나 |
| 281 | +[커밋 로그](https://github.com/ruby/ruby/compare/v3_2_0...{{ release.tag }})를 |
| 282 | +확인해 주세요. |
| 283 | + |
| 284 | +이러한 변경사항에 따라, Ruby 3.2.0 이후로 [파일 {{ release.stats.files_changed }}개 수정, {{ release.stats.insertions }}줄 추가(+), {{ release.stats.deletions }}줄 삭제(-)](https://github.com/ruby/ruby/compare/v3_2_0...{{ release.tag }}#file_bucket)가 |
| 285 | +이루어졌습니다! |
| 286 | + |
| 287 | + |
| 288 | +## 다운로드 |
| 289 | + |
| 290 | +* <{{ release.url.gz }}> |
| 291 | + |
| 292 | + SIZE: {{ release.size.gz }} |
| 293 | + SHA1: {{ release.sha1.gz }} |
| 294 | + SHA256: {{ release.sha256.gz }} |
| 295 | + SHA512: {{ release.sha512.gz }} |
| 296 | + |
| 297 | +* <{{ release.url.xz }}> |
| 298 | + |
| 299 | + SIZE: {{ release.size.xz }} |
| 300 | + SHA1: {{ release.sha1.xz }} |
| 301 | + SHA256: {{ release.sha256.xz }} |
| 302 | + SHA512: {{ release.sha512.xz }} |
| 303 | + |
| 304 | +* <{{ release.url.zip }}> |
| 305 | + |
| 306 | + SIZE: {{ release.size.zip }} |
| 307 | + SHA1: {{ release.sha1.zip }} |
| 308 | + SHA256: {{ release.sha256.zip }} |
| 309 | + SHA512: {{ release.sha512.zip }} |
| 310 | + |
| 311 | +## Ruby는 |
| 312 | + |
| 313 | +Ruby는 1993년에 Matz(마츠모토 유키히로) 씨가 처음 개발했고, |
| 314 | +현재는 오픈 소스로서 개발되고 있습니다. 여러 플랫폼에서 동작하며, |
| 315 | +특히 웹 개발에서 전 세계적으로 이용되고 있습니다. |
0 commit comments