반응형

요즘 딥러닝과 파이썬만 공부하다 오랜만에 자바 스프링 한 번 해보려고 VSCode를 실행했다.

너무 오래되었는지 오류가 났다.

VSCode는 기존에 세팅 방식에서 변한 건 없고 jdk 버전만 올려주니 잘 되었다.

Spring.io에서 STS를 다운 받아서 실행하는데 오류가 난다.

 

오류메시지

오늘 일자로 STS(이클립스 버전) 받았고 jdk17 버전으로 세팅했다.

Spring Web 프로젝트를 Gradle로 생성했다.

그러자 위 오류가 났다.

오류정보 : 'Import Gettiing Started Content' has encountered a problem. ToolchainDownloadFailedException: No locall installed toolchains match and toolchain download repositories have not been configured.

사실 첨 보는 오류였다.

오류 정보도 친절하지 않네. 어이구야.

같은 조건으로 Maven 프로젝트는 문제 없이 잘 된다.

Gradle에서 jdk 버전 체크를 하는 듯 다.

 

해결방법 

jdk17, jdk19로 했더니 계속 오류가 났다.

오늘자로 받은 Spring STS는 최저 jdk 버전이 21부터 시작한다.

1. jdk21 버전을 다운 받는다. (https://jdk.java.net/archive/)

2. 원하는 위치에 압축을 푼다. (예: C:\jdk-21.0.2)

3. 환경설정에서 JAVA_HOME의 jdk 위치를 수정해서 넣어준다.

4. 명령 프롬프트에서 잘 세팅 되었는지 확인한다.

5. Spring STS를 실행하고 상단 Window>Preferences를 클릭한다.

6. Java>Compiler를 선택하고 JDK를 21로 변경 후 Apply(적용)한다.

7. Java>Installed JREs를 선택한 후 21 버전으로 선택 후 apply(적용)을 클릭한다.

8. Spring STS를 종료한다.

9. 원도우 탐색기를 실행해서 Spring STS가 설치된 위치로 이동한다.

10. SpringToolSuite4.ini 파일에 마우스 우클릭을 해서 메모장에서 편집을 클릭한다.

11. -vm을 찾고 그 아래 있던 정보는 지우고 새로 설치한 jdk위치를 포함한 아래 경로를 넣어주고 저장한다.

12. Spring STS를 다시 실행한다.

13. Spring Web Gradle 프로젝트를 생성한다.

 

이제 잘 실행될 것이다.

 

PS. SpringWeb 프로젝트를 생성했지만 Boot Dashboard의 local에 추가가 안되면 프로젝트 생성에 오류가 발생한 것이다. 

프로젝트가 오류 없이 생성되면 아래와 같이 자동으로 프로젝트가 추가된다.

 

이번 포스팅에서 ToolchainDownloadFailedException: No locall installed toolchains match and toolchain download repositories have not been configured.

오류 해결방법에 대해 알아봤다.

삽질은 이제 그만...

 

 

 

 

 

 

 

반응형
반응형

 

개발자는 글쓰기를 잘해야 한다

 

25년 차 개발자인 나는 지금도 글쓰기 책도 읽고 쓰기 연습을 한다.

개발자가 코딩만 잘하면 되지 글쓰기는 왜 배울까?

정규직 개발자, 프로젝트에 투입된 개발자는 코딩도 하지만 문서 작업도 한다.

 

개발자가 글쓰기를 잘해야 하는 이유

개발자가 코딩만 하면 좋겠지만 문서 작업도 엄청나다.

글쓰기를 잘해야 문서 작업도 잘한다.

개발자가 글쓰기를 못하면 어떻게 될까?

매주 작성하는 주간보고서를 보자.

나는 일주일간 작업한 내용을 빠짐없이 작성했고 제출한다.

리더는 주간 보고서를 보고 자신이 이해할 때까지 질문을 한다.

개발자가 주는 대로 취합했다가 고객사 주간보고 때 문제가 생기기 때문이다.

상세하지 않은 내용에 대해 고객이 문의를 하면 보고자도 체크를 하지 않았기에 답을 못한다.

그래서 리더는 취합할 때 본인이 이해할 수 있는 수준으로 작성을 요청하거나 질문을 통해 수정한다.

매주 반복된다면 리더는 개발자에게 짜증이 날 것이다.

글쓰기 능력이 필요한 상황이다.

 

개발자 글쓰기의 핵심은?

글쓰기의 핵심은 글을 읽는 독자(리더, 고객)를 위한 것이다.

개발자 기준으로 쓰면 안 된다.

글로써 상대에게 내 의견을 전달하기 때문이다.

잘못 쓴 글이 얼마나 많은 문제를 만드는지 예를 들어보자.

올해 초 일이다.

어떤 직원이 고객사에 보낼 메일을 작성 중이었다.

요청 문서를 보고 궁금하거나 이해가 안 되는 부분에 대한 정보를 얻기 위해서였다.

위에서 좀 도와주라는 요청이 있어서 옆에 갔다.

그 직원이 쓴 메일을 읽어봤는데 질문의 뜻을 이해하지 못했다.

그 직원에게 정확하게 원하는 정보가 무엇인지 물었다.

메일에 쓴 질문에 대해 말로 추가 설명을 해줬지만 이해가 안 가서 계속 돼 물었다.

순간 이 직원은 무엇을 물어봐야 하는지 조차 모른다는 사실을 알았다.

요청서의 내용을 읽었지만 이해가 안 되었고 무엇을 알아야 하는지도 몰랐다.

고급 등급인데 원하는 정보를 얻기 위한 질문도 못하는 상황이었다.

나도 이해가 필요해서 질문을 하다 보니 고객사에 메일을 몇 번 보낸 상황이었다.

고객사도 질문지 메일을 받고 답답해하는 상황이었다.

질문이 정확하지 않으니 고객사 답변도 엉뚱한 내용으로 채워져 있었다.

요청서를 보고 상황을 파악한 뒤 필요한 질문을 다시 만들어줬다.

그렇게 메일을 보내니 고객사도 무엇을 원하는지 알았다면서 정확한 답변을 보내왔다.

글쓰기가 왜 필요한지 알겠는가?

글쓰기의 핵심은 내가 읽기 위해 쓰는 것이 아니다. 상대방이 읽을 글을 쓰는 것이다.

 

글쓰기를 잘하면 말도 논리적으로 잘하게 된다

수많은 프로젝트를 하면서 많은 다툼을 봤다.

다툼의 가장 큰 이유는 잘못된 의사전달과 소통이었다.

고객은 A를 생각하고 요청을 하면 기획이나 개발은 B를 생각하고 실행한다.

시간이 지나고 결과물이 나오고 A를 기대했던 고객은 B를 보고 어리둥절해한다.

그리고 다툼이 시작된다.

실제로 뉴스에도 나왔던 유명 프로젝트를 진행하다 겪은 일이다.

고객에서 회의를 요청했다.

기획과 리더들이 모였다.

고객사는 추가 요청 A에 대해 설명을 했다.

기획과 리더들과 A에 대한 이야기를 하다가 B 이야기도 나왔다.

사실 B도 고객사가 요청한 내용은 맞다.

이번 회의는 B가 아닌 A가 추가되었다는 내용이었다.

지금 기획은 A에 관심이 없고 B에 대한 결정이 필요했다.

회의가 끝날즈음 기획은 B에 대해 정리를 하고 고객도 동의했다.

A에 대한 정리는 없었다.

기획에게 A는 어떻게 할 거냐고 물으니 B만 하면 된다고 했다.

지금 이 회의는 추가 요청인 A에 대한 의사결정을 하는 자리라고 다시 확인하라고 했다.

기획은 B 얘기만 계속했다.

그때 고객이 수고했다면서 회의실을 나가려고 했다.

A는 어떻게 결정된 거냐고 내가 물었다.

고객은 추가 요청 A를 하기로 한 거 아니 냔다.

기획이 당황하면서 A는 뭐냐고 한다.

다시 회의를 했다.

일 잘한다고 소문난 임원급 기획이었다.

글쓰기를 공부하면 이런 상황이 발생하지 않는다.

회의의 주제를 정하고 정리한 뒤 결론을 적는다면 이런 불상사는 발생하지 않는다.

만약 내가 체크하지 않았다면 고객의 추가 요청 A는 물 건너가고 나중에 이슈가 되었을 것이다.

 

개발자 글쓰기로 얻는 효과는?

생각하는 힘을 키울 수 있다.

글을 써보면 안다.

생각을 안 할 수가 없다.

판단하는 힘도 키울 수 있다.

프로젝트 진행 시 판단을 잘못해서 고생하는 경우가 많다.

리더가 잘못된 판단을 해서 고생한 기억이 있을 것이다.

설득하는 힘을 키울 수 있다.

O2O 프로젝트 진행할 때였다.

개발자들은 오픈을 앞두고 마지막까지 일정을 맞추기 위해 고군분투 중이었다.

추가 개발을 할 수 있는 틈이 없었다.

만약 이 상황에서 개발자들에게 추가로~라는 말을 꺼내면 짜증 대폭발과 함께 도망갈 분위기였다.

어느 날,

고객이 와서 추가 개발을 요청했다.

개발자는 지금 일정으로 불가능하다고 했다.

고객도 위에서 요청이 오고 계약된 부분이라 꼭 해야 한다고 했다.

시끄러워졌다.

리더가 상황을 보더니 개발자에게 고객이 요청한 부분을 개발하자고 한다.

개발자는 못한다고 화를 냈다.

다들 난처한 상황이 된 것이다.

고객은 다시 일정을 확인해 본다고 올라갔다.

여기서 생각의 힘이 필요하다.

그리고 판단의 힘도 필요하다.

고객이 돌아왔다.

일정을 확인했지만 계약 때문에 꼭 해야 한다고 했다.

지금 진행하는 것도 해야 한다고 하면서.. 어쩌죠?라는 표정을 짓는다.

만약 리더가 둘 다 할게요라는 잘못된 판단을 내리면 상황은 더 악화될 것이다.

이때는 설득의 힘이 필요하다.

계약 때문에 추가 개발이 먼저 진행해야 한다면 바꿀 수 없다.

현재 진행 중인 일정은 계약과 관계가 없고 일정만 조정하면 되는 일이다.

우선 추가건을 먼저 하고 나서 다시 이어 하는 것으로 설득했다.

 

글쓰기를 잘하면 모든 상황에서 생각, 판단, 설득의 능력도 발달하게 된다.

 

그럼 글쓰기 공부는 어떻게 하나요?

처음 이야기 했던 책을 읽으면 된다.

글쓰기 책은 많다.

사진: Unsplash 의 Unseen Studio

나도 많은 책을 읽어봤지만 어떤 책은 초반에 덮은 적도 있다.

글쓰기 공부에 적합한 책 2권을 추천해 본다.

"기자의 글쓰기, 박종인"

"150년 하버드 글쓰기 비법, 송숙희"

이 책들을 읽으면 공통점을 찾을 수 있다.

자신에게 맞는 부분을 잘 적용해서 매일 꾸준히 글을 써보자.

운동하면 근육이 생기듯,

반복적으로 하면 달인이 되듯

글쓰기도 매일 습관일 들여서 하면 근육이 생긴다.

개발자에게 글쓰기는 필수 능력이다.

반응형