In-Browser Performance Linting With Feature Policies : Feature-Policy 헤더를 이용해서 웹사이트의 성능을 검사하는 방법을 소개하는 글이다. Feature-Policy의 oversized-images, unoptimized-lossy-images, unoptimized-lossless-images, unsized-media를 이용해서 의도하지 않은 이미지를 찾아내서 브라우저가 차단할 수 있도록 할 수 있다. 현재 모든 브라우저가 지원하는 것은 아니지만 프로덕션에 내보내진 않고 크롬 익스텐션으로 만들어서 개발하면서 정책을 위반하는 미디어가 있는지를 검사한다.(영어)
새로운 마크다운 파서가 필요한 이유 : 인기를 많이 끌고 있는 Toast UI 에디터에서 마크다운 지원을 강화하기 위해서 새로운 마크다운 파서를 만들게 되는 과정을 적은 글이다. 마크다운을 실시간 미리 보기와 함께 사용하고 있지만 여러 마크다운 라이브러리가 용도에 따라 나뉘어 있기 때문에 구문 강조가 다르게 되는 경우가 있고 마크다운을 수정할 때마다 미리 보기를 새로 갱신하기 때문에 성능에 대한 문제가 있다. 이런 부분을 이미 해결하려고 했던 시도가 IDE에 있는데 크게 트리시터(tree-sitter)와 언어 서버 프로토콜(LSP)로 나눌 수 있고 이에 대한 장단점을 설명한 뒤 Toast UI의 목적에 맞게 commonmark.js를 수정해서 ToaskMark를 만들었다고 한다.(한국어)
Profiling React.js Performance : Reactdml Profiler API를 이용해서 컴포넌트의 성능을 측정하고 클릭 등 인터렉션의 성능을 측정할 수 있는 Interaction Tracing API를 사용하는 방법을 설명하고 Puppeteer로 이를 자동화하는 방법을 소개한다.(영어)
(번역) 세상은 왜 CSS개발자를 필요로 하는가? : CSS의 발전 과정을 설명하고 Bootstrap부터 CSS-in-JS까지 발전해오면서 CSS를 제대로 안 배우고 사용하는 방향으로 가고 있다고 하고 특히 CSS-in-JS에서 CSS 클래스를 기계적인 문자로 바꾸는 것을 비난하고 있다. 이렇게 했을 때 CSS가 꼬이면 문제가 되고 CSS 개발자라고 부르는 전문 인력이 따로 필요하다고 주장한다. 이 사람의 주장만큼은 아니어도 CSS가 중요하다는 부분에는 동의하기에 CSS 개발자를 따로 분리하기보다는 CSS도 중요한 이유를 더 자세히 설명했으면 좋았을 것 같지만 한번 고민해 볼 만한 이슈라고 생각한다.(한국어)
Moving from reCAPTCHA to hCaptcha : CloudFlare에서 Google의 reCAPTCHA를 계속 사용하고 있었고 그동안 프라이버시 문제로 얘기는 있었지만, 우선순위로 인해 작업은 진행되지 않다가 이번에 Google이 reCAPTCHA에 과금을 하기로 하면서 여러 솔루션을 비교한 뒤에 hCaptcha로 갈아타기로 했다고 한다.(영어)
서머타임과 배치작업 : 서머타임이 있는 지역에서 크론 등의 작업을 돌릴 때 작업이 안 돌거나 혹은 두 번 돌거나 다른 시간에 도는 상황을 파악하기 위해서 crontab과 Spring scheduled task를 만들어서 비교해 본 결과이다. crontab은 문서에 서머타임에 대한 고려가 어느 정도 되어 있는 것으로 나와 있고 실제로도 실험 결과에서도 기대에 가깝게 결과가 나왔다. 출장 갔다가 비슷한 고민 한 적이 있는데 서머타임이 없는 우리나라에서는 겪기 힘든 경험이고 1년에 1번밖에 실험을 못 한다는 점에서도 재밌는 글이다.(한국어)
Go의 철학 : The Zen of Go를 번역한 글이다. Go의 패키지는 하나의 목적만 달성하고 에러는 명시적으로 처리하며 동시성은 호출자에게 맡긴다는 등 Go의 철학을 정리했다.(한국어)
Deno 1.0 : TypeScript 런타임인 Deno의 1.0 버전 릴리스가 5월 13일로 잡혔다.(영어)
AWS CLI v2에서 아마존 ECR 로그인 방법 변경 : AWS CLI v2에서는 기존과 ECR 로그인 방법이 달라져서 기존에 사용하던 aws ecr get-login 대신 aws ecr get-login-password를 사용해야 하는데 이 방법을 설명하고 있다.(한국어)
HashiCorp Joins the CNCF : Terraform, Consul 등을 만든 HashiCorp가 Cloud Native Computing Foundation(CNCF)에 합류했다.(영어)
DevOps 팀은 원격근무를 추구하면 안되는 것일까? : HBSmith가 창업했을 때부터 15명이 넘는 지금까지 원격으로 업무를 진행하면서 어떻게 DevOps 문화를 유지하고 있고 업무를 진행하는지를 정리한 슬라이드와 이를 정리한 글이다. 2주 단위 스프린트를 진행하면서 각 이슈의 스토리 포인트를 부여해서 진행하고 매일 Did list를 작성해서 서로 간의 업무를 공유하고 있다. 스토리 포인트 부분에서 "점점 더 많은 이슈를 처리할 수 있게 되는 게 아니라, 동료와 자기 자신 모두가 납득할수 있는 기준을 스스로 세우고 지킬수 있게 되는 것이다" 부분이 인상적이었다.(영어)
실리콘밸리 스타트업에서 성장하기 : 샌프란시스코에서 심플해빗이라는 스타트업에 Growth Lead로 합류해서 2년간 배운 것들을 정리한 글이다. 심플해빗을 성장시키기 위해서 어느 부분 최적화했는지에 관한 고민의 과정이 나와 있고 그에 따라 500%의 매출 성장을 이루면서 스스로 "문제를 정의하고, 해결하는 사람"으로 정의하고 원칙을 세워서 진행했다고 하는데 얼마나 많이 고민하면서 문제를 해결했는지를 알 수 있다.(한국어)
IT 업계 뉴스
GitHub is now free for teams : GitHub이 작년에도 많은 기능을 무료로 풀었지만, 아직 조직을 만들어서 비공개로 개발하려면 유료 결제를 해야 했는데 이번에 이 기능까지도 무료로 풀었다. 조직에서도 비공개 저장소와 협업자를 추가할 수 있고 코드 소유자 등의 유료 기능은 $9에서 $4로 인하되었다.(영어)
Comments