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